merge into update操作时能不能批量更新
我今天在用mergeintoupdate操作时批量更新报ora-30926无法在源表中获得一组稳定的数据具体sqlififlage=1then--dbms_output....
我今天在用 merge into update 操作时批量更新 报ora-30926 无法在源表中获得一组稳定的数据
具体sql
if iflage = 1 then
-- dbms_output.put_line(iflage);
merge into res_fourtwoproject res
using (select * from CORRECTLY_RES_FOURTWOPROJECT s where s.batch=p_batch) c --按照某个条件查询数据集
on (res.IYEAR=years and res.SWEEKNUM = weeks and res.SSITENAME = c.SSITENAME)
when matched then --存在就更新
update set
res.SCOMPANYNAME=c.SCOMPANYNAME,
res.SLISTTYPE = c.SLISTTYPE,res.STHREETOONEUNIQUE=c.STHREETOONEUNIQUE,
--res.STHREETOONEUNIQUE=c.STHREETOONEUNIQUE,
求大神救我,跪谢 展开
具体sql
if iflage = 1 then
-- dbms_output.put_line(iflage);
merge into res_fourtwoproject res
using (select * from CORRECTLY_RES_FOURTWOPROJECT s where s.batch=p_batch) c --按照某个条件查询数据集
on (res.IYEAR=years and res.SWEEKNUM = weeks and res.SSITENAME = c.SSITENAME)
when matched then --存在就更新
update set
res.SCOMPANYNAME=c.SCOMPANYNAME,
res.SLISTTYPE = c.SLISTTYPE,res.STHREETOONEUNIQUE=c.STHREETOONEUNIQUE,
--res.STHREETOONEUNIQUE=c.STHREETOONEUNIQUE,
求大神救我,跪谢 展开
2个回答
展开全部
可以批量更新的,但是你要保证更新的值是唯一的:合并的两个表以“res.IYEAR=years and res.SWEEKNUM = weeks and res.SSITENAME = c.SSITENAME”这个条件关联应该要一一对应才能更新,不然就会报错
建议查出这两个表里的数据存在多条,然后groupby一下,保证一一对应关系
建议查出这两个表里的数据存在多条,然后groupby一下,保证一一对应关系
追问
using (select * from CORRECTLY_RES_FOURTWOPROJECT s where s.batch=p_batch) 这条语句如果查出来的是个集合就有问题,如果是单条数据的话就没问题
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询