当前位置:首页 » 操作系统 » 数据库两个表关联查询

数据库两个表关联查询

发布时间: 2023-02-05 09:23:09

A. 关系数据库如何查询多表有联系数据

关联查询是日常工作中常用的查询方式,关联查询sql编写的思路一般如下:1、先确定所连接的表,2、再确定所要查询的字段,3、确定连接条件以及连接方式(表连接分类: 内连接、外连接、交叉连接、自连接)
1、内连接:[inner] join on
分类:等值连接、非等值连接
(1)等值连接: 指使用等号"=“比较两个表的连接列的值,相当于两表执行笛卡尔后,取两表连结列值相等的记录(自然连接是一种特殊的等值连接)(2)非等值连接:指使用”>“或”<"比较两个表的连接列的值,相当于两表执行笛卡尔后,取一个表大于或小于另一个表的连结列值的记录
2、外连接
分类:左外连接、右外连接、全外连接
(1)左外连接:left outer join
连接效果:查询结果包含左、右两个表需要查询的全部行,左侧的表中的全部数据都会被显示出来,但是右侧表的数据,只有和左侧匹配上的数据才会被查询出来!否则显示为null(2)右外连接:right outer join
连接效果:查询结果包含左、右两个表需要查询的全部行,右侧的表中的全部数据都会被显示出来,但是左侧表的数据,只有和右侧匹配上的数据才会被查询出来!否则显示为null(3)全外连接:full/all outer join,查询结果包含左、右两个表需要查询的全部行,对应字段没有值显示null
3、交叉连接
左表中的每一行与右表中的所有行组合,也叫表与表之间做笛卡尔积查询
4、自连接
当前表与自身的连接查询,关键点在于虚拟化出一张表,即给自身的表定义一个别名

B. SQL怎么连接查询2个表

使用where语句进行查询,如:

select Emp.E_Id,Company.C_OraName from Emp,Company where Companey.C_Id=Emp.C_Id

但是往往会碰到比较复杂的语句,这时候使用where就不太合适了,其实SQL可以用较为直接的形式进行连接操作,可以在From子句中以直接的形式指出:

select top 10 E_Id,E_Name,C_Name

from

Emp join Companey on Companey.C_Id=Emp.C_Id

where

E_Id not in (select top 20 E_Id from Emp order by E_Id asc)

order by E_Id asc

//查询表Emp中第21到第30条数据以升序排列,其中C_Name来自于另一个表

(2)数据库两个表关联查询扩展阅读:

SQL查询语句

1、获取当前数据库中的所有用户表select Name from sysobjects where xtype='u' and status>=0

2、获取某一个表的所有字段select name from syscolumns where id=object_id('表名')select name from syscolumns where id in (select id from sysobjects where type = 'u' and name = '表名')

3、查看与某一个表相关的视图、存储过程、函数select a.* from sysobjects a, syscomments b where a.id = b.id and b.text like '%表名%'

4、查看当前数据库中所有存储过程select name as 存储过程名称 from sysobjects where xtype='P'

5、查询用户创建的所有数据库select * from master..sysdatabases D where sid not in(select sid from master..syslogins where name='sa')

或者select dbid, name AS DB_NAME from master..sysdatabases where sid <> 0x01

6、查询某一个表的字段和数据类型select column_name,data_type from information_schema.columnswhere table_name = '表名'

C. pg数据库的db怎么查看表关联

一、数据库的多表连接查询,inner的不同用法

在pg数据库中建立两张表:

t_a和t_b如下所示:

t_a:

t_b:

1、inner join(内连接)

inner join就是根据on字段标示出来的条件,查询关联的表中符合条件的数据,并把他前部都显示出来,形成一个结果集。

执行如下语句:

select * from t_a inner join t_b on t_a.adi=t_b.bid

得到的结果为:

这样的查询会显示出所有的数据,如果我们仅仅需要一部分的数据(例如我们只想查出t_a中所有aid和t_b中的bid相同的数据),那么查询语句应该变成:

select t_a.* from t_a inner join t_b on t_a.aid=t_b.bid

那么得到的数据如下所示,就只显示了t_a表中的数据。如下:

要排除重复的数据,在select后加distinct即可。

2、left join

left join 就是以表t_a为基础从右表t_b中查询出所有符合on条件的结果,在合并到表t_a中对应的部分,再作为一个结果集输出,在结果集中,会显示出表t_a中的所有数据。

执行如下查询语句:

select * from t_a left join t_b on t_a.aid=t_b.bid

得到如下结果:

可以看到,在查询的结果中,有一行关于表t_b的数据都为null,因为表t_b中没有符合on条件的数据。但是表t_a表显示出了全部的数据。那么在需要筛选的时候,应该着重于筛选表t_b中的数据,如果执行如下的语句:

select t_a.* from t_a left join t_b on t_a.aid=t_b.bid

那么得到的就是表t_a中的所有数据,那么这个查询就显得没有意义了。

3、right join

right join 就是以表t_b为基础从左表t_a中查询出所有符合on条件的结果,在合并到表t_b中对应的部分,再作为一个结果集输出,在结果集中,会显示出表t_b中的所有数据。

执行如下查询语句:

select * from t_a right join t_b on t_a.aid=t_b.bid

得到的结果为:

可以看到,查询的结果中,有两行数据在表t_a的对应部分都是null的,表示表t_a中没有符合on条件的数据,但是表t_b显示了全部的数据,那么需要做条件筛选的时候,我们就应该主要针对表t_a进行筛选。

二、查询一个父级的所有子级(包括子级的子级)

在pg数据库中建立一张表t_c如下:

要查出cid为1的所有的子级、包括cid为2、3、5的子级的集合。执行以下sql语句

with recursive tb as(select * from t_c where parent_id='1' union all select t_c.* from t_c,tb where t_c.parent_id=tb.cid )select * from tb

得到如下的结果:

由查询出的结果集可以看到,我们查询出了除了父级(cid为1)以外的所有cid为父级的子级以及子级的子级。

我们来解析一下这个sql语句:

显而易见的,这是一个递归的查询方法。首先是with为查询语句提供了辅助功能,可以看做是查询语句中的临时表,其次recursive是sql中递归的关键字,只有有了这个关键字,pg才知道with这个语句需要做递归操作。union all是去重的,t_c.parent_id=tb.cid 表示了t_c的parent_id要等于临时表tb的cid要在整个with语句的外面查询建立的临时表tb,才能得到所有的子级的集合。

D. 两张表在不同的数据库,如何关联查询

1、首先我们在Toad for MySQL中打开数据库连接。

E. oracle两张表关联查询

select e.empno, e.ename, d.deptno, d.dname

from emp e, dept d

where e.deptno = d.deptno;

在之前所使用的查询操作之中,都是从一张表之中查询出所需要的内容,那么如果现在一个查询语句需要显示多张表的数据,则就必须应用到多表查询的操作,而多表查询的语法如下:

SELECT [DISTINCT] * | 字段 [别名] [,字段 [别名] ,…] FROM 表名称 [别名], [表名称 [别名] ,…] [WHERE 条件(S)] [ORDER BY 排序字段 [ASC|DESC] [,排序字段 [ASC|DESC] ,…]]。

(5)数据库两个表关联查询扩展阅读:

Oracle 常用的关联查询:

Oracle外连接:

(1)左外连接 (左边的表不加限制)。

(2)右外连接(右边的表不加限制)。

(3)全外连接(左右两表都不加限制)。

outer join则会返回每个满足第一个(顶端)输入与第二个(底端)输入的联接的行。它还返回任何在第二个输入中没有匹配行的第一个输入中的行。

外连接分为三种: 左外连接,右外连接,全外连接。 对应SQL:LEFT/RIGHT/FULL OUTER JOIN。 通常我们省略outer 这个关键字。 写成:LEFT/RIGHT/FULL JOIN。

在左外连接和右外连接时都会以一张表为基表,该表的内容会全部显示,然后加上两张表匹配的内容。 如果基表的数据在另一张表没有记录。 那么在相关联的结果集行中列显示为空值(NULL)。



F. 数据库-联表查询

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

查询结果如下:

G. 如何对access中两个数据库中表进行联合查询

点击菜单栏上面的:创建——查询设计;
在弹出的对话框中选择两个表:订单和订单明细,然后点击添加;
添加下列字段到设计表中;
点击菜单栏上面的保存按钮;
在弹出的对话框中,输入这个查询的名字,然后点击确定即可。

H. 两表关联查询SQL语句的,要怎么写

1、首先打开数据库客户端Navicat Premium 15工具,点击并打开一个数据库连接。

热点内容
招标服务器云 发布:2024-05-19 20:04:19 浏览:583
搭建小米云服务器 发布:2024-05-19 19:43:17 浏览:130
苹果手机备忘录怎么加密 发布:2024-05-19 18:57:57 浏览:16
光荣脚本 发布:2024-05-19 18:57:48 浏览:997
pythonjson字符串 发布:2024-05-19 18:51:43 浏览:253
什么是服务器厂商介绍 发布:2024-05-19 18:50:09 浏览:371
服务器网卡硬件型号怎么看 发布:2024-05-19 18:36:41 浏览:666
修改pve服务器ip 发布:2024-05-19 18:31:52 浏览:469
微信密码忘记了如何取出里面的钱 发布:2024-05-19 18:27:35 浏览:330
vs2005反编译 发布:2024-05-19 18:26:34 浏览:364