函數的定義
函數是指一段可以直接被另一段程式或代碼引用的程式或代碼。
存儲過程和函數的差別?
存儲過程是使用者定義的一系列SQL語句的集合,而函數通常是資料庫已定義的方法,
具體差別如下:
1.對于存儲過程來說可以傳回參數,而函數隻能傳回值或者表對象
2.函數必須有傳回值,存儲過程可有可無
3.存儲過程一般是作為一個獨立的部分來執行,而函數可以作為查詢語句的一部分來調用
SQL函數的基本類型和種類
在 SQL 中,基本的函數類型和種類有若幹種。
函數的基本類型:
Aggregate 函數(合計函數)
Scalar 函數
下面以表格形式向大家介紹Aggregate 函數和 Scalar 函數。
**Aggregate函數的操作面向一系列的值,并傳回一個單一的值。**如果在 SELECT 語句的項目清單中的衆多其它表達式中使用 SELECT 語句,則這個 SELECT 必須使用 GROUP BY 語句!
函數 | 描述 |
---|---|
AVG(column) | 傳回某列的平均值 |
BINARY_CHECKSUM | |
CHECKSUM | |
CHECKSUM_AGG | |
COUNT(column) | 傳回某列的行數(不包括NULL值) |
COUNT(*) | 傳回被選行數 |
COUNT(DISTINCT column) | 傳回相異結果的數目 |
FIRST(column) | 傳回在指定的域中第一個記錄的值(SQLServer2000 不支援) |
LAST(column) | 傳回在指定的域中最後一個記錄的值(SQLServer2000 不支援) |
MAX(column) | 傳回某列的最高值 |
MIN(column) | 傳回某列的最低值 |
STDEV(column) | |
STDEVP(column) | |
SUM(column) | 傳回某列的總和 |
VAR(column) | |
VARP(column) |
Scalar 函數的操作面向某個單一的值,并傳回基于輸入值的一個單一的值。
函數 | 描述 |
---|---|
UCASE© | 将某個域轉換為大寫 |
LCASE© | 将某個域轉換為小寫 |
MID(c,start[,end]) | 從某個文本域提取字元 |
LEN© | 傳回某個文本域的長度 |
INSTR(c,char) | 傳回在某個文本域中指定字元的數值位置 |
LEFT(c,number_of_char) | 傳回某個被請求的文本域的左側部分 |
RIGHT(c,number_of_char) | 傳回某個被請求的文本域的右側部分 |
ROUND(c,decimals) | 對某個數值域進行指定小數位數的四舍五入 |
MOD(x,y) | 傳回除法操作的餘數 |
NOW() | 傳回目前的系統日期 |
FORMAT(c,format) | 改變某個域的顯示方式 |
DATEDIFF(d,date1,date2) | 用于執行日期計算 |
函數的種類:
内建函數(SQL自帶的函數,如Aggregate函數和Scalar 函數)
自定義函數(使用者自定義的函數)
自定義函數的建立和使用:
我們以一張表為例來示範自定義函數的使用:
字段名 | 類型 |
---|---|
ID | int |
Name | nvarchar(50) |
Sex | bit |
代碼展示:
create function ConvertToSex(
@sex bit --函數名為ConvertToSex,參數sex
)
returns varchar(4)
as
begin
declare @rSex varchar(4)
if(@sex=1)
select @rSex='男'
else
select @rSex='女'
return @rSex
end
``
調用函數:
```sql
select *, [dbo].[ConvertToSex](sex) from [dbo].[Customers]