纵有疾风起
人生不言弃

mysql中比较两个表中的数据sql语句

在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语句
分享到: 生成海报

评论 抢沙发

评论前必须登录!

立即登录