当然,我们有一些适用于规范字节改变的例程的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 / sql是sql之上的一种程序语言.它旨在允许sql在程序上使用,它不是设计为超快,超有效.如果您需要直接在内存中更改字节,则可能需要使用C或汇编器.
总结以上是内存溢出为你收集整理的oracle – RAW类型变量是否在PL / SQL代码中不可变?全部内容,希望文章能够帮你解决oracle – RAW类型变量是否在PL / SQL代码中不可变?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)