首页数据库数据库多表查询sql语句(SQL数据库下载)

数据库多表查询sql语句(SQL数据库下载)

编程之家2026-05-22956次浏览

大家好,今天来为大家解答数据库多表查询sql语句这个问题的一些问题点,包括SQL数据库下载也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如果解决了您的问题,还望您关注下本站哦,谢谢~

数据库多表查询sql语句(SQL数据库下载)

SQL多表查询的几种连接方式

。WHERE条件:在有ON条件的SELECT语句中是过滤中间表的约束条件。在没有ON的单表查询中,是限制物理表或者中间查询结果返回记录的约束。在两表或多表连接中是限制连接形成最终中间表的返回结果的约束。从这里可以看出,将WHERE条件移入ON后面是不恰当的。推荐的做法是:ON只进行连接操作,WHERE只过滤中间表的记录。

二、连接查询

连接运算符是用来实现多表联合查询的一种重要方式,主要分为三种:内连接、外连接、交叉连接。

2.1内连接 INNER JOIN

内连接(INNER JOIN)有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行。(所谓的链接表就是数据库在做查询形成的中间表)。

语句1:隐式的内连接,没有INNER JOIN,形成的中间表为两个表的笛卡尔积。SELECT O.ID,O.ORDER_NUMBER,C.ID,C.NAMEFROM CUSTOMERS C,ORDERS OWHERE C.ID=O.CUSTOMER_ID;

数据库多表查询sql语句(SQL数据库下载)

语句2:显示的内连接,一般称为内连接,有INNER JOIN,形成的中间表为两个表经过ON条件过滤后的笛卡尔积。SELECT O.ID,O.ORDER_NUMBER,C.ID,C.NAMEFROM CUSTOMERS C INNER JOIN ORDERS O ON C.ID=O.CUSTOMER_ID;语句3和语句4的查询结果。

内连接使用比较运算符(包括=、>、<、<>、>=、<=、!>和!<)进行表间的比较操作,查询与连接条件相匹配的数据。根据所使用的比较方式不同,内连接分为等值连接、自然连接和自连接三种。

等值连接

使用”=”关系将表连接起来的查询,其查询结果中列出被连接表中的所有列,包括其中的重复列。

SELECT

PM_ACT_JOB_RLS.*, PM_ACT_RLS.*

数据库多表查询sql语句(SQL数据库下载)

FROM

PM_ACT_JOB_RLS

INNER JOIN PM_ACT_RLS ON PM_ACT_JOB_RLS.RlsPK= PM_ACT_RLS.RlsPK

自然连接

等值连接中去掉重复的列,形成的连接。

说真的,这种连接查询没有存在的价值,既然是SQL2标准中定义的,就给出个例子看看吧。自然连接无需指定连接列,SQL会检查两个表中是否相同名称的列,且假设他们在连接条件中使用,并且在连接条件中仅包含一个连接列。不允许使用ON语句,不允许指定显示列,显示列只能用*表示(ORACLE环境下测试的)。对于每种连接类型(除了交叉连接外),均可指定NATURAL。

SELECT

PM_ACT_JOB_RLS.JobPK, PM_ACT_RLS.RlsPK, RlsName

FROM

PM_ACT_JOB_RLS

Natural INNER JOIN PM_ACT_RLS ON PM_ACT_JOB_RLS.RlsPK= PM_ACT_RLS.RlsPK

语句1:SELECT*FROM ORDERS O NATURAL INNER JOIN CUSTOMERS C;

语句2:SELECT*FROM ORDERS O NATURAL LEFT OUTER JOIN CUSTOMERS C;

语句3:SELECT*FROM ORDERS O NATURAL RIGHT OUTER JOIN CUSTOMERS C;

语句4:SELECT*FROM ORDERS O NATURAL FULL OUTER JOIN CUSTOMERS C;

自连接

如果在一个连接查询中,设计到的两个表都是同一个表,这种查询称为自连接查询。

--c1、c2逻辑上是两张表,物理上是一张表 SELECT

c1.CategoryID,

c1.CategoryName

FROM

[dbo].[Category] c1

INNER JOIN [dbo].[Category] c2 ON c1.[CategoryID]= c2.[ParentID]

全外连接(FULL OUTER JOIN)

注意:MySQL是不支持全外的连接的,这里给出的写法适合Oracle和DB2。但是可以通过左外和右外求合集来获取全外连接的查询结果。SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O FULL OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;左外和右外的合集

实际上查询结果和上面的全外连接语句是相同的SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O LEFT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_IDUNIONSELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O RIGHT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;

联合连接(UNION JOIN)

这是一种很少见的连接方式。Oracle、MySQL均不支持,其作用是:找出全外连接和内连接之间差异的所有行。这在数据分析中排错中比较常用。也可以利用数据库的集合操作来实现此功能。语句1:联合查询(UNION JOIN)例句,还没有找到能执行的SQL环境。SELECT1 O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O UNION JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID语句2:语句11在DB2下的等价实现。还不知道DB2是否支持语句11呢!SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O FULL OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_IDEXCEPTSELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O INNER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;语句3:语句1在Oracle下的等价实现。SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O FULL OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_IDMINUSSELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O INNER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;

2.2外连接

内连接只返回满足连接条件的数据行,外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的数据行。

外连接分为左外连接、右外链接、全外连接三种。

1)LEFT JOIN或LEFT OUTER JOIN左向外联接的结果集包括 LEFT OUTER子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。2)RIGHT JOIN或 RIGHT OUTER JOIN右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。3)FULL JOIN或 FULL OUTER JOIN完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。

语句1:左外连接(LEFT OUTER JOIN)SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O LEFT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;

语句2:右外连接(RIGHT OUTER JOIN)SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O RIGHT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;注意:WHERE条件放在ON后面查询的结果是不一样的。例如:

语句3:WHERE条件独立。SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O LEFT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_IDWHERE O.ORDER_NUMBER<>‘MIKE_ORDER001‘;

语句4:将语句7中的WHERE条件放到ON后面。SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAMEFROM ORDERS O LEFT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID AND O.ORDER_NUMBER<>‘MIKE_ORDER001‘;

从语句3和语句4查询的结果来看,显然是不相同的,语句8显示的结果是难以理解的。因此,推荐在写连接查询的时候,ON后面只跟连接条件,而对中间表限制的条件都写到WHERE子句中。

2.3交叉连接

交叉连接(CROSS JOIN):有两种,显式的和隐式的。不带ON子句,返回的是两表的乘积,也叫笛卡尔积。

语句1:隐式的交叉连接,没有CROSS JOIN。SELECT O.ID, O.ORDER_NUMBER, C.ID, C.NAMEFROM ORDERS O, CUSTOMERS CWHERE O.ID=1;

语句2:显式的交叉连接,使用CROSS JOIN。SELECT O.ID,O.ORDER_NUMBER,C.ID,C.NAMEFROM ORDERS O CROSS JOIN CUSTOMERS CWHERE O.ID=1;语句1和语句2的结果是相同的

1.4例子

a表

b表

id

name

id

job

parent_id

1

张3

1

23

1

2

李四

2

34

2

3

王武

3

34

4

1)内连接select a.*,b.* from a inner join b on a.id=b.parent_id结果是1张3 1 23 12李四 2 34 22)左连接select a.*,b.* from a left join b on a.id=b.parent_id结果是1张3 1 23 12李四 2 34 23王武 null3)右连接select a.*,b.* from a right join b on a.id=b.parent_id结果是1张3 1 23 12李四 2 34 2null 3 34 44)完全连接select a.*,b.* from a full join b on a.id=b.parent_id结果是1张3 1 23 12李四 2 34 2null3 34 43王武 null

二、存储过程与函数等更高级的方式

三、总结

连接查询是SQL查询的核心,连接查询的连接类型选择依据实际需求。如果选择不当,非但不能提高查询效率,反而会带来一些逻辑错误或者性能低下。下面总结一下两表连接查询选择方式的依据:1、查两表关联列相等的数据用内连接。2、 Col_L是Col_R的子集时用右外连接。3、 Col_R是Col_L的子集时用左外连接。4、 Col_R和Col_L彼此有交集但彼此互不为子集时候用全外。5、求差操作的时候用联合查询。多个表查询的时候,这些不同的连接类型可以写到一块。例如:SELECT T1.C1,T2.CX,T3.CYFROM TAB1 T1INNER JOIN TAB2 T2 ON(T1.C1=T2.C2)INNER JOIN TAB3 T3 ON(T1.C1=T2.C3)LEFT OUTER JOIN TAB4 ON(T2.C2=T3.C3);WHERE T1.X>T3.Y;上面这个SQL查询是多表连接的一个示范。

参考文章

【SQL】—多表查询的几种连接方式

SQL语句之数据查询(二)多表查询-----------------数据查询的重点难点

sql内连接、外连接、自然连接等各种连接

SQL多表查询的几种连接方式

标签:bsplan区别str右外连接www.parententer另一个

求三表联合查询的SQL查询语句

1、SQL语句:select u.*,r.*,r.id rid

from user u left join sys_user_role sur on u.id= sur.useridleft join sys_role r on sur.roleid= r.id

图片:(表名截图)

请点击输入图片描述

请点击输入图片描

注1:user(用户表),sys_role(角色表),sys_user_role(关系表)。

表1:user(下图)

请点击输入图片描述

请点击输入图片描述

表2:sys_role(下图)

请点击输入图片描述

请点击输入图片描述

表3:sys_user_role(下图)

请点击输入图片描述

请点击输入图片描述

算了,建表语句也给你们了,你们自己测试,这样更详细,(程序员)多动手,比什么都好。(这里的界面对写代码不太友好,我放博客里了,自己复制粘贴测试使用就行)

sql语句地址:网页链接

2、SQL语句解释:

select a.*,b.*

from a表 a left join b表 b on a.id= b.aid

left join c表 c on b.cid= c.id

注2:此语句适合a表与c表连接,b表是关系表的情况。

SQL判断语句用法和多表查询

1.格式化时间sql语句

本例中本人随便做了两张表,和实际不是很相符,只是想说明sql语句的写法。

例1表格式如下:

需求:查询出本表,但需要使time字段的时间格式为yyyy-MM-dd,比如:2013-08-13

sql写法:

SELECT

u.id,u.userId,u.timeType,DATE_FORMAT(time,'%Y-%m-%d')

AS

time,secondId

FROM

`user`

u

运行结果:

2.多表查询(三表查询)

例二三表结构如下:

需求:查询出主表,要求在主表中显示username和secondname

sql写法:

SELECT

u.id,n.`name`,u.timeType,u.time,s.`name`

FROM

`user`

u,`name`

n,`second`

s

WHERE

u.userId=n.id

AND

u.secondId=s.id

运行结果:

3.when

then判断语句

例三表结构如下:

需求:查询上表,若timeType字段值为2时,显示每月的第二天,若timeType字段值为4时,显示每月的第四天

sql写法:

SELECT

u.id,u.userId,(CASE

WHEN

u.timeType=2

THEN

'每月第二天'

WHEN

u.timeType=4

THEN

'每月第四天'

END)

AS

timeType

,u.time,u.secondId

FROM

`user`

u

运行结果:

以上所述是小编给大家介绍的SQL判断语句用法和多表查询,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

关于数据库多表查询sql语句到此分享完毕,希望能帮助到您。

dede改了default?java中default免费的源码网站,52源码网会员免费下载