mysql左连接自连接例子_MySQL

WBOY
WBOYオリジナル
2016-06-01 13:16:231051ブラウズ

连接就是将两个表按照某个公共字段来拼成一个大表。

左连接就是在做连接是以左边这个表为标准,来遍历右边的表。

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.uidWHERE t1.channel='湖南卫视' AND t2.channel='北京卫视' )
结果:

/

各位大神,有什么好的方法,说说吧,我感觉这个不是最优的

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。