聯表查詢sql
① 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查詢語句
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
圖片:(表名截圖)
算了,建表語句也給你們了,你們自己測試,這樣更詳細,(程序員)多動手,比什麼都好。(這里的 界面 對寫代碼不太友好,我放博客里了,自己復制粘貼測試使用就行)
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聯合查詢語句(兩張表)
sql聯合查詢語句(兩張表)是:
select A.ID,A.VALUE,A.TYPE,A.NAME,B.KEY,B.ID,B.VALUE,B.NAME
min(VALUE),max(VALUE) from A left join B on A.ID = B.ID
where B.NAME="你輸入的名字"
and B.VALUE > (select min(VALUE) from B where NAME="你輸入的名字"))
and B.VALUE < (select min(VALUE) from B where NAME="你輸入的名字"));
④ 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兩個表的聯合查詢語句
(SELECT
產品單號,產品型號,產品零件,SUM(員工生產零件數量)
FROM
B
GROUP
BY
產品單號,產品型號,產品零件)
B1;
SELECT
A.產品單號,B1.產品型號,(A.生產數量-B1.SHULIAGN)
FROM
A,(SELECT
產品單號,產品型號
SUM(員工生產零件數量)
FROM
B
GROUP
BY
產品單號,產品型號)
B1
WHERE
A.產品單號=B1.產品單號
AND
A.產品型號=B.產品型號;
SELECT
SUM(員工生產零件數量),產品單號,產品型號,產品零件
FROM
B
GROUP
BY
產品單號,產品型號,產品零件;
⑥ 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語句
我來講一下多表聯合查詢SQL語句:
A、B兩表
A表:idd name2 image2 tag2
1 長城 。 長城
2 故宮 。 故宮
3 天安門 。 天安門B表:id name image tag
1 愛情1 。 長城
2 天空 。 故宮
3 23愛 。 長城當tag2=tag,輸出
查詢結果:idd name2 image2 name image
1 長城 。 愛情1、23愛 。、。註:(A表記錄1條,B表相關記錄2條)以此展開循環
⑧ 如何sql三張表關聯查詢
三張表關聯查詢
使用場景:A\B\C 三張表,現在要查詢並展示A表和C表中的某些欄位,但是A、C兩表沒有相同欄位,無法關聯,此時有B表恰好有兩個欄位,一個欄位和A表一個欄位相同,一個欄位和C表一個欄位相同,我們稱B表為「中間表」,因此通過B表把A、C表關聯起來
SELECT A1,A2,C1,C2 --展示A表中的A1\A2欄位和C表中的C1\C2
FROM B --中間表
INNER JOIN A ON A.A1 = B.B1 --A表中的與B表中相同的欄位
INNER JOIN C ON C.C1 = B.B1 --C表中的與B表中相同的欄位
where xxxxx ---條件你自己按照需求來加,沒有條件就不寫where了
⑨ sql多表聯查實例
sql多表聯查實例
下面提供四款sql多表關聯查詢的實例,個個效率不一樣。
select
*
from
order_info
as
a
,ivrlog4ivrdlvinst
as
b
where
(a.saleorder=b.ext1_skill
and
b.start_date=@date1
and
se_id='55'
and
b.ext1_skill!='')
and
convert(varchar(10),a.instime,112)=@date2
and
max(a.instime)
方法二
select
*
from
order_info
as
a
where
a.saleorder=(
select
b.ext1_skill
from
ivrlog4ivrdlvinst
as
b
where
b.start_date=@date1
and
se_id='55'
and
b.ext1_skill!='')
and
convert(varchar(10),max(a.instime),112)=@date2
方法三
declare
@date1
varchar(20),
@date2
varchar(20)
set
@date1='20100812'
set
@date2='2010-08-12'
select
*
from
order_info
as
a
where
a.saleorder=
(select
b.ext1_skill
from
ivrlog4ivrdlvinst
as
b
where
b.start_date=@date1
and
se_id='55'
and
b.ext1_skill!='')
and
convert(varchar(10),a.instime,112)=@date2
and
max(a.instime)
方法四
select
b.caller,
b.start_date,
b.start_time,
b.ext1_skill,
c.deliveryno,
c.destroyresult,
c.deliverydate,
c.deliverytime,
c.arrangetime,
c.driverphone,
c.drivermobile,
a.servicedate,
a.servicetime,
a.workertel
from
order_info
as
a
,ivrlog4ivrdlvinst
as
b
,delivery_info
as
c
where
a.saleorder
in
(select
b.ext1_skill
from
ivrlog4ivrdlvinst
where
b.start_date=@date1
and
b.se_id='55'
and
b.ext1_skill!='')
and
convert(varchar(10),a.instime,112)=@date2
order
by
b.start_date
desc,
b.start_time
desc