关于sql中多表查询的select命令

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于sql中多表查询的select命令相关的知识,希望对你有一定的参考价值。

有两个表a和b,用select命令查询a表和b表中名称为“一车间”的记录,怎么写命令啊?

请各位高手解答一下,不胜感激!!!

参考技术A SELECT * From
(SELECT [其他字段1],[车间字段]… From a
Union All
SELECT [其他字段1],[车间字段]… From b
)a
Where a.车间字段 = '一车间'

两个SELECT 的字段最好是同一种类型,否则不一样的需要用Cast强转
参考技术B 使用union指令 可以把两个select出来的结果联合起来
语法:
[SQL 语句 1]
UNION
[SQL 语句 2]

比如
select 属性1,属性2 from a where 名称='一车间'
UNION
select 属性1,属性2 from b where 名称='一车间'

但是要注意两句select中对应的字段都必须是同一类型的本回答被提问者采纳
参考技术C select * from a inner join b on 公共字段
where 字段='一车间'
参考技术D select * from a,b
where a.公共字段 = b.公共字段 and ziduan = '一车间'

sql 中多表查询-leetcode : Combine Two Tables

因为对数据库的内容早都忘得差不多了,所以我的第一感觉是:

 

select Person.FirstName, Person.LastName, Address.City from Person, Address where Person.PersonId=Address.PersonId

结果出错了:

因为至少这个人是存在的,只是没有她的地址,你不至于搜不到吧, 但是我这种写法是引用两个表,从两个表中获取数据,就是找两者相同的情况下的结果.

使用join 可以连接两个表:

join: 如果表中有一个匹配,则返回行,

select Person.FirstName, person.LastName,Address.City, Address.State from Person join Address on Person.PersonId=Address.PersonId

  (因为连个表中属性不同命,也可以不在属性前加 表名)

 

left join: 即使右表中没有匹配,也从左表中返回所有的行

符合要求

right join: 即使左表中没有匹配,也从右表中返回所有的行

 

 

以上是关于关于sql中多表查询的select命令的主要内容,如果未能解决你的问题,请参考以下文章

Yii2中多表关联查询(joinjoinwith) with是不执行sql的

sql 中多表查询-leetcode : Combine Two Tables

mysql中多表关联删除,怎样做?谢谢...

select 多表关联查询

sql语言多表查询

5MySQL多表查询