您正在看的SQLserver教程是:全面接觸SQL語法(二)。
BETWEEN...AND 運算符
決定某一人數值是否介於特定的范圍之內,此運算符只可以用在SQL的語句中。
expr[Not]BETWEEN value1 AND value2
expr
指定要加以計算的字段與表達式的組合。
value1,value2
所指明的數值范圍。
例如:
若是要從職員表格查詢出所有年齡介於25-30歲的員工,可以利用下面的程序來做。
SELECT 姓名,年齡 BETWEEN 25 AND 30
FROM 職員表格;
LIKE 操作數
用來將一字符串與另一特定字符串樣式(pattern)比較,並將符合該字符串樣式的記錄過濾出來。
expression LIKE "pattern"
expression
使用在WHERE條件子句,SQL表達式。
pattern
用以比較的字符串樣式。
例如:
若是你要查詢出所有以“李”為首的姓氏,可以利用下面的式子。
Like "李*"
LIKE操作數的多種范例:
1、多個字符:
(1)"a*a"
可篩選:"aa","aBa","aBBBa",不能篩選:"aBC"
(2)"*ab*"
可篩選:"abc","AABB","Xab",不能篩選:"aZb","bac"
2、特殊字符:
"a“*”a"
可篩選:"a*a",不能篩選:"aaa"
3、單一字符:
"a?a"
可篩選:"aaa","a3a","aBa",不能篩選:"aBBBa"
4、單一數字:
"a#a"
可篩選:"a0a","a1a","a2a",不能篩選:"aaa","a10a"
5、字符范圍:
"“a-z”"
可篩選:"f","p","j",不能篩選:"2","&"
6、指定字符以外部范圍:
"“!a-z”"
7、指定非數字:
"“!0-9”"
可篩選:"A","a","&","~",不能篩選:"0","1","9"
8、組合式結構:
"a“!b-m”#"
可篩選:"An9","az0","a99",不能篩選:"abc","aj0"
SQL數字函數
1、AVG:算數平均數
AVG(expr)
expr
字段名稱或表達式。
例如:
若要計算職員身高超過165厘米的職員平均身高,可以利用下面的SQL語句來完成。
SELECT Avg(身高)
AS 平均身高
FROM 職員表格 WHERE 身高> 165;
2、COUNT:計算記錄條數
COUNT(expr)
expr
字段名稱或表達式。
例如:
若是要統計出業務部門的職員人數,並查詢出職員的姓名,可以利用下面的程序。
SELECT Count(姓名) AS 職員姓名
FROM 職員表格
WHERE 部門名稱=’業務部’;
3、FIRST與LAST:返回某字段的第一條數據與最後一條數據。
FIRST(expr)
LAST(expr)
expr
字段名稱或表達式。
例如:
若是要找出貨品數量字段的第一條數據與貨品價格字段的最後一條數據時,可以利用下面的查詢方式。
SELECT FIRST(貨品數量),LAST(貨品價格)
FROM 訂單表格
4、MAX,與MIN:返回某字段的最大值與最小值。
用法同FIRST與LAST。
5、SUM:返回某特定字段或是運算的總和數值。
SUM(expr)
expr
字段名稱或表達式。
例如:
要計算出貨品總價,可使用下面的程序。
SELECT
Sum(單位價格*貨品數量)
AS 貨品總價 FROM 訂單表格
多層SQL查詢
顧名思義,多層的SQL查詢的便在於:“在一個SQL語句中可以包含另一個SQL查詢語句,形成內部嵌套的查詢類型。”
comparison[ANY|ALL|SOME](sqlstatement)
expression[NOT]IN (sqlstatement)
[NOT]EXISTS(sqlstatement)
comparison
將表達式與內層查詢的結果比較的操作。
如果被參考的字段是參考表格中的主鍵值,你也可以省略這個條件子句。
例如:
當我們要建立一個新的職員數據表格,表格包含姓名、部門名稱與生日三個字段,且由這三個字段建立一個唯一的索引時,可以使用下面這段SQL的語句。
CREATE TABLE 職員數據表格
(姓名 TEST,部門名稱 TEST,生日 DATETIME,CONSTRAINT 職員數據表格限制 UNIQUE(姓名,部門名稱,生日));
以上是SQL中,與數據庫表格建立相關的命令,你可以利用這些命令,通過SQL的語句,將數據庫表格完整的建立出來,接下來的章節,將針對數據庫建立之後的維護與增刪所要使用的SQL語句作一介紹。
例如:
你可以利用下面的SQL語句,將訂單數量超過1000的顧客表格記錄,與新客戶表格作UNION的操作。
TABLE 新客戶表格 UNION ALL
SELECT *
FROM 顧客表格
WHERE 訂單數量> 1000;
ALTER語句
在一個表格被建立之後,利用ALTER語句,我們可以去修改表格的字段設計。
ALTER TABLE table
{ADD {COLUMN fIEld type[(size)][CONSTRAINT index]
|CONSTRAINT multifIEldindex}
|DROP {COLUMN fIEld|CONSTRAINT indexname}}
table
欲被ALTER的表格名稱。
fIEld
要被增加或刪除的字段名稱。
type
字段數據類型。
size
字段大小。
index
對此字段的索引。
例如:
在職員表格中新建一個“薪水”的字段。
ALTER TABLE 職員表格
ADD COLUMN 薪水 CURRENCY;
例如:
在職員表格中刪除一個“薪水”的字段。
ALTER TABLE 職員表格 DROP COLUMN 薪水;
DROP語句
針對所指定的表格或字段加以刪除,或是把索引刪除。
DROP {TABLE table|INDEX index ON table}
table
欲刪除之表格或索引依附之表格名稱。
index
欲從表格中刪除的索引名稱。
例如:
從職員表格中,刪除編號索引。
DROP INDEX MyIndex ON Employees;
例如:
從數據庫中,刪除整個表格。
DROP TABLE 職員表格;
INSERT INTO語句
新建一條數據到表格當中。
多條記錄新建查詢:
INSERT INTO target [IN externaldatabase][(field1[,fIEld2[,...]])]
SELECT [source.]field1[,fIEld2[,...]
FROM tableexpression
單條記錄新建查詢:
INSERT INTO target[(field1[,fIEld2[,...]])]
VALUES(value1[,value2[,...])
target
新建記錄的表格名稱。
externaldatabase
外部數據庫的路徑,搭配IN條件子句使用。
source
若是記錄從其它表格中拷貝時,指明該表格的名稱。
field1,fIEld2
欲增加數據的字段名稱。
tableexpression
表格名稱或描述記錄是從哪一個表格中插入的表格名稱。配合INNER JOIN,LEFT JOIN,或 RIGHT JOIN 運算符一起使用。
value1,value2
欲插入表格中的數值。
例如:
在客戶數據表格中,從新的表格插入數據。
INSERT INTO 客戶數據表格
SELECT 新客戶數據表格.*
FROM 新客戶數據表格;
例如:
在職員表格中插入數據。
INSERT INTO 職員表格(姓名,生日,職稱)
VALUES("王榮","57/12/11","經理");
例如:
從訓練人員表格中,將職員雇用時間超過30天者,加入到正式職員表格中。
INSERT INTO 職員表格
SELECT 訓練人員表格.*
FROM 訓練人員表格
WHERE 雇用天數> 30;
UPDATE語句
建立一個UPDATE的查詢,通過條件的限制來修改特定的數據。
UPDATE table
SET newvalue
WHERE criteria;
table
欲修改數據的表格名稱。
newvalue
欲修改成的數值(將該項數值插入到特定的字段當中)。
criteria
查詢條件,用來決定要修改哪些記錄。
例如:
若是要把訂單表格中的訂單數量修改成1.1倍,運費為1.03倍,可利用下列之SQL語句來完成。