> 데이터 베이스 > MySQL 튜토리얼 > mysql 左连接 自连接 例证

mysql 左连接 自连接 例证

WBOY
풀어 주다: 2016-06-07 16:25:35
원래의
1166명이 탐색했습니다.

mysql 左连接 自连接 例子 连接就是将两个表按照某个公共字段来拼成一个大表。 左连接就是在做连接是以左边这个表为标准,来遍历右边的表。 1、引子 左连接,自连接 SELECT * FROM test_visit t1 LEFT JOIN test_visit t2 ON t1.uid = t2.uid 结果: 2、问题

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='北京卫视' )
로그인 후 복사


结果:


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

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿