mysql 左连接 自连接 样例
连接就是将两个表依照某个公共字段来拼成一个大表。
左连接就是在做连接是以左边这个表为标准,来遍历右边的表。
1、引子
左连接,自连接
SELECT * FROM test_visit t1 LEFT JOIN test_visit t2 ON t1.uid = t2.uid
结果:
2、问题 样例:
用户訪问记录:
问题:查出看了湖南卫视但没有看北京卫视的用户信息
逻辑:先通过左连接将看了湖南卫视和北京卫视的查出来。然后再将看了湖南卫视但不在刚才查出的结果中的用户查出来。
SELECT * FROM test_visit WHERE channel='湖南卫视' AND uid NOT IN ( SELECT DISTINCT t1.uid FROM test_visit t1 LEFT JOIN test_visit t2 ON t1.uid = t2.uid WHERE t1.channel='湖南卫视' AND t2.channel='北京卫视' )
各位大神,有什么好的方法,说说吧。我感觉这个不是最优的