繁体   English   中英

SQL-另一个表中不存在SELECT行

[英]SQL - SELECT rows NOT EXISTS in another table

我试图基于表A选择表B不存在的行。

与表B不同,表A在titleid的末尾具有“ _00”,并且该列称为title而不是titleid

表A

id | titleid
---+----------
1  | TEST1_00
2  | TEST2_00
3  | TEST3_00
4  | TEST4_00

表B

id | title
---+-------
1  | TEST1
2  | TEST2

我目前有:

SELECT `t1.titleid`
FROM `tableb t1`
LEFT JOIN `tablea t2` ON `t2.title + '_00' = t1.titleid`
WHERE `t2.title` IS NULL

如何选择A中存在但B不存在的值?


所需的输出

id | title
---+----------
3  | TEST3_00
4  | TEST4_00
 SELECT t1.titleid
 FROM tablea t1
 LEFT JOIN tableb t2 ON t2.title + '_00' = t1.titleid
 WHERE t2.title IS NULL

您要从Table A提取数据,对Table B进行left join ,并where TableB.Title is null提取数据。

您的查询试图where TableA.Title is NULL提取数据。

如果tablea则需要LEFT JOIN tableb代替

SELECT `t1.titleid`
FROM `tablea t1`
LEFT JOIN `tableb t2` ON `t1.titleid = t2.title+ '_00'`
WHERE `t2.title` IS NULL

这将显示tablea哪些记录在tableb不匹配并且为null

可以这样做

SELECT `t1.titleid`
FROM `tablea t1`

WHERE 
NOT EXISTS (SELECT t2.title FROM `tableb t2` WHERE `t1.titleid = t2.title+ '_00'`)
select * from A where SUBSTRING(A.title,0, 6) in (select B.title from B )

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM