⑴ sql语句两表联查
可以用谓词或联结实现:
连接实现:
select * from b join a on b.id=a.id where a.b=21
联结实现的条件是两表id来自同一值域,表示意义相同.在连接时其实两可以作成一个表的:
也就是
id,a.b,a.c,b.b.b.c
但由于空值的问题,导致了部分依赖所以才会拆分成两个表的.
使用谓词实现:
select * from b where id in (select id from a where a.b=21)
这个可以实现两表id来自同一值域,但表示意义不同的情况.也就是说两表中的id有无关性.
相比较而言,连接的方式更快一些,但这种情况是两表来自同一值域,且意义相同,如果不是这种情况,可能得不到你正确的值的.而使用谓词不管意义是否相同,都可以得到正确的值.
玩数据库必须知道这两个表是否具有相关性,也就是设计时的意义,否则优化词句什么的都没有办法去做的!
有几种方式可以实现你的这个需求.
1. 使用表 关联
SELECT * FROM 表2 JOIN 表1 ON ( 表2.ID = 表1.列1 );
2. 使用 IN
SELECT * FROM 表2 WHERE ID IN ( SELECT 列1 FROM 表1);
3.使用 EXISTS
SELECT * FROM 表2
WHERE EXISTS ( SELECT 1 FROM 表1 WHERE 表2.ID = 表1.列1 );
select * from t2 left join t1 on t2.ID = t1.列1 where t1需要啥条件 and t2需要啥条件
select * from 表2 where 某列 in (select 列1 from 表1) and id=1
⑵ sql语句连表查询怎么查
select * from 主表 a,从表 b where a.id=b.pid order by b.add_time desc
⑶ SQL 几种联表查询方式
二、CROSS JOIN(创建笛卡尔积) 对两张表通过交叉联合产生第三张返回结果集的表。相当于普通的连接。 三、INNER JOIN(内连接) 内连接就相当于普通的CROSS JOIN,只是格式不一样,INNER JOIN在后面有一个ON子句(相当于WHERE)的搜索条件,用于过滤返回的行。 四、OUTER JOIN (外连接) select * from ta outer join tb on (ta.c1=tb.c1) outer join告诉DBMS生成结果表,在此表中不仅带有相关(ta.c1=tb.c1)行对,而且还有来自两个源表中任一表的不匹配的行。 五、LEFT OUTER JOIN(左连接) RIGHT OUTER JOIN(右连接) select * from ta left outer join tb on (ta.c1=tb.c1) select * from ta right outer join tb on (ta.c1=tb.c1) left outer join(left join) 告诉DBMS生成包括联合行和任何不匹配的行的结果表,但是不匹配的行系来自查询的FROM子句中LEFT OUTER JOIN关键词左边的表中。 right outer join(right join)与left outer join(left join)刚好相反。 六、FULL OUTER JOIN(全连接) FULL OUTER JOIN 返回组合了LEFT OUTER JOIN 和RIGHT OUTER JOIN结果的表。 以下是Inner Join及Outer Join的具体介绍: 在一个正规化的数据库环境中, 我们常会碰到这款情形: 所需的资料并不是放在同一个资料表中, 在这个时候, 你就要用到 Join。 当然Join 如何将不同的数据库的资料结合, 还要看你如何使用它, 一共有四种不同的 Join 的方式, 在这篇文章中我们将为你介绍 Inner Join 及 Outer Join 以及其应用。 Inner Join (自然连接)Inner Join 应该是最常用的 Join 方式, 它只会传回符合 Join 规则的纪录, 还是先来看看语法: Select <要选择的字段> From <主要资料表> <次要资料表> [On ] 现在我们利用 MS SQL Server 的内建数据库看一个实例。 Select ProctId, ProctName, SupplierId From Procts 从Procts 产品资料表中取出三个字段, 分别是产品代码, 产品名称, 供货商代码, 但查询出来的结果保证让你的老板很不满意, 因为供货商代码对于人类实在是无什么意义, 这个时候 Join 就可以帮上忙了, 借由 Join Suppliers 这个资料表我们便可以查询到供货商名称Select ProctId, ProctName, Suppliers.SupplierId From Procts 首先要拿掉 Procts 资料表的 Foreign Key, 否则没有法度在 Procts 资料表新增一笔 SupplierId 没有对映到 Suppliers 资料表的纪录, 要知影一个资料表的 Constraint 你可以执行 SQL 内建的 sp_helpconstraint , 在 QA 执行 sp_helpconstraint Procts 接下来删除 FK_Procts_Suppliers 这个 Foreign Key Alter Table Procts Drop Constraint FK_Procts_Suppliers 再来新增一笔纪录于 Procts 资料表, SupplierId 使用 50 是因为它并没有对映到 Suppliers 资料表中的记录 Insert Into Procts (ProctName,SupplierId,CategoryId) values ('Test Proct','50','1') 现在我们再执行头前的查询, 只是将 Inner Join 改为 Left Outer Join Select ProctId, ProctName, Suppliers.SupplierId From Procts Left Outer Join Suppliers Procts.Suppliers = Suppliers.SupplierId 比较一下两种 Join 方式的查询结果, 你应该就会知影其中的差别! 再来看看 Right Outer Join, 请新增下底这笔记录 Insert Into Suppliers (CompanyName) values ('LearnASP') 现在请使用 Right Out Join 来作查询, 比较看看查询的结果和 Inner Join 有什么不同! 寻找不相符纪录 这里我们来看看如何使用 Out Join 来找不相符纪录, 可能是有子纪录却没有父纪录或是颠倒过来 Select Suppliers.CompanyName From Procts Right Join Suppliers On Procts.SupplierId = Suppliers.SupplierId Where Procts.SupplierId is Null 执行结果你会找到一笔资料为 LearnASP, 该笔供货商资料存在, 但基本上已经没有产品是来自这个供货商, 想象一下如果不用 Outer Join 你要怎么以一个 SQL 指令完成同一查询结果! 知道 Outer Join 的好用了吧! 再执行 Select Procts.ProctName From Procts Left Join Suppliers On Procts.SupplierId = Suppliers.SupplierId Where Suppliers.SupplierId is Null 这个查询结果你会发现 Test Proct 这项产品竟然找不到供货商的资料!
⑷ SQL语句联表查询
SELECTitem,sum(a.need_pay) '需要支付金额',sum(b.paymoney) '已付金额'
FROM A,(SELECT b.A_id,sum(B.money) 'paymoney' FROM B group by B.A_id) b
where A.A_id = b.A_id
GROUP BY A.item
HAVINGsum(a.need_pay)<> sum(b.paymoney)
(4)sql如何实现连表查询扩展阅读:
关于sql语句连表查询
语法
SELECT fields
FROM table1 INNER JOIN table2
ON table1.field1 compopr table2.field1 AND
ON table1.field2 compopr table2.field2 OR
ON table1.field3 compopr table2.field3;
也可以通过如下语法嵌套 JOIN 语句:
SELECT fields
FROM table1 INNER JOIN
(table2 INNER JOIN [( ]table3
[INNER JOIN [( ]tablex [INNER JOIN ...)]
ON table3.field3 compopr tablex.fieldx)]
ON table2.field2 compopr table3.field3)
ON table1.field1 compopr table2.field2;
LEFT JOIN 或 RIGHT JOIN 可以嵌套在 INNER JOIN 之中,但是 INNER JOIN 不能嵌套于 LEFT JOIN 或 RIGHT JOIN 之中。
⑸ sql语句如何两表连查
多表查询分为
内、外连接
外连接分为左连接(left
join
或left
outer
join)、右连接(right
join
或者
right
outer
join)、和完整外部连接
(full
join
或者
full
outer
join)
左连接(left
join
或
left
outer
join)的结果就是left
join子句中的左表的所有行,而不仅仅是链接列所匹配的行,如果左表中的某行在右表中没有匹配,则在相关联的结果行中右表的所有选择列均为空值(NULL)
SQL语法select
*
from
table1
left
join
table2
on
table1.条件列名
=
table2.条件列名;
注释:
显示的就是table1中的所有列和能匹配的列
右连接(right
join
或
right
outer
join
)在这里不做多说这左连接很象但是是相反的,只说一下语法
select
*from
table1
right
join
table2
on
table1.
条件列=
table2.条件列
完全外部连接(full
join
或
full
outer
join)
显示左右表中的所有行,当某一个表中没有匹配的行时,则另一个表的选择列表列包含空值(NULL)如果有则显示全部数据
SQL语法:
select
*from
table1
full
join
table2
on
table1.条件列名=
table2.条件列名
内连接:
概念:内连接就是用比较运算符比较要用连接列的值的连接
内连接(join
或者inner
join
)
SQL语法:
select
*fron
table1
join
table2
on
table1.条件列名
=
table2.条件列名
返回符合匹配条件的两表列
等价于:
select
A*
,B*
from
table1
A
,table2
B
where
A.条件列名
=B.条件列名
select
*form
table1
cross
join
table2
where
table1.条件列名
=
table2.条件列名(注:
Cross
join
后面不能跟on
只能用where)
交叉连接(完全)
概念:没有用where子句的交叉连接将产生连接所涉及的笛卡尔积第一个表的行数乘以第二个表的行数等于笛卡尔积和结果集的大小
交叉连接:
Cross
join(不带条件where,如果带返回或显示的是匹配的行数)
SQL语法:
select
*from
table1
cross
join
table2
如果有条件(where)
select
*
from
table1
cross
join
table2
where
table1.
条件列名=
table2.条件列名
等价于
select
*from
table1,table2
(不带where)
⑹ sql语句 连表查询
SELECT * FROM sheet1 LEFT JOIN sheet2 ON sheet1.`字段名` = sheet2.`字段名`
⑺ SQL数据库的表。怎么同时连接3个表查询。
可以参考下面的方法:
1、select * from 表1,表2,表3 where 表1.字段=表2.字段 and 表1.字段=表3.字段
2、select * from 表1 join 表2 on 表1.字段=表2.字段 and join 表3 on 表1.字段=表3.字段
如果没有AND,前面就需要加括号了。
(7)sql如何实现连表查询扩展阅读:
参考语句
创建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
根据已有的表创建新表:
1、create table tab_new like tab_old (使用旧表创建新表)
2、create table tab_new as select col1,col2… from tab_old definition only
删除新表
drop table tabname
⑻ 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来自于另一个表
(8)sql如何实现连表查询扩展阅读:
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 = '表名'
⑼ 用SQL语句实现两表联查
工具/原料
计算机 SQLserver2008
方法/步骤
1、查询所有选课的学生的学号,姓名,课程名及成绩。查询语句。
⑽ 这个sql联合查询问题困扰了我两个月,请教如何用SQL语句实现两表查询,显示如图片所示的结果
这个就是a表左连接b表,然后on条件是姓名,按照姓名和时间升序排序就可以啊。