㈠ 連接兩表查詢結果的sql語句
如果只查詢兩個表有對應關系的資料,則用內連接:
select
*
from
table1
inner
join
table2
on
table1.id=table2.id;
如果查詢表1中有的資料,表2中若有則也顯示,則使用左連接:
select
*
from
table1
left
join
table2
on
table1.id=table2.id;
不管兩個表是否有關聯,所有資料都顯示,則用外鏈接:
selecg
*
from
table1
outer
join
table2
on
table1.id=table2.id;
㈡ 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 LEFT JOIN
left join 就是左連接,class是主表,content是從表,左連接就是class顯示為主,無論左邊有沒關聯其他信息,都顯示出來,就像牧馬人(主)和馬(從)的關系,牧馬人可以有很多匹馬,也可以有很少馬,也可以沒有馬,沒有馬就不是牧馬人了嗎?這太變扭了!樓主還可以試下用right join來連接兩表!
㈣ SQL左連接查詢
select * from a left join b on a.id=b.id left join c on a.id=c.id where c.id=XX;
㈤ sql 多表 左右多次鏈接
為什麼你那麼喜歡用left join?、
我們首先來看錶表間的關系,看看需不需要left join。
按照你的表格意思?
t_emp.name='張三'
的入職時間,團隊名稱和團隊所屬部門名稱。
一個員工,不管何時入職都有一個編號,和入職時間的,都有所屬團隊和所屬部門。
應該不會存在一個員工,沒有入職時間,沒有編號,不存在所屬團隊和部門的情況吧。
所以個人感覺覺得你這里的多次左右連接其實是增加了查詢的成本,很多應該是沒有必要的,直接用hash連接應該就可以。。
當然我並不知道你的業務結構,可能你的設計沒問題,如果這樣的話,上面的就當我沒說。
SELECT t_emp.name 員工名字,t_hr.Indate 入職日期,t_dept.name 團隊名稱,dept.name 部門名稱 from t_emp,t_hr,t_dept,t_dept dept where t_emp.name='張三' and t_emp.H_num=t_hr.num and t_emp.d_num=t_dept.num and t_dept.d_num=dept.num
其實你上面的查詢也可以,再套一層就行了,你已經查到所屬部門了,在你的結果中加一個t_dept.d_num,然後外面再套一層,讓這個t_dept.d_num=t_dept.num就能找到所屬部門了。
㈥ 如何在一張表上兩次用左連接同一張表
表一是表二的子集,有必要用左連接嗎?直接等連就行了,用個union全解決了
select teacher_id as id,people_name as name
from 表1,表2
where
表1.teacher_id=表2.people_id
union select student_id as id,people_name as name
from 表1,表2
where
表1.student_id=表2.people_id
㈦ SQL語句中兩個表的連接
1、打開資料庫管理工具,在資料庫中新建兩個表用於測試,這里,兩個表的表結構要一樣,分別建立TEST 和 TEST1。
㈧ 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中這兩個左連接的sql語句代表的意思是一樣的么
不一樣,left jion是左表為主體,把右表按照on後面的條件聯接到左表中去,因為是以左表為主的,所以當遇到右表中無匹配的數據時,左表的數據照樣輸出,就以你的sql語句為例子,
select * from T_student s left join T_class c on s.classId = c.classId
如果T_student 中有一些數據的classId在T_class中是沒有的,那麼它還是會繼續輸出
㈩ 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="你輸入的名字"));