84669 personnes étudient
152542 personnes étudient
20005 personnes étudient
5487 personnes étudient
7821 personnes étudient
359900 personnes étudient
3350 personnes étudient
180660 personnes étudient
48569 personnes étudient
18603 personnes étudient
40936 personnes étudient
1549 personnes étudient
1183 personnes étudient
32909 personnes étudient
查询一张表中table_a中,有aid, bid, 查询记录,存在所有成对的记录,例如 aid = 10, bid = 11,如果存在aid = 11, bid = 10,就把这两条记录同时查出来,不存在则跳过。该怎么写呢?
table_a
aid, bid
aid = 10, bid = 11
aid = 11, bid = 10
select * from table_a where (aid, bid) in (select bid, aid from table_a )
这样写正确嘛?如果不对该怎么写呢?
闭关修行中......
很简单:
SELECT T.aid, T.bid FROM table_a T INNER JOIN table_a S ON T.aid = S.bid AND T.bid = S.aid
或者
SELECT T.aid, T.bid FROM table_a T, table_a S WHERE T.aid = S.bid AND T.bid = S.aid
也一样。
怎么判断aid bid是不是成对?
SELECT * FROM `table_a` WHERE concat ((aid*bid),'_',(aid+bid)) in ( SELECT concat((aid*bid),'_',(aid+bid)) FROM `table_a` GROUP BY (aid*bid),(aid+bid) HAVING count(id)>1 )
不知道这样子行不行(不行就当作是一种思路吧)
很简单:
或者
也一样。
怎么判断aid bid是不是成对?
不知道这样子行不行(不行就当作是一种思路吧)