SQLException: ORA-01795 异常

SQLException: ORA-01795: maximum number of expressions in a list is 1000
大家在用IN条件语句的时候可能用忽略一种情况
比如说:
UPDATE MERCHANT_ID SET STATUS = 'A' WHERE MERCHANT_ID IN (1,2,3,4,5,6,7,8,9,10);
我们需要更新,把10个Merchant的Status变成'A'.
IN clause里面有10个List Items, Merchant_id分别1,2,3,4,5,6,7,8,9,10

从1到10,这个SQL Statement是没有问题 从1到1000也是没有问题

UPDATE MERCHANT_ID SET STATUS = 'A' WHERE MERCHANT_ID IN (1,2,3,4,5,6,7,8,9,10......999,1000,1001);
但是一但超过1000个的话, 以上的异常就是出来

最土最土的解决方法可能就是:
UPDATE MERCHANT_ID SET STATUS = 'A' WHERE MERCHANT_ID IN (1,2,3,4,5,6,7,8,9,10......999,1000)
OR MERCHANT_ID IN (1001,1002,1003.....1999,2000
OR MERCHANT_ID IN (2001,2002,2003.....2999,3000);
这效率却不是很高
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值