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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

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

1
2
3
4
5
6
7
8
9
kkmlmysqlpass=$( cat  /usr/local/kk-ml/config/custom .conf |  grep  -w  "pass"  awk  -F " "  '{print $NF}' )
/usr/local/kk-ml/service/mysql/bin/mysql  -u kkml -p$kkmlmysqlpass kkml -e  "select * from core_mailbox where mailbox_id not in (select mailbox_id from co_user);"  > /root/chaji .txt
cat  /root/test .txt |  awk  -F " "  '{print $1"\t"$2}'  sed  1d > /root/chaji_id .txt
cat  /root/chaji_id .txt |  while  read  LINE
do
  mailbox_id=$( echo  $LINE | awk   '{print $1}' )
  domain_id=$( echo  $LINE | awk   '{print $2}' )
  /usr/local/kk-ml/service/mysql/bin/mysql  -u kkml -p$kkmlmysqlpass kkml -e  "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');"
done


备注(大神方法):

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

于是再改为下面的这样:

select cu.mailbox_id,cm.mailbox_id  co_user as cu 
    left join core_mailbox as cm 
      on cu.mailbox_id = cm.mailbox_id 
        where cm.mailbox_id  NULL;

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

后面也在网上找了这条:

SELECT mailbox_id FROM `co_user` left join 
(select mailbox_id as i from core_mailbox) as t1
on co_user.mailbox_id= t1.i where t1.i is NULL;

概念上与第二条同理。

 

好吧! 回顾了一下left join

SQL LEFT JOIN 关键字

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




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

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
265
分享
相关文章
Postgres使用序列实现主键自增基于navcat操作
Postgres使用序列实现主键自增基于navcat操作
151 0
SQL INSERT INTO order_record SELECT * FROM 从一张表查出数据插入到另一张表
SQL INSERT INTO order_record SELECT * FROM 从一张表查出数据插入到另一张表
52 0
sqlite语句order by两个字段同时排序处理
sqlite语句order by两个字段同时排序处理
115 0
|
11月前
|
SQL INSERT INTO 语句详解:插入新记录、多行插入和自增字段
SQL INSERT INTO 语句用于在表中插入新记录。
996 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等