SQL Server數據庫練習——SQL函數

函數的定義

函數是指一段可以直接被另一段程序或代碼引用的程序或代碼。

存儲過程和函數的區別?

存儲過程是用戶定義的一系列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]

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章