sql数据订正学习

  最近一段做的比较多的就是数据订正,各种各样的用户问题,要快速解决的话,最直接的途径就是数据订正。但是如果按照之前的操作,做大批量数据订正的时候,效率就很低,所以重新开始了学习。公司用的数据库目前为oracle

一.多表关联更新操作

    有次遇到一张表的数据某个字段有问题,必须要用另一表的数据重新更新下,共有500多条数据需要订正。只是涉及到数据内容更换,如果涉及需要把更换内容通知到第三方接口等,就必须开发一个任务,但当时从预期来看,只要把数据订正过来,避免后续产生问题即可。

  第一次采取的办法是,通过查询程序获得要进行订正数据,然后使用程序或者excel生成多条sql语句,由于系统执行的sql条数长度有限制,所以提交几次之后,决定放弃了,太浪费劳动力了;

  第二次直接采取sql语句,进行两表关系更新操作,sql如下:

update table1 a set a.modifier='xxx',gmt_modified=sysdate, a.member_id =(select member_id from table2 b where b.member_id_old=a.member_id and b.member_id!=a.member_id and a.member_id >'b' and a.member_id<'o' and a.is_deleted='n' and b.is_deleted='n' and a.av_object in ('ov','etp'))  where exists (select 1 from global_account b where b.member_id_old=a.member_id and b.member_id!=a.member_id and a.member_id >'b' and a.member_id<'o' and a.is_deleted='n' and b.is_deleted='n' and a.av_object in ('ov','etp')) 
 运行几次后,更新成功;

大概的格式为:

update table1 a set a.column1 = (select b.cloumn2 from table2 b) where exists xxxx;


二.插入表操作

 之前有个故障处理,需要对一张表做insert操作,但是此表段很多很多,按照最简单的insert table1(xx...)valus(xxx...),看那些赋值累死,于是采取了复制插入的办法,找了条内容差不多的数据,小做几个字段的修改后,就可以了。sql如下:

insert into table1  (ID, IS_DELETED, CREATOR, GMT_CREATE, MODIFIER, GMT_MODIFIED, xxx....)select SEQ_table1.nextval, IS_DELETED, CREATOR, sysdate, xxxx... from table1 where id=xxx


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值