时间:2021-07-01 10:21:17 帮助过:2人阅读
基本上联接的结果是每个集合的笛卡尔积。例如:两个集合{a,b,c}和{a,b}的笛卡尔积是如下的成对集合:{(a,a),(a,b),(b,a),(b,b),(c,a),(c,b)}。
select 表1.列1,表1.列2,表2.列3 from 表1 cross join 表2;
这种类型的联接称为交叉联接,或者笛卡尔积。在mysql中查询语句就是这样写的。
8.1.1使用两表相等联接:
两个表的行相连接的最常用的方法是通过一个相等联接。相等联接基于每行中的一个列的值。如Sql语句:select 表1.列1,表1.列2,表2.列3 from 表1,表2 where 表1.列1 = 表2.列2; 与交叉联接一样,我们可以使用一个更清楚的关键字形式表达前面的语句。 如:select 表1.列1,表1.列2,表2.列3 from 表1 join 表2 on 表1.列1 = 表2.列2; 这里不同的是我们通过join来代替逗号,使用on来代替where,但是需要注意的是,虽然where用on来进行替代了,但是where关键字还是可以在这样的语句中使用的,并不是说where就不能用了,这点需要注意。比如:
select StudentExam.ExamId,StudentExam.Makr,Student.Name as StudentName from StudentExam join Student on StudentExam.StudnetId = Student.StudnetId where StudentExam.mark >= 80;(附加条件分数大于等于80的学生信息。)
这是标准形式。为使这个示例的语法工作于所有的数据库平台并且得到相同的结果,我们须使用:inner join 替代 join。
根据上述语句我们可以解决一下类似这样的事情了,如:假设有一个表Customers带有一个CustomerId列,有一个表CreditCards也带有CustomerId列,我么就可以编写如下语句:
select Customers.CustomerId,Customers.CustomersName,CreditCards.CardsNumber from Customers join CreditCards on Customers.CustomerId = CreditCards.CustomerId;
假设这两张表是一对多的关系,一个用户可以有多张信用卡。查询结果将对CreditCards表中的每个信用卡返回一行。注意有些行有相同的客户信息,因为我们请求数据的方式就是如此。
8.1.2使用多表相等联接:
相等联接并不仅局限于两个表,我么可以在联接中包含更多表。在一个join 和 on子句后面添加join 和 on子句就可以联接更多的表。例如:select * from table1 join table2 on table1.column1 = table2.column2 join table3 on table1.column3 = table3.column4;
针对上述的语句,我们对于前面的客户和信用卡来进行表的增加,假设还有另外一个表Address的地址表,存储每个客户的一到多个地址。我么可以执行下列语句:
select Customer.CustomerId,Customer.CustomerName,CrediCards.CardNumber,Address.Country from Customer join CrediCards on Customer.CustomerId = CrediCards.CustomerId join Address on Customer.CustomerId = Address.CustomerId;
8.1.3使用非相等联接:
所有相等联接都是在on后面使用想等运算符(=),当然,我们也可以在联接中使用其他比较运算符。例如:select * from table1 join table2 on table1.column1 < table2.column2 ;
8.1.4在相等联接中使用别名:
我们从上述的例子中可以看出每一天记录的名字都是很长的,当然我们也可以通过使用 (AS) 关键字别名来使得看起来更简洁明了。比如:
select SE.ExamId,SE.Mark,S.Name AS StudentName from StudentExam AS SE join Student AS S on SE.StudentId = S.StudentId order by ExamID;
这样跟节省空间,并且使得查询更容易读懂。
8.2使用联接:
当表联接在一起时,我们将一个表中的行与其他表中的行联合,并从组合中抽取数据。联接可分为以下几类:
3.交叉联接:交叉联接返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉联接又称为笛卡尔积。
总结:数据库表的联接无疑是非常重要的知识点,在平时的学习和使用过程中未能感觉到它的美妙的地方。这个知识点也是被无数面试官所青睐的问题。比如:你知道联接的几种形式?外联接分几种?什么是笛卡尔积?等等···所以熟悉掌握它异常重要。总结到这里,基本的数据库知识就总结完了。经过这几天的总结和回顾,自然是对数据库的使用又多了一些感悟,感觉基本的数据库知识比较熟悉了。以便于在日后的工作中能将所感悟到的东西运用到实际解决问题中去,这才是正真的意义。
数据库知识整理<八>
标签: