数据库知识整理<八>

联接:



8.1理解简单的单联接: 



  基本上联接的结果是每个集合的笛卡尔积。例如:两个集合{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使用联接:



  当表联接在一起时,我们将一个表中的行与其他表中的行联合,并从组合中抽取数据。联接可分为以下几类:

  1. 内联接:是一种典型的联接运算,使用像=或者<>之类的比较运算符。包括相等联接、非相等联接和自然联接。内联接使用比价运算符根据每个表共有的列的值匹配两个表中的行。例如:检索Room和Class表中的RoomId相同的所有行。
  2. 外联接:外联接又可以分为左外联接、右外联接或全外联接。在from子句中指定外联接时,可以有以下几个关键字的一组指定:
  • 左外联接:left join或left outer join。左向外联接的结果集包括left outer 子句中指定的左表的所有行,而不仅仅是联接到所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表均为空值。
  • 右外联接:right join或right outer join。右向外联接跟左向外联接方向相反而已,其用法是一样的。
  • 全外联接:full join或full outer join。全外联接返回左表和右表的所有行,当某行在另一个表中没有匹配行时,则另一个表的选择列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。

  3.交叉联接:交叉联接返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉联接又称为笛卡尔积。

  1. 内联接:是指使用比较运算符根据每个表共有的列的值匹配两个表中的行。比如:首先我们在两个表中执行内联接。  select 表1.列1,表2.列2 from 表1 inner join 表2 on 表1.列1 = 表2.列2;
  2. 外联接:外联接考虑到源表中有些行不匹配的情况。有三种形式的外联接方式:左外、右外、全外。分别是结果集包含所有从左边的表、右边的表、左右两边的表。执行外联接时的语法与内联接相似,但是使用的left outer join、right outer join、full outer join。所有的这些联接时都需要用到一个on字。
  • 左外联接语句:select * from table1 left outer join table2 on table1.column1 = table2.column2;
  • 右外联接语句:select * from table1 right outer join table2 on table1.column1 = table2.column2;
  • 全外联接语句:select * from table1 full outer join table2 on table1.column1 = table2.column2;

总结:数据库表的联接无疑是非常重要的知识点,在平时的学习和使用过程中未能感觉到它的美妙的地方。这个知识点也是被无数面试官所青睐的问题。比如:你知道联接的几种形式?外联接分几种?什么是笛卡尔积?等等···所以熟悉掌握它异常重要。总结到这里,基本的数据库知识就总结完了。经过这几天的总结和回顾,自然是对数据库的使用又多了一些感悟,感觉基本的数据库知识比较熟悉了。以便于在日后的工作中能将所感悟到的东西运用到实际解决问题中去,这才是正真的意义。

  

时间: 2024-10-04 02:08:06

数据库知识整理<八>的相关文章

数据库知识整理

关系型数据库知识整理: 一,关系型数据库管理系统简介: 1.1使用数据库的原因: 降低存储数据的冗余度 提高数据的一致性 可以建立数据库所遵循的标准 储存数据可以共享 便于维护数据的完整性 能够实现数据的安全性 1.2基本概念: 对于任何数据库来说,表之间的关联关系存在三种基本的关系类型:一对一,一对多,多对多仅此三种. 目前流行的关系型数据库服务器管理系统有:微软-MS SQL Server.甲骨文-Oracle.IBM-DB2.开源的MySql和PostgreSQL等.(在面试中有被问到过)

数据库知识整理&lt;二&gt;

又继续写的博客,希望自己能坚持每天写博客.分享自己的点滴,对自己成长有帮助.今天下午高强度打了三个小时篮球,小腿都抽筋了.很爽,失落的心情似乎变得开明了一些.想到了一句话:“像SB式的坚持总会有好的收获”,因为坚定了目标,不达目标不罢休.其他的就没什么了.好吧,不多说这些了.继续数据库知识总结吧. 二,管理数据库和表: 2.1管理数据库: 创建和使用数据库: 创建数据库的SQL语句:create database 数据库名: 需要注意的是:数据库名在服务器中必须是唯一的并且遵循合法的标识符规则:

数据库知识整理&lt;五&gt;

简单的数据查询: 5.1查询的基本结构: Sql语句:select [distinct] (* | column [alias],...) from table [where condition] [order bycolumn]; 5.2投影操作: 投影操作是指在Sql查询中,使用select子句,选择将对表中的那些列进行操作,这些列将出现在结果中. 基本的Sql语句的查询:select 列名列表 from 表名; 表名前缀:select 表名.列明 from 表名;如 select stud

数据库知识整理&lt;三&gt;

保证数据的完整性: 3.1数据完整性概述: 数据完整性的意义:我们知道数据库能防止储存垃圾数据,RDBMS实现该功能主要是通过维护数据完整性来实现的.根据数据完整性实施方法我们将其分为四类:实体完整性.域完整性.引用完整性.自定义的完整性. 实体完整性:一个表中的一行和它代表的一行完全一致,那么我们就说该表具有完整性. 域完整性:指给定列的输入有效性,如:限制类型(通过数据类型).格式(检查约束).可能值(外简约束.检查约束.默认值定义.非空约束). 引用完整性:实体与实体之间的联系在表中用外键

数据库知识整理&lt;六&gt;

聚合函数与分组 6.1使用聚合函数进行数据统计: 聚合函数常见的有以下几种: count:返回该结果集中行的数目. sum:返回结果集中所有值的总和. avg:返回结果集中所有值的平均值. max:返回结果集中所有值得最大值. min:返回结果集中所有值的最小值. 执行行和列的计数:select count(<计数规范>) as <别名> from <表名>;其中技术规范的关键字有*.all.distinct.‘*’包括所有行包括空值null,‘all’计数所指定的列的

数据库知识整理&lt;四&gt;

使用DML语句更改数据: 所谓DML语句是指数据库操作语句,其中包括的是对数据库数据的修改.删除.插入. 4.1添加新数据: 插入单行的记录:基本的SQL语句为-insert into <表明>(<列明列表>) values (<值列表>);插入多行记录时中间用逗号隔开. 还有一种插入方式就是插入其他表的数据时,我们可以使用:insert into <表明>(<列明列表>) select <select语句>;如:insert int

SQL Server 2008常用的数据库知识整理

数据库知识点: 一.计算字段 1.NULLIF函数 将 null 的姓名转化为“佚名”: 表达式:NULLIF ( expression1 , expression2 )    含义:如果两个表达式不等价, 则 NULLIF 返回第一个 expression1的值.         如果两个表达式等价, 则 NULLIF 返回第一个 expression1类型的空值. 2.Beween And 计算字段 如:Fsalary Between Fage*1.5+2000 And Fage*1.8+5

数据库知识整理&lt;七&gt;

组合查询: 7.1使用子查询: 嵌套在其他查询中的查询,我们称之为子查询.子查询本身也可能包含一个子查询.子查询也称为内部查询,而包含子查询的语句也称为外部查询. 所有的子查询可以被分为两个类别:子查询和非相关子查询. 非相关子查询是独立于外部查询的子查询.子查询总共执行一次,执行完毕后将值传递给外部查询. 相关子查询的执行依赖于外部查询的数据,外部查询返回一行,子查询就执行一次. 子查询作为计算列:子查询的一个最简单的形式就是内部查询为外部查询的每行返回一个单值结果,他通常作为一个结果插入到一

计算数据库中各个表的数据量和每行记录所占用空间--添加架构信息-读后感及知识整理

参考文章: SQL Server 游标运用:查看一个数据库所有表大小信息(Sizes of All Tables in a Database) 分享一个SQLSERVER脚本(计算数据库中各个表的数据量和每行记录所占用空间) 监控SQLServer 数据库表每天的空间变化情况 仔细拜读上面三位的文章,不会的知识点又参考了MSDN,巩固了知识点如下: 知识点: 1.表的架构信息,涉及的系统对象 sys.schemas 和 INFORMATION_SCHEMA.TABLES,但后者不是官方推荐方式,