数据库 SQL 的多表查询:eg: table1: employees, table2: departments,table3: salary_grades;一:内连接:1):等值连接:把表employees中的department_id 与表departmes中的department_id相匹配的找出来select e.last_name, d.department_idfrom employees e,departments dwhere e.department_id = d.department_id --等值内连接的缺点是:筛选条件中没有匹配的则无法选出;2):非等值连接:把表employees中的salary按照表salary_grades中的等级进行分配等级:select last_name ,salary,grade_levelfrom employees,job_gradeswhere salary between lowest_sal and highest_sal二:外连接: --相对于内连接中的等值连接,等值连接的缺点显而易见,要想把不匹配的内容显现出来,则要使用外连接;1):左连接:右边去匹配左边的内容,把匹配不到的左边的原样输出,要在等式右边加上‘(+)‘;select e.last_name, d.department_idfrom employees e,departments dwhere e.department_id = d.department_id(+)2):右连接: 左边去匹配右边的内容,把匹配不到的右边的原样输出,要在等式左边加上‘(+)‘;select e.last_name, d.department_idfrom employees e,departments dwhere e.department_id(+) = d.department_id--外连接也是有缺陷的,它的缺陷是:左右连接不能同时使用,要想同时输出两边都不匹配的,需要用到SQL99:三: SQL99:--SQL99又是另一套体系;1):--针对上述外连接的缺陷,SQL99可以使用natural join 来解决:select last_name, department_idfrom employees e natural join departments d--他的缺陷是自动匹配两个表中列名称完全一样并且数据类型完全相同的{所有列中}的(不只是目标列)情况;2): --针对上述1)的缺陷,可以考虑使用以下的:select last_name, d.department_idfrom employees e join departments don e.department_id = d.department_id--和where的意思一样3):select last_name, department_idfrom employees join departmentsusing(department_id)--这种方式需要两个表中的列名陈和数据类型完全一样4): 左连接:select last_name, d.department_idfrom employees e left outer join departments don e.department_id = d.department_id5): 右连接:select last_name, d.department_idfrom employees e right outer join departments don e.department_id = d.department_id6): 全连接:select last_name, d.department_idfrom employees e full outer join departments don e.department_id = d.department_id四: 自连接:--去实现查询表employees中last_name = ‘chen‘ 的员工的老板的工资和email:select emp.last_name,emp.manager_id,managers.salary,managers.emailfrom employees emp,employees managerswhere emp.manager_id = managers.employee_id and lower(emp.last_name) = ‘chen‘
数据库SQL的多表查询
标签:sharp out 名称 缺点 连接 针对 art 完全 它的
小编还为您整理了以下内容,可能对您也有帮助:
SQL多表查询语句怎么写
SQL写多表查询语句的步骤如下:
我们需要准备的材料分别是:电脑、sql查询器。
1、首先,打开sql查询器,连接上相应的数据库表,例如m1表、m2表。
2、点击“查询”按钮,再输入:select max(km) from m1 join m2 on m1.md=m2.md where id=14 and lx=15。
3、点击“运行”按钮,此时查询到km的最大值为20。
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;
语句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.*
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软件,查询所有选课的学生的学号,姓名,课程名及成绩。查询语句。
2、查询结果,表示已成功执行。
3、查询所有比赵雪年龄大的学生的姓名和年龄,查询语句。
4、查询结果,表示已成功执行。
查询 (也叫连接查询,此处为基于两个表的连接查询) ,分为:
自连接查询,对同一个表进行连接操作
内连接查询,又分为:自然连接、等值连接、不等值连接三种
外连接查询,又分为:左外连接、右外连接、全外连接三种
交叉连接查询,也作无条件查询。
SQL同时查询多个表
1、打开SQL软件,查询所有选课的学生的学号,姓名,课程名及成绩。查询语句。
2、查询结果,表示已成功执行。
3、查询所有比赵雪年龄大的学生的姓名和年龄,查询语句。
4、查询结果,表示已成功执行。
查询 (也叫连接查询,此处为基于两个表的连接查询) ,分为:
自连接查询,对同一个表进行连接操作
内连接查询,又分为:自然连接、等值连接、不等值连接三种
外连接查询,又分为:左外连接、右外连接、全外连接三种
交叉连接查询,也作无条件查询。
如何用一个sql分别从两个表中查询数据
sql语句从一张表中查询数据插入到另一张表中的方法如下:
1、select * into destTbl from srcTbl。
2、insert into destTbl(fld1, fld2) select fld1, 5 from srcTbl。以上两句都是将 srcTbl 的数据插入到 destTbl,但两句又有区别的:第一句(select into from)要求目标表(destTbl)不存在,因为在插入时会自动创建。第二句(insert into select from)要求目标表(destTbl)存在,由于目标表已经存在,所以我们除了插入源表(srcTbl)的字段外,还可以插入常量。
如何用一个sql分别从两个表中查询数据
sql语句从一张表中查询数据插入到另一张表中的方法如下:
1、select * into destTbl from srcTbl。
2、insert into destTbl(fld1, fld2) select fld1, 5 from srcTbl。以上两句都是将 srcTbl 的数据插入到 destTbl,但两句又有区别的:第一句(select into from)要求目标表(destTbl)不存在,因为在插入时会自动创建。第二句(insert into select from)要求目标表(destTbl)存在,由于目标表已经存在,所以我们除了插入源表(srcTbl)的字段外,还可以插入常量。
SQL多表查询详解
本教程为大家介绍SQL中的多表查询,下面我们来看看具体实例吧。
新建两张表:
表1:student 截图如下:
表2:course 截图如下:
(此时这样建表只是为了演示连接SQL语句,当然实际开发中我们不会这样建表,实际开发中这两个表会有自己不同的主键。)
一、外连接
外连接可分为:左连接、右连接、完全外连接。
1、左连接 left join 或 left outer join
SQL语句:select * from student left join course on student.ID=course.ID
执行结果:
左外连接包含left join左表所有行,如果左表中某行在右表没有匹配,则结果中对应行右表的部分全部为空(NULL).
注:此时我们不能说结果的行数等于左表数据的行数。当然此处查询结果的行数等于左表数据的行数,因为左右两表此时为一对一关系。
2、右连接 right join 或 right outer join
SQL语句:select * from student right join course on student.ID=course.ID
执行结果:
右外连接包含right join右表所有行,如果左表中某行在右表没有匹配,则结果中对应左表的部分全部为空(NULL)。
注:同样此时我们不能说结果的行数等于右表的行数。当然此处查询结果的行数等于左表数据的行数,因为左右两表此时为一对一关系。
3、完全外连接 full join 或 full outer join
SQL语句:select * from student full join course on student.ID=course.ID
执行结果:
完全外连接包含full join左右两表中所有的行,如果右表中某行在左表中没有匹配,则结果中对应行右表的部分全部为空(NULL),如果左表中某行在右表中没有匹配,则结果中对应行左表的部分全部为空(NULL)。
二、内连接 join 或 inner join
SQL语句:select * from student inner join course on student.ID=course.ID
执行结果:
inner join 是比较运算符,只返回符合条件的行。
此时相当于:select * from student,course where student.ID=course.ID
三、交叉连接 cross join
1.概念:没有 WHERE 子句的交叉联接将产生连接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。
SQL语句:select * from student cross join course
执行结果:
如果我们在此时给这条SQL加上WHERE子句的时候比如SQL:select * from student cross join course where student.ID=course.ID
此时将返回符合条件的结果集,结果和inner join所示执行结果一样。
四、两表关系为一对多,多对一或多对多时的连接语句
当然上面两表为一对一关系,那么如果表A和表B为一对多、多对一或多对多的时候,我们又该如何写连接SQL语句呢?
其实两表一对多的SQL语句和一对一的SQL语句的写法都差不多,只是查询的结果不一样,当然两表也要略有改动。
比如表1的列可以改为:
Sno Name Cno
表2的列可以改为:
Cno CName
这样两表就可以写一对多和多对一的SQL语句了,写法和上面的一对一SQL语句一样。
下面介绍一下当两表为多对多的时候我们该如何建表以及些SQL语句。
新建三表:
表A: student 截图如下:
表B: course 截图如下:
表C: student_course 截图如下:
一个学生可以选择多门课程,一门课程可以被多个学生选择,因此学生表student和课程表course之间是多对多的关系。
当两表为多对多关系的时候,我们需要建立一个中间表student_course,中间表至少要有两表的主键,当然还可以有别的内容。
SQL语句:select s.Name,C.Cname from student_course as sc left join student as s on s.Sno=sc.Sno left join course as c on c.Cno=sc.Cno
执行结果:
此条SQL执行的结果是学生选课的情况。
SQL多表查询多个字段
SQL语句格式:
select 字段1,字段2,字段3
from 表1,表2,表3
where 条件
例子:查询s表中的sno字段, c表中的cno字段,j表中的jno字段
select sno,pno,jno
from s,p,j
扩展资料:
删除语句:DELETE * FROM table_name
查询语句:SELECT * FROM Persons WHERE ROWNUM <= 5
建立视图:CREATE VIEW view_name AS SELECT column_name(s) FROM table_name WHERE condition