『壹』 sql兩表查詢用什麼命令
命令:
select
sql 資料庫查詢表格的命令:用SELECT 語句
用法:
查詢某一列:SELECT 列名稱 FROM 表名稱
查詢所有列:SELECT * FROM 表名稱
注釋:
SQL 語句對大小寫不敏感。SELECT 等效於 select。
1、sql多表關聯查詢跟條件查詢大同小異,主要是要知道表與表之前的關系很重要;
2、userinfo(用戶信息表)表中有三個欄位分別為:user_di(用戶編號),user_name(用戶姓名),user_dep(用戶部門) 。(關系說明:userinfo表中的user_dep欄位和dep表中的dep_id欄位為主外鍵關系,userinfo表中的user_sex欄位和sex表中的sex_id欄位為主外鍵關系)。
『貳』 SQL 查找兩表中不同的數據
使用except函數,select * from B where (select count(1) from A where A.ID = B.ID) = 0.
方法一(推薦)
WITH C AS ( SELECT Name
FROM ConsumerCouponApply A
WHERE NOT EXISTS ( SELECT 1
FROM ConsumerCouponApply B
WHERE B.Name = A.Name
GROUP BY B.Name )
GROUP BY A.Name
)
SELECT COUNT(1)
FROM C
方法二
WITH C AS ( SELECT A.Name
FROM ConsumerCouponApply A
GROUP BY A.Name
EXCEPT
SELECT B.Name
FROM ConsumerCouponApply B
GROUP BY B.Name
)
SELECT COUNT(1)
FROM C
方法三
SELECT COUNT(A.Name)
FROM ConsumerCouponApply A
LEFT JOIN ConsumerCouponApply B ON A.Name = B.Name
WHERE B.ID IS NULL
(2)sql語句怎麼查出兩個表格擴展閱讀:
高級查詢運算詞:
A: UNION 運算符:
UNION 運算符通過組合其他兩個結果表(例如 TABLE1 和 TABLE2)並消去表中任何重復行而派生出一個
結果表。當 ALL 隨 UNION 一起使用時(即 UNION ALL),不消除重復行。兩種情況下,派生表的每一行
不是來自 TABLE1 就是來自 TABLE2。
B: EXCEPT 運算符
EXCEPT 運算符通過包括所有在 TABLE1 中但不在 TABLE2 中的行並消除所有重復行而派生出一個結果表。當 ALL 隨 EXCEPT 一起使用時 (EXCEPT ALL),不消除重復行。
C: INTERSECT 運算符
INTERSECT 運算符通過只包括 TABLE1 和 TABLE2 中都有的行並消除所有重復行而派生出一個結果表。當
ALL 隨 INTERSECT 一起使用時 (INTERSECT ALL),不消除重復行。
註:使用運算詞的幾個查詢結果行必須是一致的。
『叄』 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怎麼連接查詢2個表
如果是外連接:select 列名1,列名2
from 表1 left outer join 表2
on 表1.id = 表2.id
如果散簡是等值連接:select 列名1,列名2
from 表1,表2
where 表1.id = 表2.id
結構化查詢語言簡稱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="你輸入的名字"));
延展閱讀:
A表欄位stuid,stuname。
B表欄位bid,stuid,score,coursename,status。
要用一條sql查出A表中所有記錄的對應的stuid,max(score),coursename,status,並且status=1,sql語句要求跨資料庫,不能使用rownum,top,limit等方言。
比如數據:
A
stuid stuname
11 zhangshan
22 lisi
B
bid sutid coursename scoure status
a 11 yuwen 66 1
b 11 shuxue 78 1
c 11 huaxue 95 0
最後要得到的數據是
stuid couresname scoure status
11 shuxue 78 1
22 null null null
『陸』 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語句兩表聯查
可以用謂詞或聯結實現:
連接實現:
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怎麼連接查詢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 = '表名'