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

前端之家收集整理的这篇文章主要介绍了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或汇编器.

猜你在找的Oracle相关文章