A-A+

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

2017年10月17日 PHP技术文章 暂无评论 阅读 0 views 次

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

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

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

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

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

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 //开源代码www.xiariboke.net

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

标签:

给我留言