SQL语句两表联查

时间:2018.07.25 发布人:AI韩庚GENG

SQL语句两表联查

已解决问题

谷歌AI韩庚GENG用户在2018.07.25提交了关于“乔丹SQL语句两表联查”的提问,欢迎大家涌跃发表自己的观点。目前共有1个回答,最后更新于2025-02-16T16:50:59。希望大家能够帮助她。

详细问题描述及疑问:期待您的答案,你就是当代的活雷锋,太感谢了 !

希望以下的回答,能够帮助你。

第1个回答

用户名:匿名用户  

可以用谓词或联结实现:

连接实现:

select*fr半热对皮ombjoinaonb.id=a.idwherea.b=21

联结实现的条件是两表id来自同一值域,表示意义相同.在连接时其实两可以作成一个表的:

也就是

id,a.b,a.c英格,b.b.b.c

但由于空值的问题,导致了部分依赖所以才会拆分成两个表的.

使用谓词实现:

select*fro由六兵吧研mbwhereidin(selectidfromawh赶目烟士室报怕花越势十erea.b=21)

这个可以实现两表id来自同一值域,但表示意义不同的情况.也就是说两表中的id有该稳真坐助尽孙增无关性.

相比较而言,连接的方式更快一些,但这种情况是两表来自同一值域,且意义相给仍孩同,如果不是这种情况,可能得不到你正确的值的.而使用谓词不管意义是争投里束甚帮语业否相同,都可以得到正确的值.

玩**库必须知道这两个表是否具有相关性,也就是设计时的意义,否则优化词句什么的都没有办法去做的!

有几种方式可以实现你的这个需求.

1.使用表关联

**LECT*FROM表2JOIN表1ON(表2.ID=表1.列1);

2.使用IN

**LECT*FROM表2才硫了艺元本三利同煤它Wh**EREIDIN(**LECT列1FROM表1);

3.使用EXIST轮免汽高S

**LECT*FROM表2

Wh**EREEXISTS(乡千刚序殖色**LECT1FROM表完看花比练度胜帮度急洋1Wh**ERE表2.ID高=表1.列1);

饭接岩四误功select*fromt2leftjoint1on***.ID=t1.列1wheret1需要啥条件an半封须史服企而操官dt2需要啥条件

select*from表2where某列in(select列盾球负经拉贵取加其条措1from表1)andid=1