2017-03-13Tsql 表连接

Posted 丶蘇Da同

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2017-03-13Tsql 表连接相关的知识,希望对你有一定的参考价值。

笛卡尔积          穷举

在未建立连接的情况下,将car表的name列和brand表的brand_name列进行笛卡尔积查询后,实际是将两列相乘,进行穷举,列举出所有可能性

 

表连接:将多个表不同列的数据查询到一起

1.横向连接

select 列a,列b from 表p,表q where p.o=q.o         o为两表中同时拥有的一列

另一种写法 select 列a,列b from 表p join 表q on p.o=q.o

例:select Student.Sno,Sname,Cno,Degree from Student,Score where Student.Sno=Score.Sno

=   select Student.Sno,Sname,Cno,Degree from Student join Score on Student.Sno=Score.Sno 

 

在 join前加上left 是以 join左边的表为主      select Student.Sno,Sname,Cno,Degree from Student left join Scroe on Student.Sno=Scroe.Sno 

在 join前加上right是以join右边的表为主      select Student.Sno,Sname,Cno,Degree from Student right join Scroe on Student.Sno=Scroe.Sno

 

2.纵向连接      两个表之间添加  union

只有两个表列数一样,每列对应的数据类型一样,才可以进行纵连接

以上是关于2017-03-13Tsql 表连接的主要内容,如果未能解决你的问题,请参考以下文章

表连接Tsql基本编程和存储过程

连接使用表值函数创建的表时优化 TSQL

TSQL - 加入表的正确顺序是啥?

不存在的 TSQL 循环

TSQL IVF 导致 ASP.net 应用程序超时

TSQL - 游标中返回的空行