天天看点

对比2个表mailbox_id字段的差集,然后做插入操作

对比2个表mailbox_id字段的差集,并导出。然后利用循环insert插入。

1

2

3

4

5

6

7

8

9

<code>kkmlmysqlpass=$(</code><code>cat</code> <code>/usr/local/kk-ml/config/custom</code><code>.conf | </code><code>grep</code> <code>-w </code><code>"pass"</code> <code>| </code><code>awk</code> <code>-F</code><code>" "</code> <code>'{print $NF}'</code><code>)</code>

<code>/usr/local/kk-ml/service/mysql/bin/mysql</code> <code>-u kkml -p$kkmlmysqlpass kkml -e </code><code>"select * from core_mailbox where mailbox_id not in (select mailbox_id from co_user);"</code> <code>&gt;</code><code>/root/chaji</code><code>.txt</code>

<code>cat</code> <code>/root/test</code><code>.txt | </code><code>awk</code> <code>-F</code><code>" "</code> <code>'{print $1"\t"$2}'</code> <code>| </code><code>sed</code> <code>1d &gt;</code><code>/root/chaji_id</code><code>.txt</code>

<code>cat</code> <code>/root/chaji_id</code><code>.txt | </code><code>while</code> <code>read</code> <code>LINE</code>

<code>do</code>

<code> </code><code>mailbox_id=$(</code><code>echo</code> <code>$LINE |</code><code>awk</code>  <code>'{print $1}'</code><code>)</code>

<code> </code><code>domain_id=$(</code><code>echo</code> <code>$LINE |</code><code>awk</code>  <code>'{print $2}'</code><code>)</code>

<code> </code><code>/usr/local/kk-ml/service/mysql/bin/mysql</code> <code>-u kkml -p$kkmlmysqlpass kkml -e </code><code>"insert into co_user(mailbox_id,domain_id,realname,engname,oabshow,showorder,eenumber,gender,birthday,homepage,tel_mobile,tel_home,tel_work,tel_work_ext,tel_group,im_qq,im_msn,addr_country,addr_state,addr_city,addr_address,addr_zip,remark,last_session,last_login,openid,unionid,wx_id) values('$mailbox_id','$domain_id','testdel2','NULL','1','0','NULL','male','0000-00-00','NULL','NULL','NULL','NULL','NULL','NULL','NULL','NULL','NULL','NULL','NULL','NULL','NULL','NULL','NULL','NULL','0','0','0');"</code>

<code>done</code>

备注(大神方法):

好吧!这个是可以,但是数据多了的话,想到这个查询的逻辑有点受不住

于是再改为下面的这样:

利用了left join的,然后进行对比,并且利用where进行筛选。

后面也在网上找了这条:

概念上与第二条同理。

好吧! 回顾了一下left join

LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。

本文转自 sailikung 51CTO博客,原文链接:http://blog.51cto.com/net881004/2054820,如需转载请自行联系原作者