oracle – RAW类型变量是否在PL / SQL代码中不可变?

RAW类型变量是否在PL / sql代码中不可变?我的意思是可以在没有内存复制的情况下改变RAW类型变量的特定字节吗?

当然,我们有一些适用于规范字节改变的例程的UTL_RAW包,但是它们似乎都是复制变量实例内存:

UTL_RAW.BIT_AND UTL_RAW.BIT_OR UTL_RAW.OVERLAY

此问题与有效的字符串连接问题密切相关.例如在Java字符串中是不可变的,我们有这个任务的StringBuilder.
我没有在Oracle文档中找到明确的信息.经过一番搜索[1],答案看起来像:是的. RAW类型变量在PL / sql代码以及字符串中都是不可变的.真的是真的吗对这个问题有更多的解释和历史会更好.

参考文献:

> https://asktom.oracle.com/pls/apex/f?p=100:11:0::::P11_QUESTION_ID:10445025326812#followup-76860752200038

在PL / sql中没有更改分配给变量的内存的特定子部分.如果它是一个函数(与所述utl_raw例程一样),它总是返回值的新实例.如果它是一个带有out nocopy参数的过程,它可能在 reference to the argument上工作,而不是在其副本上,但仍然是,该过程中的实际工作涉及复制值,而不是在同一个内存中工作. (好的,这不适用于LOB,但这不是你所问的.)

PL / sqlsql之上的一种程序语言.它旨在允许sql在程序上使用,它不是设计为超快,超有效.如果您需要直接在内存中更改字节,则可能需要使用C或汇编器.

相关文章

数据库版本:11.2.0.4 RAC(1)问题现象从EM里面可以看到,在23号早上8:45~8:55时,数据库等待会话暴增...
(一)问题背景最近在对一个大约200万行数据的表查看执行计划时,发现存在异常,理论上应该返回100多万...
(一)删除备份--DELETE命令用于删除RMAN备份记录及相应的物理文件。当使用RMAN执行备份操作时,会在RM...
(1)DRA介绍 数据恢复顾问(Data Recovery Advise)是一个诊断和修复数据库的工具,DRA能够修复数据文...
RMAN(Recovery Manager)是Oracle恢复管理器的简称,是集数据库备份(backup)、修复(restore)和恢复...
(1)备份对象 可以使用RMAN进行的备份对象如下: --整个数据库:备份所有的数据文件和控制文件; --数...