⑴ 数据库-联表查询
SQL使用(一)——联合查询
1.联合查询分类
内连接(inner Join 或 Join)
外连接(outer Join)
左外连接(left outer Join 或 left Join)
右外连接(right outer Join 或 right Join)
全外连接(full outer Join 或 full Join)
交叉连接 (cross Join)
结果集链接 (union 和 union all)
2.联合查询介绍
相关数据表如下:
A表
B表
C表
2.1内连接(Inner Join)
内连接:仅显示两个表中匹配行,即两表中都有才显示。
SQL如下:
SELECT A.id AS AID, A.content AS AContent, B.id AS BID, B.content AS BContent FROM A INNERJOIN B ON (A.id = B.id);
1
2
3
4
5
6
7
8
查询结果:
由查询结果可以看出,内连接根据连接条件(A.id=B.id)查询出了A、B两表中都存在的数据信息。2个表的联合查询结果如此,那么3个表甚至更多表联合查询的结果呢?
A、B、C三表联合内查询SQL
SELECTA.idASAID, A.contentASAContent, B.idASBID, B.contentASBContent, C.idASCID, C.(A.id = B.id)INNERJOINCON(A.id = C.id)
1
2
3
4
5
6
7
8
9
10
11
查询结果:
啊?怎么多了一行数据?不用惊讶,其实C表中有2个id为1的记录,然而我们怎么理解得到的查询结果呢?
可以把A、B两表的查询结果作为T表(中间结果表),然后T表内连接C表,连接条件为T.A.id=C.id。
简单来说n(n>=2)都可以看做两张表的联合查询,后面的小节将只介绍两个表的联合查询。
2.2外连接(Outer Join)
2.2.1左外连接(Left outer Join)
左外连接:左表有就显示,不论右表。
SQL:
SELECTA.idASAID, A.contentASAContent, B.idASBID, B.(A.id = B.id);
1
2
3
4
5
6
7
8
查询结果:
左连接并不是把B表左连接到A表上,而是把A表作为基准表。由查询结果可以看出,A、B两表左连接,只要A中有结果,无论B表中有无结果,都会被查询出来。
2.2.2右外连接(Right outer Join)
右外连接:右表有就显示,不论左表。
SQL:
SELECTA.idASAID, A.contentASAContent, B.idASBID, B.(A.id = B.id);
1
2
3
4
5
6
7
8
9
查询结果:
右连接和左连接类似,只是把B表(连接的表)作为基准表。由查询结果可以看出,无论A表是否存在其他数据,只要B表数据存在就会被查询出来。
2.2.3全外连接(Full outer Join)
全外连接:左表/右表,有一个有就显示。
SQL:
SELECTA.idASAID, A.contentASAContent, B.idASBID, B.(A.id = B.id);
1
2
3
4
5
6
7
8
9
查询结果:
全外连接查询就字面意思也不难看出是查询出两表(A、B)中的所有记录信息。
注:MySQL中不支持全外连接(但是可以union来实现,后面会介绍)。
2.2交叉连接(Cross Join)
SQL:
SELECTA.idASAID, A.contentASAContent, B.idASBID, B.;
1
2
3
4
5
6
7
8
9
查询结果:
由结果可以看出,交叉连接是对A、B量表进行笛卡尔积的结果查询出来。即A的每条记录都有和B中所有记录相对应的信息。
2.3 SQL Union
SQL Union用于将多个select结果集进行合并。值得注意的是,UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。
SQL:
SELECT*FROMAUNIONSELECT*fromB;
1
查询结果:
Union是把2个Select结果集进行合并,由查询结果也不难看出,A、B两表的结果数据进行了合并,并且都被查询出来了。
如果2个Select结果集中存在相同的结果,用Union则会把相同的记录进行合并,查询结果中仅仅会显示一条。那么如果想都显示出来,把Union换成Union All 即可。
Union实现Full outer Join:
1.首先获取A、B表中id的不同组合。
SQL:
CREATEVIEWvasSELECTA.idfromAUNIONSELECTB.idfromB;
1
视图内存如下:
2.以视图V为基本表,Left Join A、B表即可。
SQL:
SELECTA.id, A.content, B.id, B.contentFROMvLEFTJOINAON(A.id = v.id)LEFTJOINBON(B.id = v.id);
1
2
3
4
5
6
7
8
9
查询结果如下:
⑵ 如何对access中两个数据库中表进行联合查询
点击菜单栏上面的:创建——查询设计;
在弹出的对话框中选择两个表:订单和订单明细,然后点击添加;
添加下列字段到设计表中;
点击菜单栏上面的保存按钮;
在弹出的对话框中,输入这个查询的名字,然后点击确定即可。
⑶ 数据库中的统计查询和组合查询
1、
select a.编号,a.名称,sum(b.数量)
from 药品 a,处方 b
where a.编号=b.药品编号
group by a.编号,a.名称
2、
select 厂商 from 药品 group by 厂商 having count(1)>=3
3、首隐
select * from 医生 where 编号 not in (select distinct 医生编号 from 处方 where 药品编号 in (select 编号 from 药巧芹稿品 where 名孝孝称 like '%青霉素%'))
⑷ 数据库中的统计查询和组合查询
联接最简单
select 科室,sum(数量)
from 医生,处方,段孝敏药品
where 药品.名称='青霉素'
and 医生.编号 = 处方.医生编号
and 处方.药品编号 = 药品.编号
group by 科室
你要求不连接单表
declare @药编号 int
select @药编号=编号 from 药品 where 名称='青霉素'
select 科室,
sum((select 数量 from 处方 where 医生编号=医生.编号慎察 and 药品编号=@药编握枝号))
from 医生
group by 科室
⑸ 数据分析人必掌握的数据库语言-SQL指南第七期
本篇重点为大家讲解 组合数据、数据插入、更新和删除数据 相关内容。
多数SQL查询只包含从一个或多个表中返回数据的单条 SELECT 语句。但是,SQL也允许执行多个查询,并将结果作为一个查询结果集返回。这些组合查询通常称为并 (union) 或复合查询 (compound query)。
主要有 两种情况 需要使用组合查询:
在一个查询中从不同的表返回结构数据;
对一个表执行多个查询,宴顷轮按一个查询返回数据。
创建组合查询
利用 UNION ,可给出多条 SELECT 语句,将它们的结果组合成一个结果集。
使用方法: 给出每条SELECT语句,在各条语句之间放上关键字UNION。
假如需要Illinois、Indiana和Michigan等美国几个州的所有顾客的报表,还想包括不管位于哪个州的所有的Fun4All。
分析:这条语句由两条 SELECT语句 组成,之间用 UNION 关键字分隔。UNION指示DBMS执行这两条SELECT语句,并把输出组合成一个查询结果集。
在简单的例子中,使用UNION可能比使用WHERE子句更为复杂。但对于较复杂的过滤条件,或者从多个表中检索数据的情形,使用UNION可能会使处理更简单。
1、UNION规则
UNION必须由 两条或两条以上 的SELECT语句组成,语句之间用关键字 UNION分隔。
UNION中的每个查询必须包含相同的 列、表达式或聚集函数。
列数据晌信类型 必须兼容 :类型不必完全相同,但必须是DBMS可以隐含转换的类型。
2、包含或取消重复的行
使用 UNION 时, 重复的行会被自动取消 ,这是UNION的默认行为,如果想返回所有的匹配行,可使用 UNION ALL 。
3、对组合查询结果排序
在用 UNION组合查询 时,只能使用一条 ORDER BY 子句,它必须位于最后一条SELECT语句之后。
TopBDA大数据分析师培训
除了SQL数据库学习,还有大量数据分析知识和实操等你 探索 !
SELECT是最常用的SQL语句,还有其他3个常用的SQL语句需要学习,第一个就是 INSERT ,另外两个之后为大家介绍。
INSERT用来 将行插入或添加到数据库表 ,插入有几种方式:
插入完整的行;
插入行的一部分;
插入某些查询的结果。
插入完整的行
把数据插入表中的最简单方法是使用基本的 INSERT 语法。
分析:在插入行时,DBMS将用VALUES列表中的相应值填入列表中的对应项。VALUES中的第一个值对应于第一个指定列名,第二个值对应于第二个列名,如此等等。
插入部分行
使用这种语法,还可以 省略列 ,这表示可以只给某些列提供值,给其他列不提供值。
分析:没有给 cust_contact 和 cust_email 这两列提供值,这表示没必要在INSERT语句中包含它们。因此,这里的INSERT语句 省略了这两列及其对应的值。
插入检索出的数据
INSERT一般用来给表插入具有指定列值的行。
INSERT还存在另一种形式, 可以利用它将SELECT语句的结果插入表中, 这就是所谓的 INSERT SELECT 。
假如想把另一表中的顾客列合并到Customers表中,不需要每次读取一行再将它用INSERT插入,可以如下进乎塌行:
分析:使用INSERT SELECT从CustNew中将所有数据导入Customers。SELECT语句从CustNew检索出要插入的值,SELECT中列出的每一列对应于Customers表名后所跟的每一列。
从一个表复制到另一个表
可以使用 CREATE SELECT 语句(或者在SQL Server里也可用 SELECT INTO 语句)。
与 INSERT SELECT 将数据添加到一个已经存在的表不同,CREATE SELECT将数据复制到一个新表。
使用SQL Server,可以这么写:
分析:创建一个名为CustCopy的新表,并把Customers表的整个内容复制到新表中。
在使用 SELECT INTO 时,任何SELECT选项和子句都可以使用,包括 WHERE 和 GROUP BY ;可利用连接从多个表插入数据;不管从多少个表中检索数据,数据都只能插入到一个表中。
更新数据
更新表中的数据,可以使用 UPDATE 语句,使用UPDATE的方式有两种:
更新表中的特定行;
更新表中的所有行。
基本UPDATE语句由三部分组成,分别是:
要更新的表;
列名和它们的新值;
确定要更新哪些行的过滤条件。
举一个简单例子,客户1现在有了电子邮件地址,因此他的记录需要更新,语句如下:
分析:UPDATE语句以要更新的表名开始。要更新的表名为Customers。SET命令用来将新值赋给被更新的列。UPDATE语句以WHERE子句结束,它告诉DBMS更新哪一行。
更新多个列的语法稍有不同。
分析:在更新多个列时,只需要使用一条SET命令,每个“列=值”对之间用逗号分隔(最后一列之后不用逗号)。
要删除某个列的值,可设置它为NULL。
分析:NULL用来去除cust_email列中的值。
删除数据
从一个表中删除数据,使用DELETE语句,使用DELETE的方式有两种:
从表中删除特定的行;
从表中删除所有行。
分析:DELETEFROM要求指定删除数据的表名,WHERE子句过滤要删除的行。如果省略WHERE子句,它将删除表中每个顾客。
DELETE不需要列名或通配符 ,DELETE删除整行而不是删除列,要删除指定的列,使用 UPDATE 语句。
使用 UPDATE或DELETE 时所遵循的重要原则:
除非更新和删除每一行,否则绝对不要使用不带WHERE子句的UPDATE或DELETE语句。
保证每个表都有主键,尽可能像WHERE子句那样使用它。
在UPDATE或DELETE语句使用WHERE子句前,应该先用SELECT进行测试,保证它过滤的是正确的记录,以防编写的WHERE子句不正确。
使用强制实施引用完整性的数据库,这样DBMS将不允许删除其数据与其他表相关联的行。
有的DBMS允许数据库管理员施加约束,防止执行不带WHERE子句的UPDATE或DELETE语句。若是SQL没有撤销(undo)按钮,应该非常小心地使用UPDATE和DELETE。
以上就是今天分享的全部内容,下期重点为大家介绍 使用视图和创建和操纵表 ,我们下期见!
⑹ access 数据库组合框查询功能
1,打开access,点击创建,点击窗体设计,然后在工具栏的属性表,在属性表的数据的控件来源中选择要查询的比偶。
2,点击工具栏中窗体设计工具控基桐旁搏橡件的组合框,在主体中任意拉一个组合框,然后在跳出的框框中选择第三个。
3,选择要查询的字段,点击下一步,直到最后一个,在最后一个框里输入该查询轮握窗体的名称,点击确定。
4,点击保存,右击该窗体的名称,选择窗体视图,就可以看到效果了。
⑺ 数据库实验:统计查询和组合查询
1 统计各出版社出版图书的数量。
SELECT
出版社.出版社名称,
COUNT(图书.书号) AS 出版图书的数量
FROM
图书, 出版社
WHERE
图书.出版社编号 = 出版社.编号
GROUP BY
出版社.出版社名称
2 列出多人合著的图书书号和价格。
SELECT
书号,
价格
FROM
图书
GROUP BY
书号,
价格
HAVING
COUNT(作者编号) >= 2
3 列出高教出版社出版的最贵图书信息。
SELECT
图书.*
FROM
图书, 出版蚂敏社
WHERE
图书.出版社编号 = 出版社.编号
AND 出版社.出版社名称 = '高教出版社'
AND 图书态明.价格 IN (SELECT MAX(价格) FROM 图书 T WHERE T.出闷闭枝版社编号 = 出版社.编号)
4 列出所有图书都是30元以上的出版社名称。
SELECT
出版社.出版社名称
FROM
图书, 出版社
WHERE
图书.出版社编号 = 出版社.编号
GROUP BY
出版社.出版社名称
HAVING
SUM ( CASE WHEN 图书.价格 > 30 THEN 0 ELSE 1 END ) = 0
⑻ 数据库SQL组合查询,两表之间取数据
select
*
from
B
where
id
in
(select
Max(ID)
from
B
where
B.Name
in
(select
name
from
A
where
pid='迅哗99999'亩厅行伏盯)
group
by
name
)
⑼ 数据库的组合查询可以用其他语句代替吗,有什么不同
可以用其他语句代替。同一个查询可以用不同的方式来实现,但每种查询方法的执行渗猛桥效率不同。总体来说,多表连接丛猛查询的效率比子查询的效率要高,嵌套子查询的效率比相关子查询的效知凳率要好一些。