IN OUT NOCOPY 分析

本文探讨了PL/SQL中IN、OUT、IN OUT参数类型的使用,特别是NOCOPY特性对性能的影响。NOCOPY在处理大数据量参数如collections、records和object types时能提升效率。未使用NOCOPY时,OUT或IN OUT参数会按值传递,异常发生不会改变实参;使用NOCOPY则按引用传递,异常情况下实参会被修改且无法回滚到初始状态。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当我们声明一个参数是IN类型时,进行传参是将传给该参数一个实参的指针;

当我们声明一个参数是OUT或者IN OUT类型时,进行传参是将传给该参数一个实参的拷贝;

只有当程序正常结束时,赋给OUT或者IN OUT类型参数的值才会返回(除非使用了NOCOPY)。

将NOCOPY应用在传递数据量很大的参数(such as collections, records, and instances of object types)时,可起到优化性能的作用。

当参数是OUT或者IN OUT类型时:没有NOCOPY=按值传递(ByVal);加上NOCOPY=按引用传递(ByRef)。


pl/sql中对out,in out参数使用的?默认形参会复制一份实参的副本,然后在内部传递,修改等,发生异常,不会赋值给实参,控制权交还调用环境,

而实参值不变,还是调用前的值。而使用了nocopy后,形参将获得一个指向实参的指针,然后在内部传递,赋值都直接修改实参了,此时如果异常发生,

控制权交还调用环境,但是实参已经被修改了。无法还原成调用前的值。


PS:如果没有NOCOPY ,如果函数中间报错退出,NOCOPY参数还是原来的值,

    如果有NOCOPY,中间出错后,如果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值