时间: 2020-09-25|tag:37次围观|0 条评论

在mysql中我们要比较两个数据表中数据是否相同我们可以使用联合查询了,关于mysql中的联合查询有很多种,下面我整理两条语句.

有两个表t_appinfo 和g_appinfo,存储的信息基本一致,都包含package_name这个字段,现在需要查出package_name 存在于t_appinfo表,而且不存在于g_appinfo表的记录.

方法一:使用NOT EXISTS,代码如下:

  1. SELECT a.name,a.package_name FROM t_appinfo a 
  2. WHERE NOT EXISTS (SELECT 1 FROM g_appinfo g WHERE a.package_name=g.p_packagename) LIMIT 10000 

方法二:使用NOT IN,代码如下:

  1. SELECT a.name , a.package_name FROM t_appinfo a WHERE a.package_name NOT IN (SELECT g.p_packagename FROM g_appinfo g )    LIMIT 50000 //开源代码phpfensi.com 

当两个表的数据量都较多,例如都超过10万条,此时需要给package_name加索引,提高查询效率.

 

本博客所有文章如无特别注明均为原创。
复制或转载请以超链接形式注明转自起风了,原文地址《mysql中比较两个表中的数据sql语句
   

还没有人抢沙发呢~