mssql链接mysql查询语句_MSSQL 详解SQL Server连接(内连接、外连接、交叉连接)

在查询多个表时,我们经常会用“连接查询”。连接是关系数据库模型的主要特点,也是它区别于其它类型数据库管理系统的一个标志。

什么是连接查询呢?

概念:根据两个表或多个表的列之间的关系,从这些表中查询数据。

目的:实现多个表查询操作。

知道了连接查询的概念之后,什么时候用连接查询呢?

一般是用作关联两张或两张以上的数据表时用的。看起来有点抽象,我们举个例子,做两张表:学生表(T_student)和班级表(T_class)

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 --创建DB

2 --filename修改为自己电脑上MSSQL存储的位置

3 create databaseMyTestDB4 on primary

5 (6 name='MyTestDB',7 filename='D:\yangZ_MSSQL\MyTestDB.mdf',8 size=10mb,9 maxsize=100mb,10 filegrowth=10%

11 )12 log on

13 (14 name='MyTestDB_log',15 filename='D:\yangZ_MSSQL\MyTestDB_log.ldf',16 size=2mb,17 maxsize=100mb,18 filegrowth=5mb19 )20 ---------------------------------------------

21 useMyTestDB22 go

23

24 create tableT_Student25 (26 id int identity(1,1) primary key,27 student nvarchar(100) not null,28 classId int not null

29 )30

31 create tableT_Class32 (33 classId int identity(1,1) primary key,34 chassName nvarchar(100) not null

35 )36 -------------------------------------------

37 ---设置T_Student classId字段为外键

38 alter table T_Student add constraint FK_T_Student_classId foreign key(classId) referencesT_Class(classId)39 --增加外键约束时,设置【级联更新、级联删除】:来保证,当主键表中的记录发生改变时候,对应的外键表中的数据也发生相应的改变。

40 on delete cascade

41 on update cascade

42

43 ---删除外键

44 alter table T_Student drop constraintFK_T_Student_classId45

46 -------------------------------------------

47 insert intoT_Class48 select '一班' union all

49 select '二班' union all

50 select '三班' union all

51 select '四班'

52 go

53

54 insert intoT_Student55 select '老赵',1 union all

56 select '老钱',2 union all

57 select '老孙',3 union all

58 select '老李',5

59 go

60 -------------------------------------------

61 select * fromT_Student62 select * from T_Class

MSSQL create DB and Table(T_Student/T_Class)

ffc3e359a4eb8ac027bfc60606ec9fbb.png

连接标准语法格式:

SQL-92标准所定义的FROM子句的连接语法格式为:

FROM join_table join_type join_table[ON (join_condition)]

其中join_table指出参与连接操作的表名,连接可以对同一个表操作,也可以对多表操作,对同一个表操作的连接又称做自连接。join_type 指出连接类型。join_condition指连接条件。

连接类型:

连接分为三种:内连接(INNER JOIN)、外连接、交叉连接(CROSS JOIN)[也称迪卡尔积]。

内连接: 等值连接、不等连接、自然连接

外连接: 左连接(LEFT JOIN/LEFT OUTER JOIN)、右连接(RIGHT JOIN/RIGHT OUTER JOIN)和全连接(FULL JOIN/FULL OUTER JOIN)

交叉连接: 不带where、有where子句

内连接(INNER JOIN)

使用比较运算符(包括=、>、、>=、<=、!>和!

1、等值连接

概念:在连接条件中使用等于号(=)运算符,其查询结果中列出被连接表中的所有列,包括其中的重复列。

1 select * from T_Student as s,T_Class asc2 where s.classId =c.classId3 --等价于下面的写法

4 select * from T_student s inner join T_class c on s.classId = c.classId

MSSQL查询结果为:

c8964abcce456f1dbc6bd2cc04c2c698.png

2、不等连接

概念:在连接条件中使用除等于号之外运算符(>、、>=、<=、!>和!

1 select * from T_Student as s, T_Class asc2 where s.classId <>c.classId3 --等价于下面的写法

4 select * from T_Student s inner join T_Class c on s.classId <> c.classId

MSSQL查询结果为:

642ec708306199f07c05f0a3bd861fa4.png

3、自然连接

概念:连接条件和等值连接相同,但是会删除连接表中的重复列。

查询语句同等值连接基本相同:

1 select s.*,c.chassName from T_student s inner join T_class c on s.classId = c.classId

MSSQL查询结果为:

c91f186d6eca798dfd517ddb8d1a4edb.png

总结:内连接是只显示满足条件的!

外连接

外连接分为左连接(LEFT JOIN)或左外连接(LEFT OUTER JOIN)、右连接(RIGHT JOIN)或右外连接(RIGHT OUTER JOIN)、全连接(FULL JOIN)或全外连接(FULL OUTER JOIN)。我们就简单的叫:左连接、右连接和全连接。

1、左连接:

概念:返回左表中的所有行,如果左表中行在右表中没有匹配行,则结果中右表中的列返回空值。

1 select * from T_student s left join T_class c on s.classId = c.classId

MSSQL查询结果为:

aa4068abac12ebb5fb9f9e5a6747b127.png

总结:左连接显示左表全部行,和右表与左表相同行。

2、右连接:

概念:恰与左连接相反,返回右表中的所有行,如果右表中行在左表中没有匹配行,则结果中左表中的列返回空值

1 select * from T_student s right join T_class c on s.classId = c.classId

MSSQL查询结果为:

57e55722427f913a81a799f7d427be0b.png

总结:右连接恰与左连接相反,显示右表全部行,和左表与右表相同行。

3、全连接:

概念:返回左表和右表中的所有行。当某行在另一表中没有匹配行,则另一表中的列返回空值

1 select * from T_student s full join T_class c on s.classId = c.classId

MSSQL查询结果为:

cee85b00f2c4b676778db86c22d0b819.png

总结:返回左表和右表中的所有行。

交叉连接(CROSS JOIN):也称迪卡尔积

概念:不带WHERE条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积(例如:T_student和T_class,返回4*4=16条记录),

如果带where,返回或显示的是匹配的行数。

1、不带where:

1 select *from T_student cross joinT_class2 --等于

3 select *from T_student, T_class

MSSQL查询结果为:

44c9deb79c8fadabffc742fe5530716f.png

总结:相当与笛卡尔积,左表和右表组合。

2、有where子句,往往会先生成两个表行数乘积的数据表,然后才根据where条件从中选择。

1 select * from T_student s cross join T_class c where s.classId =c.classId2 --(注:cross join后加条件只能用where,不能用on)

MSSQL查询结果为:

7aa9cd94acd70f951138269b536b99a4.png

查询结果跟等值连接的查询结果是一样。

MSSQL全部源码参考:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 --创建DB

2 --filename修改为自己电脑上MSSQL存储的位置

3 create databaseMyTestDB4 on primary

5 (6 name='MyTestDB',7 filename='D:\yangZ_MSSQL\MyTestDB.mdf',8 size=10mb,9 maxsize=100mb,10 filegrowth=10%

11 )12 log on

13 (14 name='MyTestDB_log',15 filename='D:\yangZ_MSSQL\MyTestDB_log.ldf',16 size=2mb,17 maxsize=100mb,18 filegrowth=5mb19 )20 ---------------------------------------------

21 useMyTestDB22 go

23

24 create tableT_Student25 (26 id int identity(1,1) primary key,27 student nvarchar(100) not null,28 classId int not null

29 )30

31 create tableT_Class32 (33 classId int identity(1,1) primary key,34 chassName nvarchar(100) not null

35 )36 -------------------------------------------

37 ---设置T_Student classId字段为外键

38 alter table T_Student add constraint FK_T_Student_classId foreign key(classId) referencesT_Class(classId)39 --增加外键约束时,设置【级联更新、级联删除】:来保证,当主键表中的记录发生改变时候,对应的外键表中的数据也发生相应的改变。

40 on delete cascade

41 on update cascade

42

43 ---删除外键

44 alter table T_Student drop constraintFK_T_Student_classId45

46 -------------------------------------------

47 insert intoT_Class48 select '一班' union all

49 select '二班' union all

50 select '三班' union all

51 select '四班'

52 go

53

54 insert intoT_Student55 select '老赵',1 union all

56 select '老钱',2 union all

57 select '老孙',3 union all

58 select '老李',5

59 go

60 -------------------------------------------

61 select * fromT_Student62 select * fromT_Class63 -------------------------------------------

64 --1、等值连接

65 --概念:在连接条件中使用等于号(=)运算符,其查询结果中列出被连接表中的所有列,包括其中的重复列。

66 select * from T_Student as s,T_Class asc67 where s.classId =c.classId68 --等价于下面的写法

69 select * from T_student s inner join T_class c on s.classId =c.classId70 -------------------------------------------

71 --2、不等连接

72 --概念:在连接条件中使用除等于号之外运算符(>、、>=、<=、!>和!

73 select * from T_Student as s, T_Class asc74 where s.classId <>c.classId75 --等价于下面的写法

76 select * from T_Student s inner join T_Class c on s.classId <>c.classId77 -------------------------------------------

78 --3、自然连接

79 --概念:连接条件和等值连接相同,但是会删除连接表中的重复列。

80 --查询语句同等值连接基本相同:

81 select s.*,c.chassName from T_student s inner join T_class c on s.classId =c.classId82

83 ------------------------------------------

84 --1、左连接:

85 --概念:返回左表中的所有行,如果左表中行在右表中没有匹配行,则结果中右表中的列返回空值。

86 select * from T_student s left join T_class c on s.classId =c.classId87 ------------------------------------------

88 --2、右连接:

89 --概念:恰与左连接相反,返回右表中的所有行,如果右表中行在左表中没有匹配行,则结果中左表中的列返回空值

90 select * from T_student s right join T_class c on s.classId =c.classId91 ------------------------------------------

92 --3、全连接:

93 --概念:返回左表和右表中的所有行。当某行在另一表中没有匹配行,则另一表中的列返回空值

94 select * from T_student s full join T_class c on s.classId =c.classId95 -------------------------------------------

96 --交叉连接(CROSS JOIN):也称迪卡尔积

97 --1、不带where:

98 select *from T_student cross joinT_class99 --等于

100 select *fromT_student, T_class101 -------------------------------------------

102 --2、有where子句,往往会先生成两个表行数乘积的数据表,然后才根据where条件从中选择。

103 select * from T_student s cross join T_class c where s.classId =c.classId104 --(注:cross join后加条件只能用where,不能用on)

MSSQL全部源码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值