有两个表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 |
当两个表的数据量都较多,例如都超过10万条,此时需要给package_name加索引,提高查询效率。
时间: 2025-01-27 04:40:50