MySQL 函數(shù)

MySQL 有很多內(nèi)置的函數(shù),以下列出了這些函數(shù)的說明。

MySQL 字符串函數(shù)

函數(shù)描述示例
ASCII(s)返回字符串 s 的第一個(gè)字符的 ASCII 碼。

返回 CustomerName 字段第一個(gè)字母的 ASCII 碼:

SELECT ASCII(CustomerName) AS NumCodeOfFirstChar
FROM Customers;
CHAR_LENGTH(s)返回字符串 s 的字符數(shù)

返回字符串 NHOOO 的字符數(shù)

SELECT CHAR_LENGTH("NHOOO") AS LengthOfString;
CHARACTER_LENGTH(s)返回字符串 s 的字符數(shù)

返回字符串 NHOOO 的字符數(shù)

SELECT CHARACTER_LENGTH("NHOOO") AS LengthOfString;
CONCAT(s1,s2...sn)字符串 s1,s2 等多個(gè)字符串合并為一個(gè)字符串

合并多個(gè)字符串

SELECT CONCAT("SQL ", "Nhooo ", "Gooogle ", "Facebook") AS ConcatenatedString;
CONCAT_WS(x, s1,s2...sn)同 CONCAT(s1,s2,...) 函數(shù),但是每個(gè)字符串之間要加上 x,x 可以是分隔符

合并多個(gè)字符串,并添加分隔符:

SELECT CONCAT_WS("-", "SQL", "Tutorial", "is", "fun!")AS ConcatenatedString;
FIELD(s,s1,s2...)返回第一個(gè)字符串 s 在字符串列表(s1,s2...)中的位置

返回字符串 c 在列表值中的位置:

SELECT FIELD("c", "a", "b", "c", "d", "e");
FIND_IN_SET(s1,s2)返回在字符串s2中與s1匹配的字符串的位置

返回字符串 c 在指定字符串中的位置:

SELECT FIND_IN_SET("c", "a,b,c,d,e");
FORMAT(x,n)函數(shù)可以將數(shù)字 x 進(jìn)行格式化 "#,###.##", 將 x 保留到小數(shù)點(diǎn)后 n 位,最后一位四舍五入。

格式化數(shù)字 "#,###.##" 形式:

SELECT FORMAT(250500.5634, 2);     -- 輸出 250,500.56
INSERT(s1,x,len,s2)字符串 s2 替換 s1 的 x 位置開始長度為 len 的字符串

從字符串第一個(gè)位置開始的 6 個(gè)字符替換為 nhooo:

SELECT INSERT("google.com", 1, 6, "nhooo");  -- 輸出:(cainiaoplus.com)
LOCATE(s1,s)從字符串 s 中獲取 s1 的開始位置

獲取 b 在字符串 abc 中的位置:

SELECT LOCATE('st','myteststring');  -- 5

返回字符串 abc 中 b 的位置:

SELECT LOCATE('b', 'abc') -- 2
LCASE(s)將字符串 s 的所有字母變成小寫字母

字符串 NHOOO 轉(zhuǎn)換為小寫:

SELECT LCASE('NHOOO') -- nhooo
LEFT(s,n)返回字符串 s 的前 n 個(gè)字符

返回字符串 nhooo 中的前兩個(gè)字符:

SELECT LEFT('nhooo',2) -- ru
LOWER(s)將字符串 s 的所有字母變成小寫字母

字符串 NHOOO 轉(zhuǎn)換為小寫:

SELECT LOWER('NHOOO') -- nhooo
LPAD(s1,len,s2)在字符串 s1 的開始處填充字符串 s2,使字符串長度達(dá)到 len

將字符串 xx 填充到 abc 字符串的開始處:

SELECT LPAD('abc',5,'xx') -- xxabc
LTRIM(s)去掉字符串 s 開始處的空格

去掉字符串 NHOOO開始處的空格:

SELECT LTRIM("    NHOOO") AS LeftTrimmedString;-- NHOOO
MID(s,n,len)從字符串 s 的 n 位置截取長度為 len 的子字符串,同 SUBSTRING(s,n,len)

從字符串 NHOOO 中的第 2 個(gè)位置截取 3個(gè) 字符:

SELECT MID("NHOOO", 2, 3) AS ExtractString; -- UNO
POSITION(s1 IN s)從字符串 s 中獲取 s1 的開始位置

返回字符串 abc 中 b 的位置:

SELECT POSITION('b' in 'abc') -- 2
REPEAT(s,n)將字符串 s 重復(fù) n 次

將字符串 nhooo 重復(fù)三次:

SELECT REPEAT('nhooo',3) -- nhooonhooonhooo
REPLACE(s,s1,s2)將字符串 s2 代替字符串 s 中的字符串 s1

將字符串 abc 中的字符 a 替換為字符 x:

SELECT REPLACE('abc','a','x') --xbc
REVERSE(s)將字符串s的順序反過來

將字符串 abc 的順序反過來:

SELECT REVERSE('abc') -- cba
RIGHT(s,n)返回字符串 s 的后 n 個(gè)字符

返回字符串 nhooo 的后兩個(gè)字符:

SELECT RIGHT('nhooo',2) -- ob
RPAD(s1,len,s2)在字符串 s1 的結(jié)尾處添加字符串 s2,使字符串的長度達(dá)到 len

將字符串 xx 填充到 abc 字符串的結(jié)尾處:

SELECT RPAD('abc',5,'xx') -- abcxx
RTRIM(s)去掉字符串 s 結(jié)尾處的空格

去掉字符串 NHOOO 的末尾空格:

SELECT RTRIM("NHOOO     ") AS RightTrimmedString;   -- NHOOO
SPACE(n)返回 n 個(gè)空格

返回 10 個(gè)空格:

SELECT SPACE(10);
STRCMP(s1,s2)比較字符串 s1 和 s2,如果 s1 與 s2 相等返回 0 ,如果 s1>s2 返回 1,如果 s1<s2 返回 -1

比較字符串:

SELECT STRCMP("nhooo", "nhooo");  -- 0
SUBSTR(s, start, length)從字符串 s 的 start 位置截取長度為 length 的子字符串

從字符串 NHOOO 中的第 2 個(gè)位置截取 3個(gè) 字符:

SELECT SUBSTR("NHOOO", 2, 3) AS ExtractString; -- UNO
SUBSTRING(s, start, length)從字符串 s 的 start 位置截取長度為 length 的子字符串

從字符串 NHOOO 中的第 2 個(gè)位置截取 3個(gè) 字符:

SELECT SUBSTRING("NHOOO", 2, 3) AS ExtractString; -- UNO
SUBSTRING_INDEX(s, delimiter, number)返回從字符串 s 的第 number 個(gè)出現(xiàn)的分隔符 delimiter 之后的子串。
如果 number 是正數(shù),返回第 number 個(gè)字符左邊的字符串。
如果 number 是負(fù)數(shù),返回第(number 的絕對值(從右邊數(shù)))個(gè)字符右邊的字符串。
SELECT SUBSTRING_INDEX('a*b','*',1) -- a
SELECT SUBSTRING_INDEX('a*b','*',-1)    -- b
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('a*b*c*d*e','*',3),'*',-1)    -- c
TRIM(s)去掉字符串 s 開始和結(jié)尾處的空格

去掉字符串 NHOOO 的首尾空格:

SELECT TRIM('    NHOOO    ') AS TrimmedString;
UCASE(s)將字符串轉(zhuǎn)換為大寫

將字符串 nhooo 轉(zhuǎn)換為大寫:

SELECT UCASE("nhooo"); -- NHOOO
UPPER(s)將字符串轉(zhuǎn)換為大寫

將字符串 nhooo 轉(zhuǎn)換為大寫:

SELECT UPPER("nhooo"); -- NHOOO

MySQL 數(shù)字函數(shù)

函數(shù)名描述示例
ABS(x)返回 x 的絕對值  

返回 -1 的絕對值:

SELECT ABS(-1) -- 返回1
ACOS(x)求 x 的反余弦值(參數(shù)是弧度)
SELECT ACOS(0.25);
ASIN(x)求反正弦值(參數(shù)是弧度)
SELECT ASIN(0.25);
ATAN(x)求反正切值(參數(shù)是弧度)
SELECT ATAN(2.5);
ATAN2(n, m)求反正切值(參數(shù)是弧度)
SELECT ATAN2(-0.8, 2);
AVG(expression)返回一個(gè)表達(dá)式的平均值,expression 是一個(gè)字段

返回 Products 表中Price 字段的平均值:

SELECT AVG(Price) AS AveragePrice FROM Products;
CEIL(x)返回大于或等于 x 的最小整數(shù) 
SELECT CEIL(1.5) -- 返回2
CEILING(x) 返回大于或等于 x 的最小整數(shù) 
SELECT CEILING(1.5); -- 返回2
COS(x)求余弦值(參數(shù)是弧度)
SELECT COS(2);
COT(x)求余切值(參數(shù)是弧度)
SELECT COT(6);
COUNT(expression)返回查詢的記錄總數(shù),expression 參數(shù)是一個(gè)字段或者 * 號

返回 Products 表中 products 字段總共有多少條記錄:

SELECT COUNT(ProductID) AS NumberOfProducts FROM Products;
DEGREES(x)將弧度轉(zhuǎn)換為角度  
SELECT DEGREES(3.1415926535898) -- 180
n DIV m整除,n 為被除數(shù),m 為除數(shù)

計(jì)算 10 除于 5:

SELECT 10 DIV 5;  -- 2
EXP(x)返回 e 的 x 次方  

計(jì)算 e 的三次方:

SELECT EXP(3) -- 20.085536923188
FLOOR(x)返回小于或等于 x 的最大整數(shù)  

小于或等于 1.5 的整數(shù):

SELECT FLOOR(1.5) -- 返回1
GREATEST(expr1, expr2, expr3, ...)返回列表中的最大值

返回以下數(shù)字列表中的最大值:

SELECT GREATEST(3, 12, 34, 8, 25); -- 34

返回以下字符串列表中的最大值:

SELECT GREATEST("Google", "Nhooo", "Apple");   -- Nhooo
LEAST(expr1, expr2, expr3, ...)返回列表中的最小值

返回以下數(shù)字列表中的最小值:

SELECT LEAST(3, 12, 34, 8, 25); -- 3

返回以下字符串列表中的最小值:

SELECT LEAST("Google", "Nhooo", "Apple");   -- Apple
LN返回?cái)?shù)字的自然對數(shù),以 e 為底。

返回 2 的自然對數(shù):

SELECT LN(2);  -- 0.6931471805599453
LOG(x) 或 LOG(base, x)返回自然對數(shù)(以 e 為底的對數(shù)),如果帶有 base 參數(shù),則 base 為指定帶底數(shù)?! ?/td>
SELECT LOG(20.085536923188) -- 3
SELECT LOG(2, 4); -- 2
LOG10(x)返回以 10 為底的對數(shù)  
SELECT LOG10(100) -- 2
LOG2(x)返回以 2 為底的對數(shù)

返回以 2 為底 6 的對數(shù):

SELECT LOG2(6);  -- 2.584962500721156
MAX(expression)返回字段 expression 中的最大值

返回?cái)?shù)據(jù)表 Products 中字段 Price 的最大值:

SELECT MAX(Price) AS LargestPrice FROM Products;
MIN(expression)返回字段 expression 中的最小值

返回?cái)?shù)據(jù)表 Products 中字段 Price 的最小值:

SELECT MIN(Price) AS MinPrice FROM Products;
MOD(x,y)返回 x 除以 y 以后的余數(shù) 

5 除于 2 的余數(shù):

SELECT MOD(5,2) -- 1
PI()返回圓周率(3.141593)  
SELECT PI() --3.141593
POW(x,y)返回 x 的 y 次方 

2 的 3 次方:

SELECT POW(2,3) -- 8
POWER(x,y)返回 x 的 y 次方 

2 的 3 次方:

SELECT POWER(2,3) -- 8
RADIANS(x)將角度轉(zhuǎn)換為弧度  

180 度轉(zhuǎn)換為弧度:

SELECT RADIANS(180) -- 3.1415926535898
RAND()返回 0 到 1 的隨機(jī)數(shù)  
SELECT RAND() --0.93099315644334
ROUND(x)返回離 x 最近的整數(shù)
SELECT ROUND(1.23456) --1
SIGN(x)返回 x 的符號,x 是負(fù)數(shù)、0、正數(shù)分別返回 -1、0 和 1 
SELECT SIGN(-10) -- (-1)
SIN(x)求正弦值(參數(shù)是弧度)  
SELECT SIN(RADIANS(30)) -- 0.5
SQRT(x)返回x的平方根  

25 的平方根:

SELECT SQRT(25) -- 5
SUM(expression)返回指定字段的總和

計(jì)算 OrderDetails 表中字段 Quantity 的總和:

SELECT SUM(Quantity) AS TotalItemsOrdered FROM OrderDetails;
TAN(x)求正切值(參數(shù)是弧度)
SELECT TAN(1.75);  -- -5.52037992250933
TRUNCATE(x,y)返回?cái)?shù)值 x 保留到小數(shù)點(diǎn)后 y 位的值(與 ROUND 最大的區(qū)別是不會進(jìn)行四舍五入)
SELECT TRUNCATE(1.23456,3) -- 1.234

MySQL 日期函數(shù)

函數(shù)名描述示例
ADDDATE(d,n)計(jì)算起始日期 d 加上 n 天的日期
SELECT ADDDATE("2017-06-15", INTERVAL 10 DAY);
->2017-06-25
ADDTIME(t,n)n 是一個(gè)時(shí)間表達(dá)式,時(shí)間 t 加上時(shí)間表達(dá)式 n

加 5 秒:

SELECT ADDTIME('2011-11-11 11:11:11', 5);
->2011-11-11 11:11:16 (秒)

添加 2 小時(shí), 10 分鐘, 5 秒:

SELECT ADDTIME("2020-06-15 09:34:21", "2:10:5"); 
-> 2020-06-15 11:44:26
CURDATE()返回當(dāng)前日期
SELECT CURDATE();
-> 2018-09-19
CURRENT_DATE()返回當(dāng)前日期
SELECT CURRENT_DATE();
-> 2018-09-19
CURRENT_TIME返回當(dāng)前時(shí)間
SELECT CURRENT_TIME();
-> 19:59:02
CURRENT_TIMESTAMP()返回當(dāng)前日期和時(shí)間
SELECT CURRENT_TIMESTAMP()
-> 2018-09-19 20:57:43
CURTIME()返回當(dāng)前時(shí)間
SELECT CURTIME();
-> 19:59:02
DATE()從日期或日期時(shí)間表達(dá)式中提取日期值
SELECT DATE("2017-06-15");    
-> 2017-06-15
DATEDIFF(d1,d2)計(jì)算日期 d1->d2 之間相隔的天數(shù)
SELECT DATEDIFF('2001-01-01','2001-02-02')
-> -32
DATE_ADD(d,INTERVAL expr type)計(jì)算起始日期 d 加上一個(gè)時(shí)間段后的日期
SELECT ADDDATE('2011-11-11 11:11:11',1)
-> 2011-11-12 11:11:11    (默認(rèn)是天)
SELECT ADDDATE('2011-11-11 11:11:11', INTERVAL 5 MINUTE)
-> 2011-11-11 11:16:11 (TYPE的取值與上面那個(gè)列出來的函數(shù)類似)
DATE_FORMAT(d,f)按表達(dá)式  f的要求顯示日期 d
SELECT DATE_FORMAT('2011-11-11 11:11:11','%Y-%m-%d %r')
-> 2011-11-11 11:11:11 AM
DATE_SUB(date,INTERVAL expr type)函數(shù)從日期減去指定的時(shí)間間隔。

Orders 表中 OrderDate 字段減去 2 天:

SELECT OrderId,DATE_SUB(OrderDate,INTERVAL 2 DAY) AS OrderPayDate
FROM Orders
DAY(d)返回日期值 d 的日期部分
SELECT DAY("2017-06-15");  
-> 15
DAYNAME(d)返回日期 d 是星期幾,如 Monday,Tuesday
SELECT DAYNAME('2011-11-11 11:11:11')
->Friday
DAYOFMONTH(d)計(jì)算日期 d 是本月的第幾天
SELECT DAYOFMONTH('2011-11-11 11:11:11')
->11
DAYOFWEEK(d)日期 d 今天是星期幾,1 星期日,2 星期一,以此類推
SELECT DAYOFWEEK('2011-11-11 11:11:11')
->6
DAYOFYEAR(d)計(jì)算日期 d 是本年的第幾天
SELECT DAYOFYEAR('2011-11-11 11:11:11')
->315
EXTRACT(type FROM d)從日期 d 中獲取指定的值,type 指定返回的值。
type可取值為:
  • MICROSECOND

  • SECOND

  • MINUTE

  • HOUR

  • DAY

  • WEEK

  • MONTH

  • QUARTER

  • YEAR

  • SECOND_MICROSECOND

  • MINUTE_MICROSECOND

  • MINUTE_SECOND

  • HOUR_MICROSECOND

  • HOUR_SECOND

  • HOUR_MINUTE

  • DAY_MICROSECOND

  • DAY_SECOND

  • DAY_MINUTE

  • DAY_HOUR

  • YEAR_MONTH

SELECT EXTRACT(MINUTE FROM '2011-11-11 11:11:11') 
-> 11
FROM_DAYS(n)計(jì)算從 0000 年 1 月 1 日開始 n 天后的日期
SELECT FROM_DAYS(1111)
-> 0003-01-16
HOUR(t)返回 t 中的小時(shí)值
SELECT HOUR('1:2:3')
-> 1
LAST_DAY(d)返回給給定日期的那一月份的最后一天
SELECT LAST_DAY("2017-06-20");
-> 2017-06-30
LOCALTIME()返回當(dāng)前日期和時(shí)間
SELECT LOCALTIME()
-> 2018-09-19 20:57:43
LOCALTIMESTAMP()返回當(dāng)前日期和時(shí)間
SELECT LOCALTIMESTAMP()
-> 2018-09-19 20:57:43
MAKEDATE(year, day-of-year)基于給定參數(shù)年份 year 和所在年中的天數(shù)序號 day-of-year 返回一個(gè)日期
SELECT MAKEDATE(2017, 3);
-> 2017-01-03
MAKETIME(hour, minute, second)組合時(shí)間,參數(shù)分別為小時(shí)、分鐘、秒
SELECT MAKETIME(11, 35, 4);
-> 11:35:04
MICROSECOND(date)返回日期參數(shù)所對應(yīng)的微秒數(shù)
SELECT MICROSECOND("2017-06-20 09:34:00.000023");
-> 23
MINUTE(t)返回 t 中的分鐘值
SELECT MINUTE('1:2:3')
-> 2
MONTHNAME(d)返回日期當(dāng)中的月份名稱,如 November
SELECT MONTHNAME('2011-11-11 11:11:11')
-> November
MONTH(d)返回日期d中的月份值,1 到 12
SELECT MONTH('2011-11-11 11:11:11')
->11
NOW()返回當(dāng)前日期和時(shí)間
SELECT NOW()
-> 2018-09-19 20:57:43
PERIOD_ADD(period, number)為 年-月 組合日期添加一個(gè)時(shí)段
SELECT PERIOD_ADD(201703, 5);   
-> 201708
PERIOD_DIFF(period1, period2)返回兩個(gè)時(shí)段之間的月份差值
SELECT PERIOD_DIFF(201710, 201703);
-> 7
QUARTER(d)返回日期d是第幾季節(jié),返回 1 到 4
SELECT QUARTER('2011-11-11 11:11:11')
-> 4
SECOND(t)返回 t 中的秒鐘值
SELECT SECOND('1:2:3')
-> 3
SEC_TO_TIME(s)將以秒為單位的時(shí)間 s 轉(zhuǎn)換為時(shí)分秒的格式
SELECT SEC_TO_TIME(4320)
-> 01:12:00
STR_TO_DATE(string, format_mask)將字符串轉(zhuǎn)變?yōu)槿掌?/td>
SELECT STR_TO_DATE("August 10 2017", "%M %d %Y");
-> 2017-08-10
SUBDATE(d,n)日期 d 減去 n 天后的日期
SELECT SUBDATE('2011-11-11 11:11:11', 1)
->2011-11-10 11:11:11 (默認(rèn)是天)
SUBTIME(t,n)時(shí)間 t 減去 n 秒的時(shí)間
SELECT SUBTIME('2011-11-11 11:11:11', 5)
->2011-11-11 11:11:06 (秒)
SYSDATE()返回當(dāng)前日期和時(shí)間
SELECT SYSDATE()
-> 2018-09-19 20:57:43
TIME(expression)提取傳入表達(dá)式的時(shí)間部分
SELECT TIME("19:30:10");
-> 19:30:10
TIME_FORMAT(t,f)按表達(dá)式 f 的要求顯示時(shí)間 t
SELECT TIME_FORMAT('11:11:11','%r')
11:11:11 AM
TIME_TO_SEC(t)將時(shí)間 t 轉(zhuǎn)換為秒
SELECT TIME_TO_SEC('1:12:00')
-> 4320
TIMEDIFF(time1, time2)計(jì)算時(shí)間差值
SELECT TIMEDIFF("13:10:11", "13:10:10");
-> 00:00:01
TIMESTAMP(expression, interval)單個(gè)參數(shù)時(shí),函數(shù)返回日期或日期時(shí)間表達(dá)式;有2個(gè)參數(shù)時(shí),將參數(shù)加和
SELECT TIMESTAMP("2017-07-23",  "13:10:11");
-> 2017-07-23 13:10:11
TO_DAYS(d)計(jì)算日期 d 距離 0000 年 1 月 1 日的天數(shù)
SELECT TO_DAYS('0001-01-01 01:01:01')
-> 366
WEEK(d)計(jì)算日期 d 是本年的第幾個(gè)星期,范圍是 0 到 53
SELECT WEEK('2011-11-11 11:11:11')
-> 45
WEEKDAY(d)日期 d 是星期幾,0 表示星期一,1 表示星期二
SELECT WEEKDAY("2017-06-15");
-> 3
WEEKOFYEAR(d)計(jì)算日期 d 是本年的第幾個(gè)星期,范圍是 0 到 53
SELECT WEEKOFYEAR('2011-11-11 11:11:11')
-> 45
YEAR(d)返回年份
SELECT YEAR("2017-06-15");
-> 2017
YEARWEEK(date, mode)返回年份及第幾周(0到53),mode 中 0 表示周天,1表示周一,以此類推
SELECT YEARWEEK("2017-06-15");
-> 201724

MySQL 高級函數(shù)

函數(shù)名描述示例
BIN(x)返回 x 的二進(jìn)制編碼

15 的 2 進(jìn)制編碼:

SELECT BIN(15); -- 1111
BINARY(s)將字符串 s 轉(zhuǎn)換為二進(jìn)制字符串
SELECT BINARY "NHOOO";
-> NHOOO
CASE expression
    WHEN condition1 THEN result1
    WHEN condition2 THEN result2
   ...
    WHEN conditionN THEN resultN
    ELSE result
END
CASE 表示函數(shù)開始,END 表示函數(shù)結(jié)束。如果 condition1 成立,則返回 result1, 如果 condition2 成立,則返回 result2,當(dāng)全部不成立則返回 result,而當(dāng)有一個(gè)成立之后,后面的就不執(zhí)行了。
SELECT CASE 
  WHEN 1 > 0
  THEN '1 > 0'
  WHEN 2 > 0
  THEN '2 > 0'
  ELSE '3 > 0'
  END
->1 > 0
CAST(x AS type)轉(zhuǎn)換數(shù)據(jù)類型

字符串日期轉(zhuǎn)換為日期:

SELECT CAST("2017-08-29" AS DATE);
-> 2017-08-29
COALESCE(expr1, expr2, ...., expr_n)返回參數(shù)中的第一個(gè)非空表達(dá)式(從左向右)
SELECT COALESCE(NULL, NULL, NULL, '(cainiaoplus.com)', NULL, 'google.com');
-> (cainiaoplus.com)
CONNECTION_ID()返回唯一的連接 ID
SELECT CONNECTION_ID();
-> 4292835
CONV(x,f1,f2)返回 f1 進(jìn)制數(shù)變成 f2 進(jìn)制數(shù)
SELECT CONV(15, 10, 2);
-> 1111
CONVERT(s USING cs)函數(shù)將字符串 s 的字符集變成 cs
SELECT CHARSET('ABC')
->utf-8    
SELECT CHARSET(CONVERT('ABC' USING gbk))
->gbk
CURRENT_USER()返回當(dāng)前用戶
SELECT CURRENT_USER();
-> guest@%
DATABASE()返回當(dāng)前數(shù)據(jù)庫名
SELECT DATABASE();   
-> nhooo
IF(expr,v1,v2)如果表達(dá)式 expr 成立,返回結(jié)果 v1;否則,返回結(jié)果 v2。
SELECT IF(1 > 0,'正確','錯誤')    
->正確
IFNULL(v1,v2)如果 v1 的值不為 NULL,則返回 v1,否則返回 v2。
SELECT IFNULL(null,'Hello Word')
->Hello Word
ISNULL(expression)判斷表達(dá)式是否為 NULL
SELECT ISNULL(NULL);
->1
LAST_INSERT_ID()返回最近生成的 AUTO_INCREMENT 值
SELECT LAST_INSERT_ID();
->6
NULLIF(expr1, expr2)比較兩個(gè)字符串,如果字符串 expr1 與 expr2 相等 返回 NULL,否則返回 expr1
SELECT NULLIF(25, 25);
->
SESSION_USER()返回當(dāng)前用戶
SELECT SESSION_USER();
-> guest@%
SYSTEM_USER()返回當(dāng)前用戶
SELECT SYSTEM_USER();
-> guest@%
USER()返回當(dāng)前用戶
SELECT USER();
-> guest@%
VERSION()返回?cái)?shù)據(jù)庫的版本號
SELECT VERSION()
-> 5.6.34
丰满人妻一级特黄a大片,午夜无码免费福利一级,欧美亚洲精品在线,国产婷婷成人久久Av免费高清