码迷,mamicode.com
首页 > 数据库 > 详细

工作随笔——mysql子查询删除原表数据

时间:2015-09-22 16:06:24      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:

最近在开发的时候遇到一个mysql的子查询删除原表数据的问题。在网上也看了很多方法,基本也是然并卵(不是写的太乱就是效率太慢)。

公司DBA给了一个很好的解决方案,让人耳目一新。

 DELETE fb.* FROM froadbill.bill fb LEFT JOIN froadbill.refundinfo br ON br.billSeqNo = fb.seq_no WHERE br.billSeqNo IS NULL AND fb.create_time >=20150102000000  AND fb.create_time <20150302000000 ;

froadbill.bill是账单表(约1kw数据),froadbill.refundinfo是退款表(约10w数据)。这条sql是要删除账单表20150102-20150302并且不在退款表的数据。这种写法避免了在sql中使用in或者not in这种低效的语句。

数据插入也可以使用这种写法:

INSERT INTO froadbill.bill_history SELECT DISTINCT fb.* FROM froadbill.bill fb LEFT JOIN froadbill.refundinfo br ON br.billSeqNo = fb.seq_no WHERE br.billSeqNo IS NULL AND fb.create_time >=‘20150102000000‘  AND fb.create_time <‘20150302000000‘ ;

 

  

工作随笔——mysql子查询删除原表数据

标签:

原文地址:http://www.cnblogs.com/zz0412/p/4828819.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!