加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-12 13:04:29 所属栏目:百科 来源:网络整理
导读:RAW类型变量是否在PL / SQL代码中不可变?我的意思是可以在没有内存复制的情况下改变RAW类型变量的特定字节吗? 当然,我们有一些适用于规范字节改变的例程的UTL_RAW包,但是它们似乎都是复制变量实例内存: UTL_RAW.BIT_AND UTL_RAW.BIT_OR UTL_RAW.OVERLAY
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或汇编器.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读