SqlServer函式

umeric_expr) umeric_expr) ame(char_expr)

字元串函式

1 字元串函式

1.1 長度與分析用

datalength(Char_expr) 返回字元串包含字元數,但不包含後面的空格

substring(expression,start,length) 不多說了,取子串

right(char_expr,int_expr) 返回字元串右邊int_expr個字元

1.2 字元操作類

upper(char_expr) 轉為大寫

lower(char_expr) 轉為小寫

space(int_expr) 生成int_expr個空格

replicate(char_expr,int_expr)複製字元串int_expr次

reverse(char_expr) 反轉字元串

stuff(char_expr1,start,length,char_expr2) 將字元串char_expr1中的從

start開始的length個字元用char_expr2代替

ltrim(char_expr) rtrim(char_expr) 取掉空格

ascii(char) char(ascii) 兩函式對應,取ascii碼,根據ascii碼取字元

1.3 字元串查找

charindex(char_expr,expression) 返回char_expr的起始位置

patindex("%pattern%",expression) 返回指定模式的起始位置,否則為0

數學函式

trunc(45.923,1) 按指定精度截斷十進制數 結果:45.9 此為oracle函式

mod(1600,300) 求除法餘數 結果:100

abs(numeric_expr) 求絕對值

ceiling(numeric_expr) 取大於等於指定值的最小整數

avg(numeric_expr)取平均數

exp(float_expr) 取指數

floor(numeric_expr) 小於等於指定值得最大整數

pi() 3.1415926.........

power(numeric_expr,power) 返回power次方

rand([int_expr]) 隨機數產生器

round(numeric_expr,int_expr) 安int_expr規定的精度四捨五入

sign(int_expr) 根據正數,0,負數,,返回+1,0,-1

sqrt(float_expr) 平方根

日期時間函式

getdate() 返回日期

datename(datepart,date_expr) 返回名稱如 June

datepart(datepart,date_expr) 取日期一部份

datediff(datepart,date_expr1.dateexpr2) 日期差

dateadd(datepart,number,date_expr) 返回日期加上 number

上述函式中datepart的

寫法 取值和意義

yy 1753-9999 年份

qq 1-4 刻

mm 1-12 月

dy 1-366 日

dd 1-31 日

wk 1-54 周

dw 1-7 周幾

hh 0-23 小時

mi 0-59 分鐘

ss 0-59 秒

ms 0-999 毫秒

日期轉換

convert()

系統其他函式

suser_name() 用戶登錄名

user_name() 用戶在資料庫中的名字

user 用戶在資料庫中的名字

show_role() 對當前用戶起作用的規則

db_name() 資料庫名

object_name(obj_id) 資料庫對象名

col_name(obj_id,col_id) 列名

col_length(objname,colname) 列長度

valid_name(char_expr) 是否是有效標識符

類型轉換函式

convert (數據類型[(長度)],表達式[,樣式])

將一種數據類型的表達式顯式轉換為另一種數據類型的表達式;

長度:如果數據類型允許設定長度,可以設定長度,例如 varchar(10);

樣式:用於將日期類型數據轉換為字元數據類型的日期格式的樣式。

cast (表達式 AS 數據類型[(長度)])

將一種數據類型的表達式顯式轉換為另一種數據類型的表達式。

例如:select cast(123 as nvarchar) 返回123

select N'年齡:' + cast(23 as nvarchar) 返回 年齡:23

系統函式

newid 無參數

返回一個GUID(全局唯一表示符)值

例如:select newid()

返回:2E6861EF-F4DB-4FFE-86EB-637482FE982J2

isnumeric (任意表達式)

判斷表達式是否為數值類型或者是否可以轉換成數值。

是:返回1,不是:返回0

例如:select isnumeric(1111) 返回 1

select isnumeric('123rr') 返回 0

select isnumeric('123') 返回 1

isnull (任意表達式1,任意表達式2)

如果任意表達式1不為NULL,則返回它的值;否則,在將任意表達式2的類型轉換為任意表達式1的類型(如果這兩個類型不同)後,返回任意表達式2的值。

例如:select isnull(null,N'沒有值') 返回 沒有值

select isnull(N'具體的值',N'沒有值') 返回 具體的值

isdate (任意表達式)

確定輸入表達式是否為有效日期或可轉成有效的日期;

是:返回1,不是:返回0

例如:select isdate(getdate()) 返回1

select isdate('2013-01-02') 返回1

select isdate('198') 返回0

排名函式

row_number 無參數

為結果集內每一行進行編號,從1開始後面行依次加1,常用於產生序號;

例如:select row_number() over(order by userid desc) as [NO],username,password from T_USER

聚合函式

count()

返回組中的總條數,count(*)返回組中所有條數,包括NULL值和重複值項,如果抒寫表達式,則忽略空值,表達式為任意表達式。

max()

返回組中的最大值,空值將被忽略,表達式為數值表達式,字元串表達式,日期。

min()

返回組中的最小值,空值將被忽略,表達式為數值表達式,字元串表達式,日期。

sum()

返回組中所有值的和,空值將被忽略,表達式為數據表達式。

avg()

返回組中所有值的平均值,空值將被忽略,表達式為數據表達式。

相關詞條

相關搜尋

熱門詞條

聯絡我們