其實不能說連接查詢有什麼優缺點
要非得說的話也許是
當需要即時計算聚集值並把該值用於外部查詢中進行比較時,子查詢就比連接更具有優勢。
如果查詢中的SELECT列表所包含的列來自於多個表,那麼這時連接的優勢要勝過子查詢
以下是連接查詢
你慢慢看吧
一.自連接查詢:
一個表自己與自己建立連接稱為自連接或自身連接。
進行自連接就如同兩個分開的表一樣,可以把一個表的某一行與同一表中的另一行連接起來。
例:
查詢選學「101」課程的成績高於「9505201」號學生成績的所有學生記錄,
並按成績從高到低排列。
select x.* from sclass x,sclass y
where x.cno=''101'' and x.degree>y.degree and y.sno=''9505201'' and y.cno=''101''
order by x.degree desc
二. 內連接查詢
內連接(INNER JOIN)使用比較運算符進行表間某(些)列數據的比較操作,並列出這些表中與連接條件相匹配的數據行。根據所使用的比較方式不同,內連接又分為等值連接、自然連接和不等連接三種。
1、等值連接:
所謂等值連接,是指表之間通過「等於」關系連接起來,產生一個臨時表,
然後對該臨時表進行處理後生成最終結果。其查詢結果中列出被連接表中的所有列,
包括其中的重復列。
SELECT *
FROM authors AS a INNER JOIN publishers AS p
ON a.city=p.city
我們可以有兩種方式,這兩種是等效的
一種是:SELECT e.employeeid,e.employeename,d.deptname FROM EmployeeTB AS e,DeptTB AS d WHERE e.deptid=d.deptid
另外一個是:SELECT e.employeeid,e.employeename,d.deptname FROM EmployeeTB AS e INNER JOIN DeptTB AS d ON e.deptid=d.deptid
3、自然連接:
在等值連接中消除重復列就是自然連接。(state,city在兩個表中都存在)
SELECT a.*,p.pub_id,p.pub_name,p.country
FROM authors AS a INNER JOIN publishers AS p
ON a.city=p.city
三 外連接查詢 (左外連接、右外連接、全外連接)
左向外聯接的結果集包括 LEFT OUTER 子句中指定的左表的所有行,而不僅僅是聯接列所匹配的行。如果左表的某行在右表中沒有匹配行,則在相關聯的結果集行中右表的所有選擇列表列均為空值
右向外聯接是左向外聯接的反向聯接。將返回右表的所有行。如果右表的某行在左表中沒有匹配行,則將為左表返回空值。
A left join B 的連接的記錄數與A表的記錄數同
A right join B 的連接的記錄數與B表的記錄數同 這種說法是錯誤的,只有當表A與表B是一對一時才成立。
首先我們做兩張表:員工信息表和部門信息表,在此,表的建立只為講述連接的概念,所以欄位非常的簡單
EmployeeTB(員工信息表):
employeeid employeename deptid
0001 張三 01
0002 李四 01
0003 王五 02
0004 趙六 02
0005 鄭七 NULL
DeptTB(部門信息表)
deptid deptname
01 技術部
02 市場部
03 工程部
1左外聯結
但是有些情況下,我們需要知道所有員工的信息,即使他不屬於任何部門。這樣我們就可以採用外連接,在這里為左外連接,也就是連接中的左表的表中的記錄,無論能不能在右表中找到匹配的項,都要檢索,如果沒有匹配的項目,那麼右表中的欄位值為NULL(空),在這里就代表,此員工不屬於任何部門。
檢索語句為:
SELECT e.employeeid,e.employeename,d.deptname FROM EmployeeTB AS e LEFT OUTER JOIN DeptTB AS d ON e.deptid=d.deptid
檢索的結果都是:
employeeid employeename deptname
0001 張三 技術部
0002 李四 技術部
0003 王五 市場部
0004 趙六 市場部
0005 鄭七 NULL
但是在這里,工程部同樣不會被檢索,因為,deptname是在連接的右邊的表中,「工程部」在左表中不存在任何的記錄,所以不會被檢索。這里關注的是「連接中的左邊的表」
2、右外連接
有時,我們需要知道,全部部門的信息,即使它沒有任何的員工。在我們的查詢中部門表在連接的右邊,如果我們想知道右邊表中的所有記錄信息,那麼就可以採用右外連接,如果此記錄在左邊的表中找不到匹配項,則相應欄位(employeeid,employeename)為NULL
檢索語句為:
SELECT e.employeeid,e.employeename,d.deptname FROM EmployeeTB AS e RIGHT OUTER JOIN DeptTB AS d ON e.deptid=d.deptid
檢索的結果都是:
employeeid employeename deptname
0001 張三 技術部
0002 李四 技術部
0003 王五 市場部
0004 趙六 市場部
NULL NULL 工程部
但在這里,鄭七是不會被檢索了,因為它在右表中找不到匹配項,這里關注的是「連接中的右邊的表」
3、完全外連接
如果我們想知道所有的記錄呢?無論員工有沒有部門,部門有沒有員工,我們都需要檢索。這里就可以使用完全外連接。關注連接中的兩部分。如果沒有部門,部門為空,沒有員工,員工信息為空。
檢索語句為:
SELECT e.employeeid,e.employeename,d.deptname FROM EmployeeTB AS e FULL OUTER JOIN DeptTB AS d ON e.deptid=d.deptid
檢索的結果都是:
employeeid employeename deptname
0001 張三 技術部
0002 李四 技術部
0003 王五 市場部
0004 趙六 市場部
0005 鄭七 NULL
NULL NULL 工程部
四.交叉連接
交叉連接不帶WHERE 子句,它返回被連接的兩個表所有數據行的笛卡爾積,返回到結果集合中的數
據行數等於第一個表中符合查詢條件的數據行數乘以第二個表中符合查詢條件的數據行數。
例,titles表中有6類圖書,而publishers表中有8家出版社,則下列交叉連接檢索到的記錄數將等
於6*8=48行。
三個表的左連接示例:
准備數據:
表t1
欄位名:t1_id,username,psw
表t2
欄位名:t2_id,gname,t1_id //這里一個t1_id對應多個t2_id
t3
欄位名:t3_id,realname,tel,t1_id //這里一個t1_id對應一個t3_id
『貳』 sql中怎樣查出關聯外的數據
SELECT A.*,B.* FROM A FULL JOIN B ON a.XXX_id = b.XXX_id
------------------------------------------------------
例如:a表欄位XXX_id值: 1、2、3,b表欄位XXX_id值:1、2、3、4、5、6,關聯出的是1、2、3,而我只想查出4、5、6這這3條記錄
要那樣也容易
再補充個where就好
SELECT A.*,B.* FROM A FULL JOIN B ON a.XXX_id = b.XXX_id
where a.id is null or b.id is null
『叄』 SQl常用增刪改查
SQl常用增刪改查模板
篇一:SQl常用增刪改查
SQL常用增刪改查語句
增加
現在有一張表,表(Test)裡面有三個欄位,分別為sno,sname,age。舉例用一條增加SQL語句,插入一條數據進庫。
語句:
Insert into 表名 value(『數據1』,』數據2』,』數據3』)
具體操作: Insert into testvalues('test','test','1')
通過上面這條語句,Test表裡面就多了一條數據。如下圖所示:
上面這個例子,是在每條欄位都需要插入的時候為了方便而直接在 into 後面跟表名。但是也會遇到一些特殊的情況,比如一張表,因為有主外鍵約束(我這里只有一張表),而我只想插入被約束的欄位sno(主鍵)加上age這個欄位,在 into的時候就需要指明需要插入的欄位,下面舉例說明:
語句:
Insert into 表名(『欄位名1』,』欄位名2』) values(『數據1』,』數據2』)
具體操作:
into test(sno,age)values('彭宇','21')
這樣資料庫裡面,又多了一條數據,而沒有插入任何數據那個欄位默認為NULL。如下圖所示:
刪除
在我們增加數據入庫的時候,難免會出現數據錄入錯誤,或者信息過期後不再需要的數據,所以我們要利用刪除語句將表裡面不需要的數據刪除掉。下面舉例說明。
語句:
Delete from 表名 where 欄位名='需要刪除的數據'
具體操作:
from test where sno='test'
通過這條SQL語句,Test表主鍵sno欄位裡面數據為test的該條數據就已經被刪除了。
Ps:一般來說都以主鍵為條件進行刪除,因為主鍵是不可重復的,我們可以設想一下,如果沒使用主鍵為刪除條件,假設一個公司有兩個叫彭宇的人。我使用sname=』彭宇』作為刪除條件的話,那麼這兩個同名同姓人的資料都會被刪除掉,所以這是不可取的。
批量刪除
當有多條數據需要刪除的時候,我們可以使用批量刪除語句來實現一次刪除多條數據。
語句:
from表名where欄位名in('該欄位裡面的數據1','該欄位裡面的數據2',……)
具體操作:
首先,看一下Test表裡面有多少條數據,如下圖:
現在我想利用一條SQL語句,將前三條數據刪除掉。
from test where sno in('test','test2','test3')
通過執行這條SQL語句後,前三條數據已經被我批量刪除了。
修改
一條已經錄入資料庫裡面的數據如果需要更新、修正,我們就需要用到SQL修改語句。
語句:
Update 表名set欄位='修改後的數據' where 欄位='修改條件'
具體操作:
Update test set sno='SQL修改語句' where sno='test'
修改前後比較,下圖所示: (
修改前
)(修改後)
查詢
上面進行了增加,修改操作後,資料庫裡面已經存在有數據了,最後我們要利用SQL查詢語句將它們查詢並顯示出來。
全部查詢
語句:
Select * from 表名
具體操作:
Select * from test
執行了上面這句話,那麼test表裡面存在的數據都會被查詢出來,如果我想要單獨查詢出某個人的數據怎麼辦?很簡單,只需要加上一個關鍵詞where就能夠實現了。
單條件查詢
語句:
Select * from 表名 where 欄位=』需要查詢的數據』
具體操作:
Select * from test where sno=』彭宇』
這樣我就查詢出資料庫裡面sno欄位為彭宇的數據了。
多條件查詢
多條件查詢就是比起單條件查詢多了一個and關鍵詞,使用多條件查詢,查出來的結構能夠更加的精確。
語句:
Select * from 表名 where 欄位=』需要查詢的數據』 and 欄位=』需要查詢的數據』
具體操作:
Select * from test where sno=』彭宇』』21』 and age=
篇二:SQL語句增刪改查
一、刪:有2中方法
1.使用刪除數據某些數據
語法: from <表名> [where <刪除條件>]
例: from a where name='開心朋朋'(刪除表a中列值為開心朋朋的行) 注意:刪除整行不是刪除單個欄位,所以在後面不能出現欄位名
2.使用truncate table 刪除整個表的數據
語法:truncate table <表名>
例:truncate table tongxunlu
注意:刪除表的所有行,但表的結構、列、約束、索引等不會被刪除;不能用語有外建約束引用的表
二、改
使用update更新修改數據
語法:<表名> set <列名=更新值> [where <更新條件>]例:tongxunlu set 年齡=18 where 姓名='藍色小名'
注意:set後面可以緊隨多個數據列的更新值;where子句是可選的,用來限制條件,如果不選則整個表的所有行都被更新
四、查
1.普通查詢
語法:select <列名> from <表名> [where <查詢條件表達試>] [order by <排序的列名>[asc或desc]]
1).查詢所有數據行和列
例:select * from a
說明:查詢a表中所有行和列
2).查詢部分行列--條件查詢
例:select i,j,k from a where f=5 說明:查詢表a中f=5的所有行,並顯示i,j,k3列
3).在查詢中使用AS更改列名
例:select name as 姓名 from a whrer xingbie='男'
說明:查詢a表中性別為男的所有行,顯示name列,並將name列改名為(姓名)顯示
4).查詢空行
例:select name from a where email is null
說明:查詢表a中email為空的所有行,並顯示name列;SQL語句中用is null或者is not null來判斷是否為空行
5).在查詢中使用常量
例:select name '唐山' as 地址 from a
說明:查詢表a,顯示name列,並添加地址列,其列值都為'唐山'
6).查詢返回限制行數(關鍵字:top percent)
例1:select top 6 name from a
說明:查詢表a,顯示列name的前6行,top為關鍵字
例2:select top 60 percent name from a
說明:查詢表a,顯示列name的60%,percent為關鍵字
7).查詢排序(關鍵字:order by , asc , desc)
例:select name
from a
where chengji>=60
order by desc
說明:查詢表中chengji大於等於60的所有行,並按降序顯示name列;默認為ASC升序
2.模糊查詢
1).使用like進行模糊查詢
注意:like運算副只用語字元串,所以僅與char和varchar數據類型聯合使用 例:select * from a where name like '趙%'
說明:查詢顯示表a中,name欄位第一個字為趙的記錄
2).使用between在某個范圍內進行查詢
例:select * from a where nianling between 18 and 20
說明:查詢顯示表a中nianling在18到20之間的記錄
3).使用in在列舉值內進行查詢
例:select name from a where address in ('北京','上海','唐山')
說明:查詢表a中address值為北京或者上海或者唐山的記錄,顯示name欄位3.分組查詢
1).使用group by進行分組查詢
例:select studentID as 學員編號,AVG(score) as 平均成績 (注釋:這里的score是列名)
from score (注釋:這里的score是表名)
group by studentID
說明:在表score中查詢,按strdentID欄位分組,顯示strdentID欄位和score欄位的平均值;select語句中只允許被分組的列和為每個分組返回的一個值的表達試,例如用一個列名作為參數的聚合函數
2).使用having子句進行分組篩選
例:select studentID as 學員編號,AVG(score) as 平均成績 (注釋:這里的score是列名)
from score (注釋:這里的score是表名)
group by studentID
having count(score)>1
說明:接上面例子,顯示分組後count(score)>1的行,由於where只能在沒有分組時使用,分組後只能使用having來限制條件,
4.多表聯接查詢
1).內聯接
①在where子句中指定聯接條件
例:select a.name,b.chengji
from a,b
where a.name=b.name
說明:查詢表a和表b中name欄位相等的記錄,並顯示表a中的name欄位和表b中的chengji欄位
②在from子句中使用join…on
例:select a.name,b.chengji
from a inner join b
on (a.name=b.name)
說明:同上
2).外聯接
①左外聯接查詢
例:select s.name,c.courseID,c.score
from strdents as s
left outer join score as c
on s.scode=c.strdentID
說明:在strdents表和score表中查詢滿足on條件的行,條件為score表的.strdentID與strdents表中的sconde相同
②右外聯接查詢
例:select s.name,c.courseID,c.score
from strdents as s
right outer join score as c
on s.scode=c.strdentID
說明:在strdents表和score表中查詢滿足on條件的行,條件為strdents表中的sconde與score表的strdentID相同
三、增:有4種方法
1.使用插入單行數據:
語法: [into] <表名> [列名] values <列值>
例: into Strdents (姓名,性別,出生日期) values ('開心朋朋','男','1980/6/15')
注意:into可以省略;列名列值用逗號分開;列值用單引號因上;如果省略表名,將依次插入所有列
2.使用 select語句將現有表中的數據添加到已有的新表中
語法: into <已有的新表> <列名>
select <原表列名> from <原表名>
例: into tongxunlu ('姓名','地址','電子郵件')
select name,address,email
from Strdents
注意:into不可省略;查詢得到的數據個數、順序、數據類型等,必須與插入的項保持一致
3.使用select into語句將現有表中的數據添加到新建表中
語法:select <新建表列名> into <新建表名> from <源表名>例:select name,address,email into tongxunlu from strdents
注意:新表是在執行查詢語句的時候創建的,不能夠預先存在
在新表中插入標識列(關鍵字『identity』):
語法:select identity (數據類型,標識種子,標識增長量) AS 列名
into 新表 from 原表名
例:select identity(int,1,1) as 標識列,dengluid,password into tongxunlu from Struents
注意:關鍵字『identity』
4.使用union關鍵字合並數據進行插入多行
語法: <表名> <列名> select <列值> tnion select <列值>
例: Students (姓名,性別,出生日期)
select '開心朋朋','男','1980/6/15' union(union表示下一行)
select '藍色小明','男','19**/**/**'
注意:插入的列值必須和插入的列名個數、順序、數據類型一致
篇三:SQL常用增刪改查語句
SQLSQL常用增刪改查語句
作者:hiker
一. Insert 插入語句
1. Insert into 表名(列名) values (對應列名值)//插入一行.
2. Insert into 新表名(列名)
Select (列名) 舊表名
3. Select 舊表名.欄位…
Into 新表名 from 舊表名
4. Select identity ( 數據類型,標識種子,標識增長量) as 列名
Into新表名
From 舊表名
5. Insert 表名(列名)
Select (對應列名值) union
Select (對應列名值) union
Select (對應列名值)
二. Update 更新語句
1. Update 表名 set 列名=』更新值』 where 更新條件
三. 刪除語句
1. from 表名 where 刪除條件
2. truncate table 表名 //刪除表中所有行
四. select 基本查詢語句
1. select 列名 from 表名 where 查詢條件
order by 排序的列名asc或desc升/降
2. select 列名 as 別名 from 表名 where 查詢條件
3. select 列名 from 表名 where 列名 is null //查詢空值
4. select 列名 , 『常量值』 as 別名 from 表名//查詢時定義輸出一列常量值
5. select top 5 列名 from 表名 //查詢前5行
6. select top 5 percent 列名 from 表名 //查詢前百分之5的數據行
五.
1.
2.
3.
4. select 函數查詢語句 selectLEN(Class_Name)fromClass //查詢class_Name字元串長度 selectupper(Class_Name)fromClass //查詢class_Name並轉換為大寫 ltrim和rtrim //清除字元串左右空格 selectREPLACE(card_No,'0','9')fromCardRecord//修改列中字元串中的字元 列名字元串中0修改為9
5. selectSTUFF(Card_No,2,3,'8888')fromCardRecord
列名字元串中第2個開始刪除3個字元,再從第二個開始插入8888字元串
6. selectGETDATE()//顯示系統日期
六.
1.
2.
3.
4.
5. select 高級查詢語句 select * from 表名 where列名 like 『 %s%』 //模糊查詢 select * from 表名 where 列名 between 60 and 80 //范圍查詢 select * from 表名 where 列名 in (『列舉』,』』,』』) //在列舉范圍內查詢 selectSUM(Score_Num)fromscores //查詢分數總和 avg max min count //查詢平均分/最大數/最小數/行數
selectcourse_Id,SUM(Score_Num)fromscores
groupbyCourse_Id//分組查詢
havingCourse_Id='jsj001'//分組子句篩選
七. Select 多表連接查詢語句
1.selects.stu_Nameas'姓名',c.Course_nameas'科目',sc.Score_Num
fromStudentsass
innerjoinScoresasscon(sc.Stu_Id=s.Stu_ID)
innerjoinCoursesascon(sc.Course_Id=c.Course_Id)
orderbys.Stu_Namedesc //三表內聯查詢
2.selects.stu_Nameas'姓名',c.Course_nameas'科目',sc.Score_Num
fromStudentsass
leftouterjoinScoresasscon(sc.Stu_Id=s.Stu_ID)
leftouterjoinCoursesascon(sc.Course_Id=c.Course_Id)
//三表左外聯查詢,以stu表為主,其它表為從。
3.selects.stu_Nameas'姓名',c.Course_nameas'科目',sc.Score_Num
fromCoursesasc
rightouterjoinScoresasscon(sc.Course_Id=c.Course_Id)
rightouterjoinStudentsasson(sc.Stu_Id=s.Stu_ID)
//三表右外聯查詢,以stu右表為主,其它表為從。
八. Create 創建資料庫語句
1. create database 資料庫名
on[primary]
(
<數據文件參數>[,…n] [<文件參數>]
)
[log on]
(
{<日誌文件參數> […n]}
)
文件參數:
Name=邏輯文件名,filename=物理文件名,size=大小,maxsize=最大容量,
Filegrowth=增長
文件組參數:
Filegroup 文件組名<文件參數>
例:
usemaster
go
ifexists(select*fromsysdatabaseswherename='abc')
dropdatabaseabc
createdatabaseabc
onprimary
(
name='abc',
filename='d:abc.mdf',
size=5,
maxsize=50,
filegrowth=10%
)
logon
(
name='abc_log',
filename='d:abc_log.ldf',
size=2,
maxsize=20,
filegrowth=1
)
2. use 資料庫名
go
create table 表名
(
欄位數據類型列的特徵
)
Go
例:
usedb_myschool
go
ifexists(select*fromsysobjectswherename='test1')
droptabletest1
createtabletest1
(
Idintnotnull,
SNamenvar50)notnull,
Telintnotnull
)
go
3.使用SQL語句創建和刪除約束
alter table表名
Add constraint 約束名約束類型描述說明
altertabledbo.testaddconstraintPK_IDprimarykey (ID)
主鍵:primary keyPK_ 唯一:uniqueUQ_ 檢查:check CK_ 默認:defaultDF_外鍵:foreign keyFK_
1.execsp_addlogin'abc','abc'//添加SQL用戶名
usedb_myqq
go
execsp_grantdbaccess'abc'//添加用戶名到資料庫中
3. 授權語句
Grant 許可權 on 表名 to 資料庫用戶名 九. 登錄驗證語句
十. SQL編程語句
局部變數/全局變數
1.以@標記符作前綴
Declare @name var8)//聲明
Set @name = value
Select @name=value//賦值
2.以@@標記符作前綴
@@error //最後一個T-SQL錯誤的錯誤號
@@identity //最後一次插入的標識值
@@language//當前使用的語言的名稱
@@max_connections //可以創建的同時連接的最大數目
@@rowcount //受上一個SQL語句影響的行數
@@servername//本地伺服器的名稱
@@servicename //該計算機上的SQL服務的名稱
@@timeticks //當前計算機上每刻度的微秒數
@@transcount //當前連接打開的事務數
@@version //SQL Server的版本信息
4. 輸出
print'SQL服務名:'+@@servicename
select@@SERVICENAMEas'SQL服務名'
5. 邏輯控制項語句
declare@avgfloat
select@avg=avg(Score_Num)fromScoreswhereStu_Id='sc0002'
print'平均分為'+convert(var8),@avg)+'分'
if(@avg>90)
begin
print'最高分'
selectMAX(Score_Num)fromScores
end
else
begin
print'最低分'
selectMIN(Score_Num)fromScores
6. while 循環語句
declare@nint
while(1=1)
begin
select@n=COUNT(*)fromScoreswhereScore_Num<60
if(@n>0)
updateScoressetScore_Num+=2 whereScore_Num<60
else
break
end
print'加分後的成績'
select*fromScores
7. Case多分支語句
selectStu_id,score=case
whenScore_Num>90 then'A'
whenScore_Numbetween 80 and 89 then'B'
whenScore_Numbetween 60 and 79 then'C'
else'D'
end
fromScores
十一.高級查詢
1. where子查詢
2. in 和 not in 子查詢
3. if exists (子查詢)
;『肆』 SQL何時用左聯查詢,何時用右聯查詢
左臉和右聯都屬於外聯,用於兩個表的連接操作,在前說明的是左表,在後說明的是右表。
如果需要左表所有記錄,就稱為左連, LEFT OUTER JOIN
如果需要右表所有記錄,就稱為右聯,RIGHT OUTER JOIN
SELECT ...欄位... FROM 左表 LEFT/RIGHT OUTER JOIN 右表 WHERE 連接欄位
『伍』 在SQL中 如何正確使用各種聯接查詢
SELECT--SQL語法
從一個或多個表中檢索數據。SELECT SQL 命令是與其它 Vfp一樣的內置的 Vfp命令。當你使用 SELECT 來生成查詢時, Vfp翻譯查詢並從表中獲取指定數據。你可以從以下地方創建 SELECT 查詢:
「命令」窗口中
帶有其它任何 Vfp命令的 Vfp程序中
查詢設計器中
SELECT [ALL | DISTINCT] [TOP nExpr [PERCENT]] [Alias.] Select_Item
[[AS] Column_Name] [, [Alias.] Select_Item [[AS] Column_Name] ...]
FROM [FORCE] [DatabaseName!] Table [[AS] Local_Alias]
[ [INNER | LEFT [OUTER] | RIGHT [OUTER] | FULL [OUTER] JOIN DatabaseName!]
Table [[AS] Local_Alias] [ON JoinCondition ...]
[[INTO Destination] | [TO FILE FileName [ADDITIVE] | TO PRINTER [PROMPT] | TO SCREEN]]
[PREFERENCE PreferenceName] [NOCONSOLE] [PLAIN] [NOWAIT]
[WHERE JoinCondition [AND JoinCondition ...] [AND | OR FilterCondition [AND | OR FilterCondition ...]]]
[Group By GroupColumn [, GroupColumn ...]] [HAVING FilterCondition] [UNION [ALL] SELECTCommand]
[Order By Order_Item [ASC | DESC] [, Order_Item [ASC | DESC] ...]]
參數
SELECT
在 SELECT 子句中指定在查詢結果中包含的欄位、常量和表達式。
ALL
查詢結果中包含所有行 ( 包括重復值 )。ALL 是默認設置。
DISTINCT
在查詢結果中剔除重復的行。每一個 SELECT 子句只能使用一次 DISTINCT。
TOP nExpr [PERCENT]
在符合查詢條件的所有記錄中,選取指定數量或百分比的記錄。TOP 子句必須與 ORDER BY 子句同時使用。ORDER BY 子句指定查詢結果中包含的列上由Top字句決定的行數, TOP 子句根據此排序選定最開始的 nExpr個或 nExpr% 的記錄。
您可以指定選取 1 到 32767 個記錄。使用 ORDER BY 子句指定的欄位進行排序,會產生並列的情況,比如,可能有多個記錄,它們在選定的欄位上相同;所以,如果您指定 nExpr 為 10,在查詢結果中可能多於 10 個記錄,因為可能有幾個記錄位置並列。
如果包含 PERCENT 關鍵字指定查詢結果中的記錄數,得到記錄數的可能是小數,這時進行取整。包含 PERCENT 關鍵字時,nExpr 的范圍是 0.01 到 99.99。
[Alias.] Select_Item
限定匹配項的名稱。Select_Item 指定的每一項在查詢結果中都生成一列。一個項可以是以下一個
FROM 子句所包含的表中的欄位名稱。
一個常量,查詢結果中每一行都出現這個常量值。
一個表達式,可以是用戶自定義函數名。
關於使用用戶定義函數的詳細信息, 參見注釋節中的帶用戶定義函數的 SELECT。
你用 Select_Item 指定的各項生成一個查詢結果列。
如果兩個或更多的項具有相同的名稱, 在項名前包含表別名和一個句點來避免列重復。
[AS] Column_Name
為查詢輸出中的列指定顯示名。Column_Name 可以是表達式但不能包含不允許的字元, 如, 欄位名中的空格。
當 Select_Item 是一個表達式或包含一個欄位函數而且你想給該列一個有意義的名字時該選項是有用的。
FROM [FORCE] DatabaseName!
列出所有從中檢索數據的表。
FORCE 指定連接表時按它們出現在 FROM 子句中的順序。如果省略 FORCE, Vfp會試圖對查詢進行優化。但是, 使用 FORCE 子句,避免了優化過程,可能加快查詢執行的速度。
當包含表的資料庫不是當前資料庫時,DatabaseName! 指定這個資料庫的名稱。如果資料庫不是當前資料庫,就必須指定包含表的資料庫名稱。應在資料庫名稱之後表名之前加上感嘆號(!)分隔符。
[[AS] Local_Alias]
為 Table 中的表指定一個臨時名稱。如果指定了本地別名,那麼在整個SELECT 語句中必須都用這個別名代替表名。本地別名不影響 Visual FoxPro環境。INNER JOIN 只有在其他表中包含對應記錄(一個或多個)的記錄才出現在查詢結果中。
INNER JOIN 只有在其他表中包含對應記錄(一個或多個)的記錄才出現在查詢結果中。
LEFT [OUTER] JOIN 在查詢結果中包含:JOIN 左側表中的所有記錄,以及JOIN 右側表中匹配的記錄。OUTER 關鍵字可被省略;包含 OUTER 強調這是一個外連接 (outer join)。
RIGHT [OUTER] JOIN 在查詢結果中包含:JOIN 右側表中的所有記錄,以及 JOIN 左側表中匹配的記錄。OUTER 關鍵字可被省略;包含 OUTER 強調這是一個外連接接 (outer join)。
FULL [OUTER] JOIN 在查詢結果中包含:JOIN 兩側所有的匹配記錄,和不匹配的記錄;包含 OUTER 強調這是一個外連接 (outer join)。
關於連接的詳細信息, 參見備注段中的 Joins。
ON JoinCondition 指定連接條件。
INTO Destination
指定在何處保存查詢結果。Destination 可以是下列子句之一:
ARRAY ArrayName ,將查詢結果保存到變數數組中。
如果查詢結果中不包含任何記錄,則不創建這個數組。
CURSOR CursorName [NOFILTER | READWRITE] 將查詢結果保存到臨時表中。
要創建一個查用於子查詢中的游標, 用 NOFILTER。關於 NOFILTER 的詳細信息, 參見備注節。
要指定游標是臨時的和可修改的, 使用 READWRITE。如果源表或表使用 autoincrementing, 該設置不會被 READWRITE 游標繼承。
DBF | TABLE TableName [DATABASE DatabaseName [NAME LongTableName]] 保存查詢結果到一個表中。
包含 DATABASE DatabaseName 以指定添加了表的資料庫。
包含 NAME LongTableName 可以為該表命一個最多可包括 128 個字元的並且可以在資料庫中代替短名字的長名。
如果沒有包括 INTO 子句, 查詢結果顯示在一個「瀏覽」窗口中。也可以用 TO FILE 子句來定向查詢結果到列印機或一個文件。
TO FILE FileName [ADDITIVE] | TO PRINTER [PROMPT] | TO SCREEN
定向查詢結果到列印機或一個文件。
ADDITIVE 添加查詢輸出到 TO FILE FileName 中指定的已存在的文本文件內容中。
TO PRINTER 定向查詢輸出到一個列印機。在列印開始之前,使用可選的 PROMPT 子句顯示一個對話框。您可以根據當前安裝的列印機驅動程序調整列印機的設置。將 PROMPT 子句放置在緊跟 TO PRINTER 之後。
TO SCREEN 使查詢結果定向輸出到 Vfp主窗口或活動的用戶自定義窗口中。
PREFERENCE PreferenceName
如果查詢結果送往瀏覽窗口,就可以使用 PREFERENCE 保存瀏覽窗口的屬性和選項以備後用。關於 PREFERENCE 功能的詳細信息, 參見備注節。
NOCONSOLE
不顯示送到文件、列印機或 Vfp主窗口的查詢結果。
PLAIN
防止列標題出現在顯示的查詢結果中。不管有無 TO 子句都可使用 PLAIN子句。如果 SELECT 語句中包括 INTO 子句,則忽略 PLAIN 子句。
NOWAIT
打開瀏覽窗口並將查詢結果輸出到這個窗口後繼續程序的執行。程序並不等待關閉瀏覽窗口,而是立即執行緊接在 SELECT 語句後面的程序行。關於如何使用 NOWAIT 的說明, 參見備注節。
WHERE JoinCondition
指定 Vfp的查詢結果中只包括符合指定條件的記錄。JoinCondition 指定位於 FROM 子句中的欄位連接表。關於指定連接條件的詳細信息, 參見備注節。
WHERE 支持 JoinCondition 的 ESCAPE 操作符, 讓你可以執行包含有百分號 (%) 和下劃線 (_) 通配符的 SELECT SQL 命令查詢。ESCAPE 允許你指定一個按原字樣處理的 SELECT SQL 命令通配符。在 ESCAPE 子句中, 一旦一個字元被放到通配符字元之前,就表示這個通配符被看作一個文字字元。
FilterCondition
指定將包含在查詢結果中記錄必須符合的條件。使用 AND 或 OR 操作符,您可以包含隨意數目的過濾條件。您還可以使用 NOT 操作符將邏輯表達式的值取反,或使用 EMPTY() 函數以檢查空欄位。
SELECT SQL 命令在篩選條件中支持 "<field> IS / IS NOT NULL"。要學習如何使用 FilterCondition。
Group By GroupColumn [, GroupColumn ...]
按列的值對查詢結果的行進行分組。GroupColumn 可以是常規的表欄位名,也可以是一個包含 SQL 欄位函數的欄位名,還可以是一個數值表達式,指定查詢結果表中的列位置(最左邊的列編號為 1 )。
HAVING FilterCondition
指定包括在查詢結果中的組必須滿足的篩選條件。HAVING 應該同 GROUP BY一起使用。它能包含數量不限的篩選條件,篩選條件用 AND 或 OR 連接,還可以使用 NOT 來對邏輯表達式求反。可以在 HAVING 子句中使用本地別名和欄位函數。 關於你可以使用的欄位函數的詳細信息, 參見備注節。FilterCondition 不能包含子查詢。
可以使用帶 HAVING 子句的 Group By。使用 HAVING 子句的命令如果沒有使用 GROUP BY 子句,則它的作用與WHERE 子句相同。
如果 HAVING 子句不包含欄位函數的話,使用 WHERE 子句可以獲得較快的速度。
HAVING 子句應該出現在 INTO 子句前否則產生錯誤。
[UNION [ALL] SELECTCommand]
把一個 SELECT 語句的最後查詢結果同另一個 SELECT 語句最後查詢結果組合起來。默認情況下,UNION 檢查組合的結果並排除重復的行。
要組合多個UNION 子句,可使用括弧。可以用 UNION 子句模擬一個外部聯接。
ALL 防止 UNION 刪除組合結果中重復的行。
當一個列是備注或通用型時, 不允許連接不同類型的列。
在 Vfp8.0 以前的版本中, 當在兩個不同類型的欄位上執行 UNION 操作時你需要執行明確的轉換。
Vfp現在對支持它的數據類型支持隱含數據類型轉換。關於隱含數據類型轉換和數據類型優先, UNION 子句允許的規則, 以及其它信息的詳細內容, 參見備注節中的數據類型轉換和優先。
Order By Order_Item [ASC | DESC]
根據列的數據對查詢結果進行排序。每個 Order_Item 都必須對應查詢結果中的一列。它可以是下列之一:
FROM 子句中表的欄位,同時也是 SELECT 主句(不在子查詢中)的一個選擇項。
一個數值表達式,表示查詢結果中列的位置(最左邊列編號為 1 )。
ASC 指定查詢結果根據排序項以升序排列。它是 ORDER BY 的默認選項。
DESC 指定查詢結果以降序排列。
備注
在使用 FROM 子句時如果沒有打開表, Vfp顯示「打開」對話框讓你指定文件位置。一但打開後, 表在查詢完成後仍然保持打開。
當在 Destination 參數中使用 CURSOR 子句時, 如果你指定了一個打開的表的名字, Vfp產生一條錯誤信息。在 SELECT 執行後, 臨時游標保持打開並是活動的和只讀的除非你指定了 READWRITE 選項。當你關閉該臨時游標時, 它被刪除。游標可以指定 SORTWORK 而成為存在於驅動器或卷上的臨時文件。
當在 Destination 參數中使用 CURSOR 子句時, 你現在可以使用 NOFILTER 來創建一個可用於後來的查詢的游標。在早期版本的 Vfp中, 你需要包括一個額外的常數或表達式作為篩選。例如, 添加一個邏輯 true 作為篩選表達式來創建一個可用於後來的查詢的查詢:
SELECT *, .T. FROM customers INTO CURSOR myquery
但是, 包括 NOFILTER 會降低查詢性能因為要在磁碟上創建一個臨時表。臨時表在游標關閉時從磁碟上刪除。
當在 Destination 參數中使用 DBF | TABLE 子句時, 如果你指定了一個已經打開的表, 而且 SET SAFETY 是設置為 OFF, Vfp不警告地復寫該表。如果你沒有指定一個擴展名, Vfp給表一個 .dbf 擴展名。在 SELECT 執行後表保持打開並且是活動的。
如果你在相同查詢中包括 INTO 和 TO 子句, Vfp忽略 TO 子句。如果你包括 TO 子句但沒有包括 INTO 子句, 你可以定向查詢結果到一個名為 FileName 的 ASCII 文本文件, 到列印機, 或到 Vfp主窗口。
PREFERENCE 把特徵, 屬性或參數選項長期保存在 FoxUser.dbf 資源文件中。Preferences 可以在任何時候獲取。第一次執行有 PREFERENCE Preference Name 的 SELECT 命令時創建參數選項。以後執行有相同參數選項名的 SELECT 命令時便將瀏覽窗口恢復到原來的參數選項狀態。當瀏覽窗口關閉時,更新參數選項。如果您按下 CTRL+Q+W 鍵退出「瀏覽」窗口,您對「瀏覽」窗口所做的更改不會保存到資源文件中。
SELECT 命令中包括 TO SCREEN 可以把查詢結果定向輸出到 Vfp主窗口或用戶自定義窗口。如果顯示時 Vfp主窗口或用戶自定義窗口中寫滿了一屏,就暫停輸出。按任意鍵可以查看查詢結果後面的內容。但是,如果命令中包括了 NOWAIT 子句,顯示查詢結果時就不會暫停,等待按鍵,而是在 Vfp主窗口或用戶自定義窗口中連續滾過所有內容。如果命令中包含有 INTO 子句,忽略 NOWAIT 子句。
在一個 SQL 查詢的 WHERE 子句中包括 EVALUATE() 函數會返回不正確的數據。
如果包括一個以上的表在查詢中, 你應該在第一個以後為每一個表指定一個連接條件。連接條件可以包含篩選條件。
注意 每一個 SELECT 語句的最大連接數是 9.
必須用 AND 操作符來連接多個連接條件。各連接條件具有以下格式:
當你在串中使用 = 操作符時, 它的動作根據 SET ANSI 的設置會不同。當 SET ANSI 設置為 OFF 時, Vfp只比較串到較短串結束。當 SET ANSI 設置為 ON 時, Vfp遵循 ANSI 標準的字元串比較。關於 Vfp如果執行字元串比較的額外信息, 參見 SET ANSI 和 SET EXACT。
下列欄位函數可以與選定項一起使用,選定項可以是一個欄位或包含欄位的表達式:
AVG(Select_Item), 計算列中數值的平均值。
COUNT(Select_Item), 計算列中選定項的數目。計算查詢輸出的行數。COUNT(*) 計算查詢輸出中的行數。
MIN(Select_Item), 確定列中 Select_Item 的最小值。
MAX(Select_Item), 確定列中 Select_Item 的最大值。
SUM(Select_Item), 計算列中數值的和。
欄位函數不能嵌套使用。
UNION 子句遵守下列規則:
不能使用 UNION 來組合子查詢。
兩個 SELECT 命令的查詢結果中的列數必須相同。
兩個 SELECT 查詢結果中的對應列必須有相同的數據類型和寬度。
只有最後的 SELECT 中可以包含 ORDER BY 子句,而且必須按編號指出所輸出的列。如果包含了一個 ORDER BY 子句,它將影響整個結果。
當你用 UNION 連接查詢中的兩個表時, 僅匹配連接欄位值的記錄會出現在查詢結果中。如果在父表中的記錄在子表中沒有相應的記錄, 父表中的記錄不會出現在查詢結果中。一個外部聯接允許你包括父表中的所有記錄到輸出結果中, 連同子表中的匹配記錄一起。要在 Vfp中創建一個外部聯接, 你需要要使用一個嵌套的 SELECT 命令
注意 確信在每一個分號前包括一個空格。否則, Vfp產生一個錯誤。
上例中, 在 UNION 子句前的部分的命令從兩個表中選擇具有匹配值的記錄。不包括沒有相關的發票的客戶公司。命令中 UNION 子句後的部分選擇客戶表中的在訂單表中無匹配記錄的記錄。
關於第二部分的命令, 注意以下幾點:
包括在園括弧中的 SELECT 語句首先處理。該語句的結果是選擇訂單表中的所有客戶編號。
WHERE 子句找出 customer 表中的在 orders 表沒有相關記錄的所有客戶編號。由於第一節中的命令提供了所在 orders 表中有客戶編號的公司, Customer 表中的所有公司現在都包含在查詢結果中了。
因為在 UNION 中的表的結構必須相同, 有兩個佔位符在第二個 SELECT 語句中來代表第一個 SELECT 語句中的 orders.order_id 和 orders.emp_id。
注意 佔位符必須與它們所代表的欄位有相同類型。如果欄位是日期型, 佔位符應該是 。如果欄位是一個字元欄位, 佔位符應該是一個空串 ("")。
如果你沒有在 Order By 子句中指定排序, 查詢結果顯示為未排序。
當你發出 SET TALK ON 並執行 SELECT 時, Vfp顯示查詢使用的時間和結果中的記錄數。 _TALLY 包含了在查詢結果中的記錄數。
SET FILTER 設置的篩選條件對 SELECT 命令不起作用。
注意 下面部分提到的子查詢, 是指在 SELECT 命令中包含的 SELECT 命令。子查詢必須包括在園括弧中。在 SELECT 命令的 WHERE 子句中可以包含最多兩個平級的(非嵌套)的子查詢。子查詢中可以有多個連接條件 (join conditions)。
在你創建查詢輸出時, 列的命名遵循如下規則:
如果選擇項是具有唯一名稱的欄位,則用欄位名作為輸出列名。
如果多個選擇項具有相同名稱。例如,如果名為 Customer 的表有一個STREET 欄位,而名為 Employees 的表也有一個 STREET 欄位,則輸出列命名為 Extension_A 和 Extension_B (STREET_A 和 STREET_B)。如果選擇項名稱有 10 字元長,可以將名稱截短後再加下劃線和字母。例如,DEPARTMENT 變為 DEPARTME_A。
如果選擇項是表達式,它的輸出列命名為 EXP_A。其他表達式分別命名為EXP_B、EXP_C,依此類推。
如果選擇項包含諸如 COUNT() 這樣的欄位函數,則輸出列命名為CNT_A。如果另一個選擇項包含 SUM(),它的輸出列命名為 SUM_B。
用戶定義函數和 在 SELECT 子句中使用用戶自定義函數有明顯優點,但使用時應考慮以下限制:
SELECT 子句的運行速度會受用戶自定義函數執行速度的影響。因此,如果使用戶自定義函數的操作量很大,則這些函數的功能最好調用 C 語言或匯編語言編寫的 API 或用戶自定義函數來完成。
在 SELECT 激活的用戶自定義函數中,很難預測 Vfp輸入/輸出(I/O)和表的環境。一般來說,不知道選擇的工作區是哪一個,不知道當前表的名稱,甚至不知道正在處理的欄位名。這些變數的值完全取決於用戶自定義函數在優化過程的什麼地方激活。
在 SELECT 子句調用的用戶自定義函數中修改 VfpI/O 或表的環境是很不安全的。一般來說,這樣做的結果難以預料。
從 SELECT 將值傳遞給用戶自定函數唯一可靠的方法,是激活用戶自定義函數時以參數的形式傳遞。
經過實踐,有可能發現某種被認為是違法的操作在某種 FoxPro 版本中運行正確,但這並不保證它在以後的版本中也能正確運行。
拋開這些限制不說,用戶自定義函數在 SELECT 語句中還是可接受的。但不要忘記使用 SELECT 可能要降低性能。要學習如何在 SELECT 中使用用戶定義函數, 參見示例節。
連接 Vfp支持 ANSI SQL '92 連接 (Join) 語法,通過比較兩個或多個表中的欄位,將它們的記錄連接到一起,生成查詢。例如,內部連接 (inner join) 是將兩個表中連接欄位 (joined field) 值相同的記錄選取到查詢中。Vfp支持嵌套連接(nested joins)
由於 SQL 是派生於數學集合理論, 各表可以代表一個環。指定連接條件的 ON 子句確定交接點, 它代表匹配的行集合。對於一個內部聯接, 交接發生在兩個環的內部或 "inner" 部分。一個外聯接不僅僅包括這些表內部的交叉區域匹配的行, 也包括環的外面的左或右部的交集的行。
『陸』 SQL內連接與外連接的區別
SQL內連接與外連接的共有3點不同:
1、兩者的分類不同:內連接分為相等連接和自然連接兩種連接方式;而外連接分為左外連接、右外連接和全外連接三種連接方式(左外連接即LEFT OUTER JOIN;右外連接即RIGHT OUTER JOIN)。
2、兩者所連接的對象表不同:內連接進行連接的兩個表是對應的相匹配的欄位完全相同的。左外連接中進行連接的兩個表會返回左邊表中的所有的行和右邊表中與之相匹配的列值,沒有相匹配的用空值代替。右外連接中進行連接的兩個表會返回右邊表中的所有的行和左邊表中與之相匹配的列值,沒有相匹配的用空值代替。
3、兩者的作用范圍不同:內連接的連接發生在一張基表內,而外連接的連接發生在兩張表之間。
註:內連接(典型的連接運算,使用像 = 或 <> 之類的比較運算符)。包括相等連接和自然連接。內連接使用比較運算符根據每個表共有的列的值匹配兩個表中的行。例如,檢索 students和courses表中學生標識號相同的所有行。
『柒』 vb中SQL多表聯合查詢
select a.工程編號,a.程名稱,a.施工人員編號,b.員工姓名 from 工程詳情 a left join
((select 員工編敗盯號,員工姓名 from 公司員工) union (select 外聯編號 as 員工編號,工人姓名 as 員工姓名襲枯絕 from 外聯工拍姿人)) emp b on a.施工人員編號=b.員工編號
『捌』 SQL Server中, 內聯接查詢和外聯接查詢的區別是甚麼.
資料庫中有兩種聯接:內連接,外連接。
一、其中內連接就是一般的相等連接。
如:select * from a, b where a.id = b.id
二、外連接
對於外連接,可以分為左外連,右外連,全外連。詳細介紹如下:
1. LEFT OUTER JOIN:左外關聯
SELECT e.last_name, e.department_id, d.department_name
FROM employees e
LEFT OUTER JOIN departments d
ON (e.department_id = d.department_id);
結果為:所有員工及對應部門的記錄,包括沒有對應部門編號department_id的員工記錄。
2. RIGHT OUTER JOIN:右外關聯
SELECT e.last_name, e.department_id, d.department_name
FROM employees e
RIGHT OUTER JOIN departments d
ON (e.department_id = d.department_id);
結果為:所有員工及對應部門的記錄,包括沒有任何員工的部門記錄。
3. FULL OUTER JOIN:全外關聯
SELECT e.last_name, e.department_id, d.department_name
FROM employees e
FULL OUTER JOIN departments d
ON (e.department_id = d.department_id);
結果為:所有員工及對應部門的記錄,包括沒有對應部門編號department_id的員工記錄和沒有任何員工的部門記錄。
你可以自己建兩張表,到庫里看看到底是怎樣的數據,這樣你就會很容易理解了!
『玖』 sql資料庫多表聯查問題
select tableid,name,name
from 表1
as 表1
left outer join 表2 as 表2.1 on AName(表1裡面的橘數尺一個ID)=id(表2.1的ID)
left outer join 表2 as 表圓高畢跡2.2 on BName(表1裡面的另一個ID)=id(表2.2的ID)
這樣試試