MySQL函式

MySQL函式,是一種控制流程函式,屬於資料庫用語言。

控制流程函式

a) CASE WHEN THEN 函式

語法:CASE value WHEN [compare-value] THEN result [WHEN [compare-value] THEN result ……] [ELSE result ]END

CASE WHEN [condition] THEN result [WHEN[condition] THEN result ……] [ELSE result] END ;

函式用法說明:在第一個方案中, 當滿足條件value =compare-value 時,返回對應的result,否則返回ELSE後的result。

在第二個方案中,當滿足條件condition時,返回對應的result,否則返回ELSE後的result。

兩種方案中,如果都不滿足而且如果沒有ELSE 部分,則返回值為NULL

b) IF 函式用法

語法: IF(expr1,expr2,expr3)

函式用法說明:如果 expr1 是 TRUE (expr1 <> 0 and expr1 <> NULL) ,則 IF() 的返回值為 expr2 ; 否則返回值則為 expr3 。 IF() 的返回值為數字值或字元串值,具體情況視其所在語境而定

c) IFNULL 函式

語法: IFNULL(expr1,expr2)

函式用法說明:假如 expr1 不為 NULL ,則 IFNULL() 的返回值為 expr1 ; 否則其返回值為 expr2 。 IFNULL() 的返回值是數字或是字元串,具體情況取決於其所使用的語境

d) NULLIF函式

語法:NULLIF(expr1,expr2)

函式用法說明:NULLIF()函式將會檢驗提供的2個參數是否相等,如果相等,則返回NULL,如果不相等就返回第一個參數。

字元串函式

a) 函式 ascii(str)

函式用法說明:返回值為字元串 str 的最左字元的數值。假如 str 為空字元串,則返回值為 0 。假如 str 為 NULL ,則返回值為 NULL 。 ASCII() 用於帶有從 0 到 255 的數值的字元

b) 函式 BIN(N)

函式用法說明:返回值為 N 的二進制值的字元串表示,其中 N 為一個 longlong (BIGINT) 數字。這等同於 CONV(N ,10,2) 。假如 N 為 NULL ,則返回值為 NULL 。

c) 函式CHAR(N ,... [USING charset ])

函式用法說明: CHAR() 將每個參數 N 理解為一個整數,其返回值為一個包含這些整數的代碼值所給出的字元的字元串。 NULL 值被省略。

d) 函式CHAR_LENGTH(str )

函式使用說明:返回值為字元串 str 的長度,長度的單位為字元。一個多位元組字元算作一個單字元。對於一個 包含五個二位元組字元集 , LENGTH() 返回值為 10, 而 CHAR_LENGTH() 的返回值為 5

e) 函式 CHARACTER_LENGTH(str )

函式使用說明: CHARACTER_LENGTH() 是 CHAR_LENGTH() 的同義詞。

f) 函式 COMPRESS(string_to_compress )

函式使用說明: COMPRESS( 壓縮一個字元串。這個函式要求 MySQL 已經用一個

諸如 zlib 的壓縮庫壓縮過。 否則,返回值始終是 NULL 。 UNCOMPRESS() 可將壓縮過的字元串進行解壓縮 ) 。

g) 函式 CONCAT(str1 ,str2 ,...)

函式使用說明:返回結果為連線參數產生的字元串。如有任何一個參數為 NULL ,則

返回值為 NULL 。或許有一個或多個參數。 如果所有參數均為非二進制字元串,則結果為非二進制字元串。 如果自變數中含有任一二進制字元串,則結果為一個二進制字元串。一個數字參數被轉化為與之相等的二進制字元串格式;若要避免這種情況,可使用顯式類型 cast, 例如: SELECT CONCAT(CAST(int_col AS CHAR), char_col)

h) 函式 CONCAT_WS(separator ,str1 ,str2 ,...)

函式使用說明: CONCAT_WS() 代表 CONCAT With Separator ,是 CONCAT() 的

特殊形式。 第一個參數是其它參數的分隔設定。分隔設定的位置放在要連線的兩個字元串之間。分隔設定可以是一個字元串,也可以是其它參數。如果分隔設定為 NULL ,則結果為 NULL 。函式會忽略任何分隔設定參數後的 NULL 值。

i) 函式CONV(N, from_base, to_base)

函式使用說明:不同數基間轉換數字。返回值為數字的 N 字元串表示,由 from_base 基轉化為 to_base 基。如有任意一個參數為 NULL ,則返回值為 NULL 。自變數 N 被理解為一個整數,但是可以被指定為一個整數或字元串。最小基數為 2 ,而最大基數則為 36 。 If to_base 是一個負數,則 N 被看作一個帶符號數。否則, N 被看作無符號數。 CONV() 的運行精確度為 64 比特。

j) 函式 ELT(N ,str1 ,str2 ,str3 ,...)

函式使用說明:若 N = 1 ,則返回值為 str1 ,若 N = 2 ,則返回值為 str2 ,以此

類推。 若 N 小於 1 或大於參數的數目,則返回值為 NULL 。 ELT() 是 FIELD() 的補數

k) 函式 EXPORT_SET(bits ,on ,off [,separator [,number_of_bits ]])

函式使用說明: 返回值為一個字元串,其中對於 bits 值中的每個位組,可以得到

一個 on 字元串,而對於每個清零比特位,可以得到一個 off 字元串。 bits 中的比特值按照從右到左的順序接受檢驗 ( 由低位比特到高位比特 ) 。字元串被分隔字元串分開 ( 默認為逗號 ‘,’) ,按照從左到右的順序被添加到結果中。 number_of_bits 會給出被檢驗的二進制位數 ( 默認為 64) 。

l) 函式 FIELD(str, str1, str2, str3, …...)

函式使用說明:返回值為 str1 , str2 , str3 ,…… 列表中的 str 指數。在找不到 str 的情況下,返回值為 0 。如果所有對於 FIELD() 的參數均為字元串,則所有參數均按照字元串進行比較。如果所有的參數均為數字,則按照數字進行比較。否則,參數按照雙倍進行比較。如果 str 為 NULL ,則返回值為 0 ,原因是 NULL 不能同任何值進行同等比較。 FIELD() 是 ELT() 的補數。

m) 函式FIND_IN_SET(str, strlist)

函式使用說明: 假如字元串 str 在由 N 子鏈組成的字元串列表 strlist 中, 則返

回值的範圍在 1 到 N 之間 。一個字元串列表就是一個由一些被 ‘,’ 符號分開的自鏈組成的字元串。如果第一個參數是一個常數字元串,而第二個是 type SET 列,則 FIND_IN_SET() 函式被最佳化,使用比特計算。如果 str 不在 strlist 或 strlist 為空字元串,則返回值為 0 。如任意一個參數為 NULL ,則返回值為 NULL 。 這個函式在第一個參數包含一個逗號 (‘,’) 時將無法正常運行。

n) 函式 FORMAT(X ,D )

函式使用說明: 將 number X 設定為格式 '#,###,###.##', 以四捨五入的方式保留到小數點後 D 位 , 而返回結果為一個字元串。

o) 函式 HEX(N_or_S )

函式使用說明:如果N_OR_S 是一個數字,則返回一個 十六進制值 N 的 字元串表示,在這裡, N 是一個longlong (BIGINT) 數。這相當於 CONV(N,10,16) 。如果N_OR_S 是一個字元串,則返回值為一個N_OR_S 的十六進制字元串表示,其中每個N_OR_S 里的每個字元被轉化為兩個十六進制數字。

p) 函式INSTR(str,substr)

函式使用說明:返回字元串 str 中子字元串的第一個出現位置。這和LOCATE() 的雙參數形式相同,除非參數的順序被顛倒。

q) 函式LCASE(str)

函式使用說明:LCASE() 是 LOWER() 的同義詞

r) 函式LEFT(str,len)

函式使用說明:返回從字元串str 開始的len 最左字元

s) 函式 LENGTH(str )

函式使用說明: 返回值為字元串 str 的長度,單位為位元組。一個多位元組字元算作多位元組。這意味著 對於一個包含 5 個 2 位元組字元的字元串, LENGTH() 的返回值為 10, 而 CHAR_LENGTH() 的返回值則為5 。

t) 函式 LOAD_FILE(file_name)

函式使用說明:讀取檔案並將這一檔案按照字元串的格式返回。 檔案的位置必須在伺服器上 , 你必須為檔案制定路徑全名,而且你還必須擁有 FILE 特許權。檔案必須可讀取,檔案容量必須小於 max_allowed_packet 位元組。若檔案不存在,或因不滿足上述條件而不能被讀取, 則函式返回值為 NULL

u) 函式 LOCATE(substr ,str ) , LOCATE(substr ,str ,pos )

函式使用說明:第一個語法返回字元串 str 中子字元串substr 的第一個出現位置。第二個語法返回字元串 str 中子字元串substr 的第一個出現位置, 起始位置在pos 。如若substr 不在str 中,則返回值為0 。

v) 函式LOWER(str )

函式使用說明:返回字元串 str 以及所有根據最新的字元集映射表變為小寫字母的字元

w) 函式LPAD(str ,len ,padstr )

函式使用說明:返回字元串 str , 其左邊由字元串padstr 填補到len 字元長度。假如str 的長度大於len , 則返回值被縮短至 len 字元。

x) 函式LTRIM(str )

函式使用說明:返回字元串 str ,其引導空格字元被刪除。

y) 函式 MAKE_SET(bits ,str1 ,str2 ,...)

函式使用說明: 返回一個設定值 ( 一個包含被 ‘,’ 號分開的字字元串的字元串 ) ,由在 bits 組中具有相應的比特的字元串組成。 str1 對應比特 0, str2 對應比特 1, 以此類推。 str1 , str2 , ... 中的 NULL 值不會被添加到結果中。

z) 函式 MID(str ,pos ,len )

函式使用說明: MID(str ,pos ,len ) 是 SUBSTRING(str ,pos ,len ) 的同義詞。

aa) 函式 OCT(N )

函式使用說明:返回一個 N 的八進制值的字元串表示,其中 N 是一個 longlong (BIGINT) 數。這等同於 CONV(N,10,8) 。若 N 為 NULL ,則返回值為 NULL 。

bb) 函式 OCTET_LENGTH(str )

函式使用說明: OCTET_LENGTH() 是 LENGTH() 的同義詞。

cc) 函式ORD(str )

函式使用說明:若字元串str 的最左字元是一個多位元組字元,則返回該字元的代碼, 代碼的計算通過使用以下公式計算其組成位元組的數值而得出:

(1st byte code)

+ (2nd byte code × 256)

+ (3rd byte code × 2562

) ...

假如最左字元不是一個多位元組字元,那么 ORD() 和函式ASCII() 返回相同的值

dd) 函式 POSITION(substr IN str )

函式使用說明:POSITION(substr IN str ) 是 LOCATE(substr ,str ) 同義詞

ee) 函式QUOTE(str )

函式使用說明:引證一個字元串,由此產生一個在SQL 語句中可用作完全轉義數據值的結果。 返回的字元串由單引號標註,每例都帶有單引號 (‘'’) 、 反斜線符號 (‘\’) 、 ASCII NUL 以及前面有反斜線符號的Control-Z 。如果自變數的值為NULL, 則返回不帶單引號的單詞 “NULL” 。

ff) 函式REPEAT(str ,count )

函式使用說明:返回一個由重複的字元串str 組成的字元串,字元串str 的數目等於count 。 若 count <= 0, 則返回一個空字元串。若str 或 count 為 NULL ,則返回 NULL 。

gg) 函式REPLACE(str ,from_str ,to_str )

函式使用說明:返回字元串str 以及所有被字元串to_str 替代的字元串from_str 。

hh) 函式REVERSE(str )

函式使用說明:返回字元串 str ,順序和字元順序相反。

ii) 函式RIGHT(str ,len )

函式使用說明:從字元串str 開始,返回最右len 字元。

jj) 函式RPAD(str ,len ,padstr )

函式使用說明:返回字元串str , 其右邊被字元串 padstr 填補至len 字元長度。假如字元串str 的長度大於 len , 則返回值被縮短到與 len 字元相同長度

kk) 函式RTRIM(str )

函式使用說明:返回字元串 str ,結尾空格字元被刪去。

ll) 函式 SOUNDEX(str )

函式使用說明:從str 返回一個soundex 字元串。 兩個具有幾乎同樣探測的字元串應該具有同樣的 soundex 字元串。一個標準的soundex 字元串的長度為4 個字元,然而SOUNDEX() 函式會返回一個任意長度的字元串。 可使用結果中的SUBSTRING() 來得到一個標準 soundex 字元串。在str 中, 會忽略所有未按照字母順序排列的字元。所有不在A-Z 範圍之內的國際字母符號被視為元音字母。

mm) 函式expr1 SOUNDS LIKE expr2

函式使用說明: 這相當於SOUNDEX(expr1 ) = SOUNDEX(expr2 ) 。

nn) 函式SPACE(N )

函式使用說明:返回一個由N 間隔符號組成的字元串

oo) 函式SUBSTRING(str ,pos ) , SUBSTRING(str FROM pos ) SUBSTRING(str ,pos ,len ) , SUBSTRING(str FROM pos FOR len )

函式使用說明:不帶有len 參數的格式從字元串str 返回一個子字元串,起始於位置 pos 。帶有len 參數的格式從字元串str 返回一個長度同len 字元相同的子字元串,起始於位置 pos 。 使用 FROM 的格式為標準 SQL 語法。也可能對pos 使用一個負值。假若這樣,則子字元串的位置起始於字元串結尾的pos 字元,而不是字元串的開頭位置。在以下格式的函式中可以對pos 使用一個負值。

pp) 函式SUBSTRING_INDEX(str ,delim ,count )

函式使用說明:在定界符 delim 以及count 出現前,從字元串str 返回自字元串。若count 為正值, 則返回最終定界符( 從左邊開始) 左邊的一切內容。若count 為負值,則返回定界符(從右邊開始)右邊的一切內容。

qq) 函式 TRIM([{BOTH | LEADING | TRAILING} [remstr ] FROM] str ) TRIM(remstr FROM] str )

函式使用說明:返回字元串 str , 其中所有remstr 前綴和/ 或後綴都已被刪除。若分類符BOTH 、LEADIN 或TRAILING 中沒有一個是給定的, 則假設為BOTH 。 remstr 為可選項,在未指定情況下,可刪除空格

rr) 函式UCASE(str)

函式使用說明:UCASE() 是UPPER() 的同義詞

ss) 函式UNCOMPRESS(string_to_uncompress )

函式使用說明:對經COMPRESS() 函式壓縮後的字元串進行解壓縮。若參數為壓縮值,則結果為 NULL 。這個函式要求 MySQL 已被諸如zlib 之類的壓縮庫編譯過。否則, 返回值將始終是 NULL

tt) 函式 UNCOMPRESSED_LENGTH(compressed_string )

函式使用說明: 返回壓縮字元串壓縮前的長度。

uu) 函式 UNHEX(str)

函式使用說明:執行從 HEX(str ) 的反向操作。就是說,它將參數中的每一對十六進制數字理解為一個數字,並將其轉化為該數字代表的字元。結果字元以二進制字元串的形式返回

vv) 函式 UPPER(str )

函式使用說明:返回字元串 str , 以及根據最新字元集映射轉化為大寫字母的字元

數學函式

a) 函式 ABS(X)

函式使用說明:返回 X 的絕對值

b) 函式 ACOS(X )

函式使用說明:返回 X 反餘弦 , 即 , 餘弦是 X 的值。若 X 不在 -1 到 1 的範圍之內,則返回 NULL 。

c) 函式 ASIN ( X )

函式使用說明:返回X 的反正弦,即,正弦為X 的值。若X 若X 不在-1 到 1 的範圍之內,則返回 NULL 。

d) 函式ATAN(X )

函式使用說明:返回 X 的反正切,即,正切為 X 的值。

e) 函式 ATAN(Y ,X ) , ATAN2(Y ,X )

函式使用說明:返回兩個變數 X 及 Y 的反正切。 它類似於 Y 或 X 的反正切計

算 , 除非兩個參數的符號均用於確定結果所在象限。

f) 函式 CEILING(X ) CEIL(X )

函式使用說明:返回不小於 X 的最小整數值。

g) 函式 COS(X )

函式使用說明:返回 X 的餘弦,其中 X 在弧度上已知。

h) 函式 COT(X )

函式使用說明:返回 X 的餘切

i) 函式 CRC32(expr )

函式使用說明:計算循環冗餘碼校驗值並返回一個 32 比特無符號值。若參數為 NULL ,則結果為 NULL 。該參數應為一個字元串,而且在不是字元串的情況下會被作為字元串處理(若有可能)

j) 函式 DEGREES(X )

函式使用說明:返回參數 X , 該參數由弧度被轉化為度。

k) 函式 EXP(X )

函式使用說明:返回 e 的 X 乘方後的值 ( 自然對數的底 ) 。

l) 函式 FLOOR(X )

函式使用說明:返回不大於 X 的最大整數值 。

m) 函式 FORMAT(X ,D )

函式使用說明:將數字 X 的格式寫成 '#,###,###.##' 格式 , 即保留小數點後 D 位,而第 D 位的保留方式為四捨五入,然後將結果以字元串的形式返回

n) 函式 LN(X )

函式使用說明:返回 X 的自然對數 , 即 , X 相對於基數 e 的對數

o) 函式 LOG(X ) LOG(B ,X )

函式使用說明:若用一個參數調用,這個函式就會返回 X 的自然對數。

p) 函式 LOG2(X )

函式使用說明:返回 X 的基數為 2 的對數。

q) 函式 LOG10(X )

函式使用說明:返回 X 的基數為 10 的對數。

r) 函式 MOD(N ,M ) , N % M N MOD M

函式使用說明: 模操作。返回 N 被 M 除後的餘數。

s) 函式 PI()

函式使用說明:返回 ϖ (pi) 的值。默認的顯示小數位數是 7 位 , 然而 MySQL 內部會使用完全雙精度值。

t) 函式 POW(X ,Y ) , POWER(X ,Y )

函式使用說明:返回 X 的 Y 乘方的結果值。

u) 函式 RADIANS(X )

函式使用說明:返回由度轉化為弧度的參數 X , ( 注意 ϖ 弧度等於 180 度)。

v) 函式 RAND() RAND(N )

函式使用說明:返回一個隨機浮點值 v ,範圍在 0 到 1 之間 ( 即 , 其範圍為 0 ≤ v ≤ 1.0) 。若已指定一個整數參數 N ,則它被用作種子值,用來產生重複序列。

w) 函式 ROUND(X ) ROUND(X ,D )

函式使用說明:返回參數 X , 其值接近於最近似的整數。在有兩個參數的情況下,返回 X ,其值保留到小數點後 D 位,而第 D 位的保留方式為四捨五入。若要接保留 X 值小數點左邊的 D 位,可將 D 設為負值。

x) 函式 SIGN(X )

函式使用說明:返回參數作為 -1 、 0 或 1 的符號,該符號取決於 X 的值為負、零或正。

y) 函式 SIN(X )

函式使用說明:返回 X 正弦,其中 X 在弧度中被給定。

z) 函式 SQRT(X )

函式使用說明: 返回非負數 X 的二次方根。

aa) 函式TAN(X )

函式使用說明: 返回 X 的正切,其中 X 在弧度中被給定。

bb) 函式TRUNCATE(X ,D )

函式使用說明: 返回被捨去至小數點後 D 位的數字 X 。若 D 的值為 0, 則結果

不帶有小數點或不帶有小數部分。可以將 D 設為負數 , 若要截去 ( 歸零 ) X 小數點左起第 D 位開始後面所有低位的值

日期時間函式

a) 函式ADDDATE(date ,INTERVAL expr type ) ADDDATE(expr ,days )

函式使用說明: 當被第二個參數的 INTERVAL 格式激活後, ADDDATE() 就是 DATE_ADD() 的同義詞。相關函式 SUBDATE() 則是 DATE_SUB() 的同義詞。對於 INTERVAL 參數上的信息 ,請參見關於 DATE_ADD() 的論述。

b) 函式 ADDTIME(expr ,expr2 )

函式使用說明: ADDTIME() 將 expr2 添加至 expr 然後返回結果。 expr 是一個時間或時間日期表達式,而 expr2 是一個時間表達式。

c) 函式 CONVERT_TZ(dt ,from_tz ,to_tz )

函式使用說明: CONVERT_TZ() 將時間日期值 dt 從 from_tz 給出的時區轉到 to_tz 給出的時區,然後返回結果值。關於可能指定的時區的詳細論述,若自變數無效,則這個函式會返回 NULL

d) 函式 CURDATE()

函式使用說明:將當前日期按照 'YYYY-MM-DD' 或 YYYYMMDD 格式的值返回,具體格式根據函式用在字元串或是數字語境中而定。

e) 函式 CURRENT_DATE CURRENT_DATE()

函式使用說明: CURRENT_DATE 和 CURRENT_DATE() 是的同義詞 .

f) 函式 CURTIME()

函式使用說明: 將當前時間以 'HH:MM:SS' 或 HHMMSS 的格式返回, 具體格式根據函式用在字元串或是數字語境中而定。

g) 函式 CURRENT_TIME, CURRENT_TIME()

函式使用說明: CURRENT_TIME 和 CURRENT_TIME() 是 CURTIME() 的同義詞。

h) 函式 CURRENT_TIMESTAMP, CURRENT_TIMESTAMP()

函式使用說明: CURRENT_TIMESTAMP 和 CURRENT_TIMESTAMP() 是 NOW() 的同義詞

i) 函式 DATE(expr )

函式使用說明: 提取日期或時間日期表達式expr 中的日期部分。

j) 函式 DATEDIFF(expr ,expr2 )

函式使用說明: DATEDIFF() 返回起始時間 expr 和結束時間 expr2 之間的天數。 Expr 和 expr2 為日期或 date-and-time表達式。計算中只用到這些值的日期部分。

k) 函式 DATE_ADD(date ,INTERVAL expr type ) DATE_SUB(date ,INTERVAL expr type )

函式使用說明:這些函式執行日期運算。 date 是一個 DATETIME 或 DATE 值,用來指定起始時間。 expr 是一個表達式,用來指定從起始日期添加或減去的時間間隔值。 Expr 是一個字元串 ; 對於負值的時間間隔,它可以以一個 ‘-’ 開頭。 type 為關鍵字,它指示了表達式被解釋的方式。

l) 函式 DATE_FORMAT(date ,format )

函式使用說明:根據 format 字元串安排 date 值的格式。

m) 函式 DAY(date )

函式使用說明: DAY() 和 DAYOFMONTH() 的意義相同

n) 函式 DAYNAME(date )

函式使用說明:返回 date 對應的工作日名稱。

o) 函式 DAYOFMONTH(date )

函式使用說明:返回 date 對應的該月日期,範圍是從 1 到 31

p) 函式 DAYOFWEEK(date )

函式使用說明:返回 date (1 = 周日 , 2 = 周一 , ..., 7 = 周六 ) 對應的工作日索引。這些索引值符合 ODBC 標準

q) 函式 DAYOFYEAR(date )

函式使用說明:返回date 對應的一年中的天數,範圍是從 1 到366 。

r) 函式 EXTRACT(type FROM date )

函式使用說明: EXTRACT() 函式所使用的時間間隔類型說明符同 DATE_ADD() 或 DATE_SUB() 的相同 , 但它從日期中提取其部分,而不是執行日期運算。

s) 函式FROM_DAYS(N )

函式使用說明: 給定一個天數 N , 返回一個 DATE 值。

t) 函式 FROM_UNIXTIME(unix_timestamp ) FROM_UNIXTIME(unix_timestamp ,format )

函式使用說明:返回'YYYY-MM-DD HH:MM:SS' 或YYYYMMDDHHMMSS 格式值的unix_timestamp 參數表示,具體格式取決於該函式是否用在字元串中或是數字語境中。 若format 已經給出,則結果的格式是根據format 字元串而定。 format 可以包含同DATE_FORMAT() 函式輸入項列表中相同的說明符。

u) 函式 GET_FORMAT(DATE|TIME|DATETIME, 'EUR'|'USA'|'JIS'|'ISO'|'INTERNAL')

函式使用說明:返回一個格式字元串。這個函式在同 DATE_FORMAT() 及 STR_TO_DATE() 函式結合時很有用

v) 函式 HOUR(time )

函式使用說明:返回 time 對應的小時數。對於日時值的返回值範圍是從 0 到 23

w) 函式 LAST_DAY(date )

函式使用說明:獲取一個日期或日期時間值,返回該月最後一天對應的值。若參數無效,則返回 NULL 。

x) 函式 LOCALTIME, LOCALTIME()

函式使用說明: LOCALTIME 及 LOCALTIME() 和 NOW() 具有相同意義。

y) 函式 LOCALTIMESTAMP, LOCALTIMESTAMP()

函式使用說明: LOCALTIMESTAMP 和 LOCALTIMESTAMP() 和 NOW() 具有相同意義。

z) 函式 MAKEDATE(year ,dayofyear )

函式使用說明:給出年份值和一年中的天數值,返回一個日期。 dayofyear 必須大於 0 ,否則結果為 NULL 。

aa) 函式 MAKETIME(hour ,minute ,second )

函式使用說明: 返回由 hour 、 minute 和 second 參數計算得出的時間值

bb) 函式 CROSECOND(expr )

函式使用說明:從時間或日期時間表達式expr 返回微秒值,其數字範圍從 0 到 999999 。

cc) 函式 MINUTE(time )

函式使用說明:返回 time 對應的分鐘數 , 範圍是從 0 到 59 。

dd) 函式 MONTH(date )

函式使用說明:返回 date 對應的月份,範圍時從 1 到 12 。

ee) 函式 MONTHNAME(date )

函式使用說明: 返回 date 對應月份的全名

ff) 函式 NOW()

函式使用說明:返回當前日期和時間值,其格式為 'YYYY-MM-DD HH:MM:SS' 或 YYYYMMDDHHMMSS , 具體格式取決於該函式是否用在字元串中或數字語境中。

gg) 函式 PERIOD_ADD(P ,N )

函式使用說明:添加 N 個月至周期 P ( 格式為 YYMM 或 YYYYMM) ,返回值的格式為 YYYYMM 。注意周期參數 P 不是 日期值。

hh) 函式 PERIOD_DIFF(P1 ,P2 )

函式使用說明:返回周期 P1 和 P2 之間的月份數。 P1 和 P2 的格式應該為 YYMM 或 YYYYMM 。注意周期參數 P1 和 P2 不是 日期值。

ii) 函式 QUARTER(date )

函式使用說明:返回 date 對應的一年中的季度值,範圍是從 1 到 4

jj) 函式 SECOND(time )

函式使用說明:返回 time 對應的秒數 , 範圍是從 0 到 59 。

kk) 函式 SEC_TO_TIME(seconds )

函式使用說明: 返回被轉化為小時、 分鐘和秒數的 seconds 參數值 , 其格式為 'HH:MM:SS' 或 HHMMSS ,具體格式根據該函式是否用在字元串或數字語境中而定

ll) 函式 STR_TO_DATE(str ,format )

函式使用說明:這是 DATE_FORMAT() 函式的倒轉。它獲取一個字元串 str 和一個格式字元串 format 。若格式字元串包含日期和時間部分,則 STR_TO_DATE() 返回一個 DATETIME 值, 若該字元串只包含日期部分或時間部分,則返回一個 DATE 或 TIME 值。

mm) 函式 SUBDATE(date ,INTERVAL expr type ) SUBDATE(expr ,days )

函式使用說明:當被第二個參數的 INTERVAL 型式調用時 , SUBDATE() 和 DATE_SUB() 的意義相同。對於有關 INTERVAL 參數的信息, 見有關 DATE_ADD() 的討論。

nn) 函式 SUBTIME(expr ,expr2 )

函式使用說明: SUBTIME() 從 expr 中提取 expr2 ,然後返回結果。 expr 是一個時間或日期時間表達式,而 xpr2 是一個時間表達式。

oo) 函式 SYSDATE()

函式使用說明:返回當前日期和時間值,格式為 'YYYY-MM-DD HH:MM:SS' 或 YYYYMMDDHHMMSS , 具體格式根據函式是否用在字元串或數字語境而定。

pp) 函式 TIME(expr )

函式使用說明:提取一個時間或日期時間表達式的時間部分,並將其以字元串形式返回。

qq) 函式 TIMEDIFF(expr ,expr2 )

函式使用說明: TIMEDIFF() 返回起始時間 expr 和結束時間 expr2 之間的時間。 expr 和 expr2 為時間或 date-and-time表達式, 兩個的類型必須一樣。

rr) 函式TIMESTAMP(expr ) , TIMESTAMP(expr ,expr2 )

函式使用說明: 對於一個單參數 , 該函式將日期或日期時間表達式expr 作為日期時間值返回 . 對於兩個參數 , 它將時間表達式 expr2 添加到日期或日期時間表達式 expr 中,將 theresult 作為日期時間值返回。

ss) 函式 TIMESTAMPADD(interval ,int_expr ,datetime_expr )

函式使用說明:將整型表達式int_expr 添加到日期或日期時間表達式 datetime_expr 中。 int_expr 的單位被時間間隔參數給定,該參數必須是以下值的其中一個: FRAC_SECOND 、SECOND 、 MINUTE 、 HOUR 、 DAY 、 WEEK 、 MONTH 、 QUARTER 或 YEAR 。可使用所顯示的關鍵字指定Interval 值,或使用SQL_TSI_ 前綴。例如, DAY 或SQL_TSI_DAY 都是正確的

tt) 函式 TIMESTAMPDIFF(interval ,datetime_expr1 ,datetime_expr2 )

函式使用說明:返回日期或日期時間表達式 datetime_expr1 和 datetime_expr2 the 之間的整數差。其結果的單位由 interval 參數給出。 interval 的法定值同 TIMESTAMPADD() 函式說明中所列出的相同。

uu) 函式 TIME_FORMAT(time ,format )

函式使用說明:其使用和 DATE_FORMAT() 函式相同 , 然而 format 字元串可能僅會包含處理小時、分鐘和秒的格式說明符。其它說明符產生一個 NULL 值或 0 。

vv) 函式 TIME_TO_SEC(time )

函式使用說明:返回已轉化為秒的 time 參數

ww) 函式 TO_DAYS(date )

函式使用說明:給定一個日期 date , 返回一個天數 ( 從年份 0 開始的天數 ) 。

xx) 函式 UNIX_TIMESTAMP(), UNIX_TIMESTAMP(date )

函式使用說明:若無參數調用,則返回一個 Unix timestamp ('1970-01-01 00:00:00' GMT 之後的秒數 ) 作為無符號整數。若用 date 來調用 UNIX_TIMESTAMP() ,它會將參數值以 '1970-01-01 00:00:00' GMT 後的秒數的形式返回。 date 可以是一個 DATE 字元串、一個 DATETIME 字元串、一個 TIMESTAMP 或一個當地時間的 YYMMDD 或 YYYMMDD 格式的數字。

yy) 函式 UTC_DATE, UTC_DATE()

函式使用說明:返回當前 UTC 日期值,其格式為 'YYYY-MM-DD' 或 YYYYMMDD ,具體格式取決於函式是否用在字元串或數字語境中。

zz) 函式 UTC_TIME, UTC_TIME()

函式使用說明:返回當前 UTC 值,其格式為 'HH:MM:SS' 或 HHMMSS ,具體格式根據該函式是否用在字元串或數字語境而定。

aaa) 函式 UTC_TIMESTAMP, UTC_TIMESTAMP()

函式使用說明:返回當前 UTC 日期及時間值,格式為 'YYYY-MM-DD HH:MM:SS' 或 YYYYMMDDHHMMSS ,具體格式根據該函式是否用在字元串或數字語境而定

bbb) 函式 WEEK(date [,mode ])

函式使用說明:該函式返回 date 對應的星期數。 WEEK() 的雙參數形式允許你指定該星期是否起始於周日或周一, 以及返回值的範圍是否為從 0 到 53 或從 1 到 53 。若 mode 參數被省略,則使用 default_week_format 系統自變數的值。

ccc) 函式 WEEKDAY(date )

函式使用說明:返回 date (0 = 周一 , 1 = 周二 , ... 6 = 周日 ) 對應的工作日索引 weekday index for

ddd) 函式 WEEKOFYEAR(date )

函式使用說明:將該日期的陽曆周以數字形式返回,範圍是從 1 到 53 。它是一個兼容度函式,相當於 WEEK(date ,3) 。

eee) 函式 YEAR(date )

函式使用說明:返回 date 對應的年份 , 範圍是從 1000 到 9999 。

fff) 函式 YEARWEEK(date ), YEARWEEK(date ,start )

函式使用說明:返回一個日期對應的年或周。 start 參數的工作同 start 參數對 WEEK() 的工作相同。結果中的年份可以和該年的第一周和最後一周對應的日期參數有所不同。

搜尋函式

a) 函式 MATCH (col1,col2,...) AGAINST (expr [IN BOOLEAN MODE | WITH QUERY EXPANSION])

加密函式

a) 函式 AES_ENCRYPT(str ,key_str ) , AES_DECRYPT(crypt_str ,key_str )

函式使用說明:這些函式允許使用官方 AES 進行加密和數據加密 ( 高級加密標準 ) 算法 , 即以前人們所熟知的 “Rijndael” 。 保密關鍵字的長度為 128 比特,不過你可以通過改變源而將其延長到 256 比特。我們選擇了 128 比特的原因是它的速度要快得多,且對於大多數用途而言這個保密程度已經夠用。

b) 函式DECODE(crypt_str ,pass_str )

函式使用說明:使用 pass_str 作為密碼,解密加密字元串 crypt_str , crypt_str 應該是由 ENCODE() 返回的字元串。

c) 函式 ENCODE(str ,pass_str )

函式使用說明:使用 pass_str 作為密碼,解密 str 。 使用 DECODE() 解密結果。

d) 函式 DES_DECRYPT(crypt_str [,key_str ])

函式使用說明:使用 DES_ENCRYPT() 加密一個字元串。若出現錯誤,這個函式會返回 NULL 。

e) 函式 DES_ENCRYPT(str [,(key_num |key_str )])

函式使用說明:用 Triple-DES 算法給出的關鍵字加密字元串。若出現錯誤,這個函式會返回 NULL 。

f) 函式 ENCRYPT(str [,salt ])

函式使用說明:使用 Unix crypt() 系統調用加密 str 。 salt 參數應為一個至少包含 2 個字元的字元串。若沒有給出 salt 參數,則使用任意值。

g) 函式 MD5(str )

函式使用說明:為字元串算出一個 MD5 128 比特檢查和。該值以 32 位十六進制數字的二進制字元串的形式返回 , 若參數為 NULL 則會返回 NULL 。例如,返回值可被用作散列關鍵字

h) 函式 OLD_PASSWORD(str )

函式使用說明:當 PASSWORD() 的執行變為改善安全性時, OLD_PASSWORD() 會被添加到 MySQL 。 OLD_PASSWORD() 返回從前的 PASSWORD() 執行值 ( 4.1 之前 ) ,同時允許你為任何 4.1 之前的需要連線到你的 5.1 版本 MySQL 伺服器前客戶端設定密碼,從而不至於將它們切斷

i) 函式PASSWORD(str )

函式使用說明:從原文密碼str 計算並返回密碼字元串,當參數為 NULL 時返回 NULL 。這個函式用於用戶授權表的Password 列中的加密MySQL 密碼存儲

信息函式

a) 函式 BENCHMARK(count ,expr )

函式使用說明: BENCHMARK() 函式重複 count 次執行表達式 expr 。 它可以被用於計算 MySQL 處理表達式的速度。結果值通常為 0 。另一種用處來自 mysql 客戶端內部 , 能夠報告問詢執行的次數

b) 函式 CHARSET(str )

函式使用說明:返回字元串自變數的字元集。

c) 函式 COERCIBILITY(str )

函式使用說明:返回字元串自變數的整序可壓縮性值。

d) 函式 COLLATION(str )

函式使用說明:返回惠字元串參數的排序方式。

e) 函式 CONNECTION_ID()

函式使用說明:返回對於連線的連線 ID ( 執行緒 ID) 。每個連線都有各自的唯一 ID 。

f) 函式 CURRENT_USER, CURRENT_USER()

函式使用說明:返回當前話路被驗證的用戶名和主機名組合。這個值符合確定你的存取許可權的 MySQL 賬戶。在被指定 SQL SECURITY DEFINER 特徵的存儲程式內, CURRENT_USER() 返回程式的創建者

g) 函式 DATABASE()

函式使用說明:返回使用 utf8 字元集的默認 ( 當前 ) 資料庫名。在存儲程式里,默認資料庫是同該程式向關聯的資料庫,但並不一定與調用語境的默認資料庫相同。

h) 函式 FOUND_ROWS()

函式使用說明: A SELECT 語句可能包括一個 LIMIT 子句,用來限制伺服器返回客戶端的行數。在有些情況下,需要不用再次運行該語句而得知在沒有 LIMIT 時到底該語句返回了多少行。為了知道這個行數 , 包括在 SELECT 語句中選擇 SQL_CALC_FOUND_ROWS ,隨後調用 FOUND_ROWS()

i) 函式 LAST_INSERT_ID() LAST_INSERT_ID(expr )

函式使用說明:自動返回最後一個 INSERT 或 UPDATE 問詢為 AUTO_INCREMENT 列設定的第一個 發生的值。

j) 函式 ROW_COUNT()

函式使用說明: ROW_COUNT() 返回被前面語句升級的、插入的或刪除的行數。 這個行數和 mysql 客戶端顯示的行數及 mysql_affected_rows() C API 函式返回的值相同。

k) 函式 SCHEMA()

函式使用說明:這個函式和 DATABASE() 具有相同的意義

l) 函式 SESSION_USER()

函式使用說明: SESSION_USER() 和 USER() 具有相同的意義。

m) 函式 SYSTEM_USER()

函式使用說明: SYSTEM_USER() 合 USER() 具有相同的意義

n) 函式 USER()

函式使用說明:返回當前 MySQL 用戶名和機主名

o) 函式 VERSION()

函式使用說明:返回指示 MySQL 伺服器版本的字元串。這個字元串使用 utf8 字元集。

其他函式

a) 函式 DEFAULT(col_name )

函式使用說明:返回一個表列的默認值。若該列沒有默認值則會產生錯誤。

b) 函式 FORMAT(X ,D )

函式使用說明:將數字 X 的格式寫為 '#,###,###.##', 以四捨五入的方式保留小數點後 D 位, 並將結果以字元串的形式返回。若 D 為 0, 則返回結果不帶有小數點,或不含小數部分。

c) 函式 GET_LOCK(str ,timeout )

函式使用說明:設法使用字元串 str 給定的名字得到一個鎖, 逾時為 timeout 秒。若成功得到鎖,則返回 1 ,若操作逾時則返回 0 ( 例如 , 由於另一個客戶端已提前封鎖了這個名字 ), 若發生錯誤則返回 NULL ( 諸如缺乏記憶或執行緒 mysqladmin kill 被斷開 ) 。假如你有一個用 GET_LOCK() 得到的鎖,當你執行 RELEASE_LOCK() 或你的連線斷開 ( 正常或非正常 ) 時,這個鎖就會解除

d) 函式 INET_ATON(expr )

函式使用說明:給出一個作為字元串的網路地址的點地址表示,返回一個代表該地址數值的整數。地址可以是 4 或 8 比特地址。

e) 函式 INET_NTOA(expr )

函式使用說明:給定一個數字網路地址 (4 或 8 比特 ), 返回作為字元串的該地址的電地址表示

f) 函式 IS_FREE_LOCK(str )

函式使用說明:檢查名為 str 的鎖是否可以使用 ( 換言之 , 沒有被封鎖 ) 。若鎖可以使用,則返回 1 ( 沒有人在用這個鎖 ), 若這個鎖正在被使用,則返回 0 ,出現錯誤則返回 NULL ( 諸如不正確的參數 ) 。

g) 函式 IS_USED_LOCK(str )

函式使用說明:檢查名為 str 的鎖是否正在被使用 ( 換言之 , 被封鎖 ) 。若被封鎖,則返回使用該鎖的客戶端的連線標識符。否則返回 NULL 。

h) 函式 MASTER_POS_WAIT(log_name ,log_pos [,timeout ])

函式使用說明:該函式對於控制主從同步很有用處。它會持續封鎖,直到從設備閱讀和套用主機記錄中所有補充資料到指定的位置。返回值是其為到達指定位置而必須等待的記錄事件的數目。若從設備 SQL 執行緒沒有被啟動、從設備主機信息尚未初始化、參數不正確或出現任何錯誤,則該函式返回 NULL 。若逾時時間被超過,則返回 -1 。若在 MASTER_POS_WAIT() 等待期間,從設備 SQL 執行緒中止,則該函式返回 NULL 。若從設備由指定位置通過,則函式會立即返回結果。

i) 函式 NAME_CONST(name ,value )

函式使用說明:返回給定值。 當用來產生一個結果集合列時 , NAME_CONST() 促使該列使用給定名稱。

j) 函式 RELEASE_LOCK(str )

函式使用說明:解開被 GET_LOCK() 獲取的,用字元串 str 所命名的鎖。若鎖被解開,則返回 1 ,若改執行緒尚未創建鎖,則返回 0 ( 此時鎖沒有被解開 ), 若命名的鎖不存在,則返回 NULL 。若該鎖從未被對 GET_LOCK() 的調用獲取,或鎖已經被提前解開,則該鎖不存在。

k) 函式 SLEEP(duration )

函式使用說明:睡眠 ( 暫停 ) 時間為 duration 參數給定的秒數,然後返回 0 。若 SLEEP() 被中斷 , 它會返回 1 。 duration 或許或包括一個給定的以微秒為單位的分數部分。

l) 函式 UUID()

函式使用說明:返回一個通用唯一標識符 (UUID) , UUID 被設計成一個在時間和空間上都獨一無二的數字。 2 個對 UUID() 的調用應產生 2 個不同的值,即使這些調用的執行是在兩個互不相連的單獨電腦上進行。

m) 函式 VALUES(col_name )

函式使用說明:在一個 INSERT … ON DUPLICATE KEY UPDATE … 語句中,你可以在 UPDATE 子句中使用 VALUES(col_name ) 函式,用來訪問來自該語句的 INSERT 部分的列值。換言之, UPDATE 子句中的 VALUES(col_name ) 訪問需要被插入的 col_name 的值 , 並不會發生重複鍵衝突。這個函式在多行插入中特別有用。 VALUES() 函式只在 INSERT ... UPDATE 語句中有意義,而在其它情況下只會返回 NULL

聚合函式

a) 函式 AVG([DISTINCT] expr )

函式使用說明:返回 expr 的平均值。 DISTINCT 選項可用於返回 expr 的不同值的平均值。

b) 函式 BIT_AND(expr )

函式使用說明:返回expr 中所有比特的 bitwise AND 。計算執行的精確度為64 比特(BIGINT) 。若找不到匹配的行,則這個函式返回1844 ( 這是無符號 BIGINT 值,所有比特被設定為 1 )。

c) 函式 BIT_OR(expr )

函式使用說明:返回expr 中所有比特的bitwise OR 。計算執行的精確度為64 比特(BIGINT) 。若找不到匹配的行,則函式返回 0 。

d) 函式BIT_XOR(expr )

函式使用說明:返回expr 中所有比特的bitwise XOR 。計算執行的精確度為64 比特(BIGINT) 。若找不到匹配的行,則函式返回 0 。

e) 函式 COUNT(expr )

函式使用說明:返回SELECT 語句檢索到的行中非NULL 值的數目。若找不到匹配的行,則COUNT() 返回 0

f) 函式 COUNT(DISTINCT expr ,[expr ...])

函式使用說明:返回不同的非NULL 值數目。若找不到匹配的項,則COUNT(DISTINCT) 返回 0

g) 函式 GROUP_CONCAT(expr )

函式使用說明:該函式返回帶有來自一個組的連線的非NULL 值的字元串結果。其完整的語法如下所示:

GROUP_CONCAT([DISTINCT] expr [,expr ...] [ORDER BY {unsigned_integer | col_name | expr }

[ASC | DESC] [,col_name ...]]

[SEPARATOR str_val ])

h) 函式 MIN([DISTINCT] expr ), MAX([DISTINCT] expr )

函式使用說明:返回 expr 的最小值和最大值。 MIN() 和 MAX() 的取值可以是一個字元串參數;在這些情況下, 它們返回最小或最大字元串值。

i) 函式 STD(expr ) STDDEV(expr )

函式使用說明:返回 expr 的總體標準偏差。這是標準 SQL 的延伸。這個函式的 STDDEV() 形式用來提供和 Oracle 的兼容性。可使用標準 SQL 函式 STDDEV_POP() 進行代替

j) 函式 STDDEV_POP(expr )

函式使用說明:返回expr 的總體標準偏差(VAR_POP() 的平方根) 。你也可以使用 STD() 或STDDEV(), 它們具有相同的意義,然而不是標準的 SQL 。若找不到匹配的行,則STDDEV_POP() 返回 NULL

k) 函式 STDDEV_SAMP(expr )

函式使用說明:返回expr 的樣本標準差 ( VAR_SAMP() 的平方根) 。若找不到匹配的行,則STDDEV_SAMP() 返回 NULL

l) 函式 SUM([DISTINCT] expr )

函式使用說明:返回expr 的總數。 若返回集合中無任何行,則 SUM() 返回NULL 。DISTINCT 關鍵字可用於 MySQL 5.1 中,求得expr 不同值的總和。 若找不到匹配的行,則SUM() 返回 NULL

m) 函式 VAR_POP(expr )

函式使用說明:返回 expr 總體標準方差。它將行視為總體,而不是一個樣本, 所以它將行數作為分母。你也可以使用 VARIANCE(), 它具有相同的意義然而不是 標準的 SQL

n) 函式 VAR_SAMP(expr )

函式使用說明:返回expr 的樣本方差。更確切的說,分母的數字是行數減去1 。若找不到匹配的行,則VAR_SAMP() 返回NULL

o) 函式VARIANCE(expr )

函式使用說明:返回expr 的總體標準方差。這是標準SQL 的延伸。可使用標準SQL 函式 VAR_POP() 進行代替。若找不到匹配的項,則VARIANCE() 返回NULL

相關詞條

相關搜尋

熱門詞條

聯絡我們