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

oracle – RAW类型变量是否在PLSQL代码中不可变?,第1张

概述RAW类型变量是否在PL / SQL代码中不可变?我的意思是可以在没有内存复制的情况下改变RAW类型变量的特定字节吗? 当然,我们有一些适用于规范字节改变的例程的UTL_RAW包,但是它们似乎都是复制变量实例内存: UTL_RAW.BIT_AND UTL_RAW.BIT_OR UTL_RAW.OVERLAY 此问题与有效的字符串连接问题密切相关.例如在Java字符串中是不可变的,我们有这个任务的S 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 / sql是sql之上的一种程序语言.它旨在允许sql在程序上使用,它不是设计为超快,超有效.如果您需要直接在内存中更改字节,则可能需要使用C或汇编器.

总结

以上是内存溢出为你收集整理的oracle – RAW类型变量是否在PL / SQL代码中不可变?全部内容,希望文章能够帮你解决oracle – RAW类型变量是否在PL / SQL代码中不可变?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1167268.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存