1. 程式人生 > 資訊 >寧德時代與四川發展簽署戰略合作協議,涉及儲能/航空動力/材料等多領域

寧德時代與四川發展簽署戰略合作協議,涉及儲能/航空動力/材料等多領域

MySQL資料庫中提供了很豐富的函式。MySQL函式包括數學函式、字串函式、日期和時間函式、條件判斷函式、系統資訊函式、加密函式、格式化函式等。通過這些函式,可以簡化使用者的操作。例如,字串連線函式可以很方便的將多個字串連線在一起。在這一講中將講解的內容包括:
數學函式
字串函式
日期和時間函式
條件判斷函式
系統資訊函式
加密函式
格式化函式

MySQL函式是MySQL資料庫提供的內部函式。這些內部函式可以幫助使用者更加方便的處理表中的資料。本小節中將簡單介紹MySQL中包含哪幾類函式,以及這幾類函式的的使用範圍和作用。MySQL函式包括數學函式、字串函式、日期和時間函式、條件判斷函式、系統資訊函式、加密函式等。SELECT語句及其條件表示式都可以使用這些函式。同時,INSERT 、UPDATE、DELECT語句及其條件表示式也可以使用這些函式。例如,表中的某個資料是負數,現在需要將這個資料顯示為正數。這就可以使用絕對值函式。從上面可以知道,MySQL函式可以對錶中資料進行相應的處理,以便得到使用者希望得到的資料。這些函式可以使MySQL資料庫的功能更加強大。

MySQL 字串函式
函式 描述 例項
ASCII(s) 返回字串 s 的第一個字元的 ASCII 碼。
返回 CustomerName 欄位第一個字母的 ASCII 碼:

SELECT ASCII(CustomerName) AS NumCodeOfFirstChar
FROM Customers;
CHAR_LENGTH(s) 返回字串 s 的字元數
返回字串 RUNOOB 的字元數

SELECT CHAR_LENGTH("RUNOOB") AS LengthOfString;
CHARACTER_LENGTH(s) 返回字串 s 的字元數
返回字串 RUNOOB 的字元數

SELECT CHARACTER_LENGTH("RUNOOB") AS LengthOfString;
CONCAT(s1,s2...sn) 字串 s1,s2 等多個字串合併為一個字串
合併多個字串

SELECT CONCAT("SQL ", "Runoob ", "Gooogle ", "Facebook") AS ConcatenatedString;
CONCAT_WS(x, s1,s2...sn) 同 CONCAT(s1,s2,...) 函式,但是每個字串之間要加上 x,x 可以是分隔符
合併多個字串,並新增分隔符:

SELECT CONCAT_WS("-", "SQL", "Tutorial", "is", "fun!")AS ConcatenatedString;
FIELD(s,s1,s2...) 返回第一個字串 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) 函式可以將數字 x 進行格式化 "#,###.##", 將 x 保留到小數點後 n 位,最後一位四捨五入。
格式化數字 "#,###.##" 形式:

SELECT FORMAT(250500.5634, 2); -- 輸出 250,500.56
INSERT(s1,x,len,s2) 字串 s2 替換 s1 的 x 位置開始長度為 len 的字串
從字串第一個位置開始的 6 個字元替換為 runoob:

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

SELECT LOCATE('st','myteststring'); -- 5
返回字串 abc 中 b 的位置:

SELECT LOCATE('b', 'abc') -- 2
LCASE(s) 將字串 s 的所有字母變成小寫字母
字串 RUNOOB 轉換為小寫:

SELECT LCASE('RUNOOB') -- runoob
LEFT(s,n) 返回字串 s 的前 n 個字元
返回字串 runoob 中的前兩個字元:

SELECT LEFT('runoob',2) -- ru
LOWER(s) 將字串 s 的所有字母變成小寫字母
字串 RUNOOB 轉換為小寫:

SELECT LOWER('RUNOOB') -- runoob
LPAD(s1,len,s2) 在字串 s1 的開始處填充字串 s2,使字串長度達到 len
將字串 xx 填充到 abc 字串的開始處:

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

SELECT LTRIM(" RUNOOB") AS LeftTrimmedString;-- RUNOOB
MID(s,n,len) 從字串 s 的 n 位置擷取長度為 len 的子字串,同 SUBSTRING(s,n,len)
從字串 RUNOOB 中的第 2 個位置擷取 3個 字元:

SELECT MID("RUNOOB", 2, 3) AS ExtractString; -- UNO
POSITION(s1 IN s) 從字串 s 中獲取 s1 的開始位置
返回字串 abc 中 b 的位置:

SELECT POSITION('b' in 'abc') -- 2
REPEAT(s,n) 將字串 s 重複 n 次
將字串 runoob 重複三次:

SELECT REPEAT('runoob',3) -- runoobrunoobrunoob
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 個字元
返回字串 runoob 的後兩個字元:

SELECT RIGHT('runoob',2) -- ob
RPAD(s1,len,s2) 在字串 s1 的結尾處新增字串 s2,使字串的長度達到 len
將字串 xx 填充到 abc 字串的結尾處:

SELECT RPAD('abc',5,'xx') -- abcxx
RTRIM(s) 去掉字串 s 結尾處的空格
去掉字串 RUNOOB 的末尾空格:

SELECT RTRIM("RUNOOB ") AS RightTrimmedString; -- RUNOOB
SPACE(n) 返回 n 個空格
返回 10 個空格:

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

SELECT STRCMP("runoob", "runoob"); -- 0
SUBSTR(s, start, length) 從字串 s 的 start 位置擷取長度為 length 的子字串
從字串 RUNOOB 中的第 2 個位置擷取 3個 字元:

SELECT SUBSTR("RUNOOB", 2, 3) AS ExtractString; -- UNO
SUBSTRING(s, start, length) 從字串 s 的 start 位置擷取長度為 length 的子字串
從字串 RUNOOB 中的第 2 個位置擷取 3個 字元:

SELECT SUBSTRING("RUNOOB", 2, 3) AS ExtractString; -- UNO
SUBSTRING_INDEX(s, delimiter, number) 返回從字串 s 的第 number 個出現的分隔符 delimiter 之後的子串。
如果 number 是正數,返回第 number 個字元左邊的字串。
如果 number 是負數,返回第(number 的絕對值(從右邊數))個字元右邊的字串。
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 開始和結尾處的空格
去掉字串 RUNOOB 的首尾空格:

SELECT TRIM(' RUNOOB ') AS TrimmedString;
UCASE(s) 將字串轉換為大寫
將字串 runoob 轉換為大寫:

SELECT UCASE("runoob"); -- RUNOOB
UPPER(s) 將字串轉換為大寫
將字串 runoob 轉換為大寫:

SELECT UPPER("runoob"); -- RUNOOB
MySQL 數字函式
函式名 描述 例項
ABS(x) 返回 x 的絕對值  
返回 -1 的絕對值:

SELECT ABS(-1) -- 返回1
ACOS(x) 求 x 的反餘弦值(引數是弧度)
SELECT ACOS(0.25);
ASIN(x) 求反正弦值(引數是弧度)
SELECT ASIN(0.25);
ATAN(x) 求反正切值(引數是弧度)
SELECT ATAN(2.5);
ATAN2(n, m) 求反正切值(引數是弧度)
SELECT ATAN2(-0.8, 2);
AVG(expression) 返回一個表示式的平均值,expression 是一個欄位
返回 Products 表中Price 欄位的平均值:

SELECT AVG(Price) AS AveragePrice FROM Products;
CEIL(x) 返回大於或等於 x 的最小整數 
SELECT CEIL(1.5) -- 返回2
CEILING(x) 返回大於或等於 x 的最小整數 
SELECT CEILING(1.5); -- 返回2
COS(x) 求餘弦值(引數是弧度)
SELECT COS(2);
COT(x) 求餘切值(引數是弧度)
SELECT COT(6);
COUNT(expression) 返回查詢的記錄總數,expression 引數是一個欄位或者 * 號
返回 Products 表中 products 欄位總共有多少條記錄:

SELECT COUNT(ProductID) AS NumberOfProducts FROM Products;
DEGREES(x) 將弧度轉換為角度  
SELECT DEGREES(3.1415926535898) -- 180
n DIV m 整除,n 為被除數,m 為除數
計算 10 除於 5:

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

SELECT EXP(3) -- 20.085536923188
FLOOR(x) 返回小於或等於 x 的最大整數  
小於或等於 1.5 的整數:

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

SELECT GREATEST(3, 12, 34, 8, 25); -- 34
返回以下字串列表中的最大值:

SELECT GREATEST("Google", "Runoob", "Apple"); -- Runoob
LEAST(expr1, expr2, expr3, ...) 返回列表中的最小值
返回以下數字列表中的最小值:

SELECT LEAST(3, 12, 34, 8, 25); -- 3
返回以下字串列表中的最小值:

SELECT LEAST("Google", "Runoob", "Apple"); -- Apple
LN 返回數字的自然對數,以 e 為底。
返回 2 的自然對數:

SELECT LN(2); -- 0.6931471805599453
LOG(x) 或 LOG(base, x) 返回自然對數(以 e 為底的對數),如果帶有 base 引數,則 base 為指定帶底數。  
SELECT LOG(20.085536923188) -- 3
SELECT LOG(2, 4); -- 2
LOG10(x) 返回以 10 為底的對數  
SELECT LOG10(100) -- 2
LOG2(x) 返回以 2 為底的對數
返回以 2 為底 6 的對數:

SELECT LOG2(6); -- 2.584962500721156
MAX(expression) 返回欄位 expression 中的最大值
返回資料表 Products 中欄位 Price 的最大值:

SELECT MAX(Price) AS LargestPrice FROM Products;
MIN(expression) 返回欄位 expression 中的最小值
返回資料表 Products 中欄位 Price 的最小值:

SELECT MIN(Price) AS MinPrice FROM Products;
MOD(x,y) 返回 x 除以 y 以後的餘數 
5 除於 2 的餘數:

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) 將角度轉換為弧度  
180 度轉換為弧度:

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

SELECT SQRT(25) -- 5
SUM(expression) 返回指定欄位的總和
計算 OrderDetails 表中欄位 Quantity 的總和:

SELECT SUM(Quantity) AS TotalItemsOrdered FROM OrderDetails;
TAN(x) 求正切值(引數是弧度)
SELECT TAN(1.75); -- -5.52037992250933
TRUNCATE(x,y) 返回數值 x 保留到小數點後 y 位的值(與 ROUND 最大的區別是不會進行四捨五入)
SELECT TRUNCATE(1.23456,3) -- 1.234
MySQL 日期函式
函式名 描述 例項
ADDDATE(d,n) 計算起始日期 d 加上 n 天的日期
SELECT ADDDATE("2017-06-15", INTERVAL 10 DAY);
->2017-06-25
ADDTIME(t,n) n 是一個時間表達式,時間 t 加上時間表達式 n
加 5 秒:

SELECT ADDTIME('2011-11-11 11:11:11', 5);
->2011-11-11 11:11:16 (秒)
新增 2 小時, 10 分鐘, 5 秒:

SELECT ADDTIME("2020-06-15 09:34:21", "2:10:5");
-> 2020-06-15 11:44:26
CURDATE() 返回當前日期
SELECT CURDATE();
-> 2018-09-19
CURRENT_DATE() 返回當前日期
SELECT CURRENT_DATE();
-> 2018-09-19
CURRENT_TIME 返回當前時間
SELECT CURRENT_TIME();
-> 19:59:02
CURRENT_TIMESTAMP() 返回當前日期和時間
SELECT CURRENT_TIMESTAMP()
-> 2018-09-19 20:57:43
CURTIME() 返回當前時間
SELECT CURTIME();
-> 19:59:02
DATE() 從日期或日期時間表達式中提取日期值
SELECT DATE("2017-06-15");
-> 2017-06-15
DATEDIFF(d1,d2) 計算日期 d1->d2 之間相隔的天數
SELECT DATEDIFF('2001-01-01','2001-02-02')
-> -32
DATE_ADD(d,INTERVAL expr type) 計算起始日期 d 加上一個時間段後的日期,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 DATE_ADD("2017-06-15", INTERVAL 10 DAY);
-> 2017-06-25

SELECT DATE_ADD("2017-06-15 09:34:21", INTERVAL 15 MINUTE);
-> 2017-06-15 09:49:21

SELECT DATE_ADD("2017-06-15 09:34:21", INTERVAL -3 HOUR);
->2017-06-15 06:34:21

SELECT DATE_ADD("2017-06-15 09:34:21", INTERVAL -3 HOUR);
->2017-04-15
DATE_FORMAT(d,f) 按表示式 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) 函式從日期減去指定的時間間隔。
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) 計算日期 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) 計算日期 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) 計算從 0000 年 1 月 1 日開始 n 天后的日期
SELECT FROM_DAYS(1111)
-> 0003-01-16
HOUR(t) 返回 t 中的小時值
SELECT HOUR('1:2:3')
-> 1
LAST_DAY(d) 返回給給定日期的那一月份的最後一天
SELECT LAST_DAY("2017-06-20");
-> 2017-06-30
LOCALTIME() 返回當前日期和時間
SELECT LOCALTIME()
-> 2018-09-19 20:57:43
LOCALTIMESTAMP() 返回當前日期和時間
SELECT LOCALTIMESTAMP()
-> 2018-09-19 20:57:43
MAKEDATE(year, day-of-year) 基於給定引數年份 year 和所在年中的天數序號 day-of-year 返回一個日期
SELECT MAKEDATE(2017, 3);
-> 2017-01-03
MAKETIME(hour, minute, second) 組合時間,引數分別為小時、分鐘、秒
SELECT MAKETIME(11, 35, 4);
-> 11:35:04
MICROSECOND(date) 返回日期引數所對應的微秒數
SELECT MICROSECOND("2017-06-20 09:34:00.000023");
-> 23
MINUTE(t) 返回 t 中的分鐘值
SELECT MINUTE('1:2:3')
-> 2
MONTHNAME(d) 返回日期當中的月份名稱,如 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() 返回當前日期和時間
SELECT NOW()
-> 2018-09-19 20:57:43
PERIOD_ADD(period, number) 為 年-月 組合日期新增一個時段
SELECT PERIOD_ADD(201703, 5);
-> 201708
PERIOD_DIFF(period1, period2) 返回兩個時段之間的月份差值
SELECT PERIOD_DIFF(201710, 201703);
-> 7
QUARTER(d) 返回日期d是第幾季節,返回 1 到 4
SELECT QUARTER('2011-11-11 11:11:11')
-> 4
SECOND(t) 返回 t 中的秒鐘值
SELECT SECOND('1:2:3')
-> 3
SEC_TO_TIME(s) 將以秒為單位的時間 s 轉換為時分秒的格式
SELECT SEC_TO_TIME(4320)
-> 01:12:00
STR_TO_DATE(string, format_mask) 將字串轉變為日期
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 (預設是天)
SUBTIME(t,n) 時間 t 減去 n 秒的時間
SELECT SUBTIME('2011-11-11 11:11:11', 5)
->2011-11-11 11:11:06 (秒)
SYSDATE() 返回當前日期和時間
SELECT SYSDATE()
-> 2018-09-19 20:57:43
TIME(expression) 提取傳入表示式的時間部分
SELECT TIME("19:30:10");
-> 19:30:10
TIME_FORMAT(t,f) 按表示式 f 的要求顯示時間 t
SELECT TIME_FORMAT('11:11:11','%r')
11:11:11 AM
TIME_TO_SEC(t) 將時間 t 轉換為秒
SELECT TIME_TO_SEC('1:12:00')
-> 4320
TIMEDIFF(time1, time2) 計算時間差值
SELECT TIMEDIFF("13:10:11", "13:10:10");
-> 00:00:01
TIMESTAMP(expression, interval) 單個引數時,函式返回日期或日期時間表達式;有2個引數時,將引數加和
SELECT TIMESTAMP("2017-07-23", "13:10:11");
-> 2017-07-23 13:10:11
TO_DAYS(d) 計算日期 d 距離 0000 年 1 月 1 日的天數
SELECT TO_DAYS('0001-01-01 01:01:01')
-> 366
WEEK(d) 計算日期 d 是本年的第幾個星期,範圍是 0 到 53
SELECT WEEK('2011-11-11 11:11:11')
-> 45
WEEKDAY(d) 日期 d 是星期幾,0 表示星期一,1 表示星期二
SELECT WEEKDAY("2017-06-15");
-> 3
WEEKOFYEAR(d) 計算日期 d 是本年的第幾個星期,範圍是 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 高階函式
函式名 描述 例項
BIN(x) 返回 x 的二進位制編碼
15 的 2 進位制編碼:

SELECT BIN(15); -- 1111
BINARY(s) 將字串 s 轉換為二進位制字串
SELECT BINARY "RUNOOB";
-> RUNOOB
CASE expression
WHEN condition1 THEN result1
WHEN condition2 THEN result2
...
WHEN conditionN THEN resultN
ELSE result
END
CASE 表示函式開始,END 表示函式結束。如果 condition1 成立,則返回 result1, 如果 condition2 成立,則返回 result2,當全部不成立則返回 result,而當有一個成立之後,後面的就不執行了。
SELECT CASE
  WHEN 1 > 0
  THEN '1 > 0'
  WHEN 2 > 0
  THEN '2 > 0'
  ELSE '3 > 0'
  END
->1 > 0
CAST(x AS type) 轉換資料型別
字串日期轉換為日期:

SELECT CAST("2017-08-29" AS DATE);
-> 2017-08-29
COALESCE(expr1, expr2, ...., expr_n) 返回引數中的第一個非空表示式(從左向右)
SELECT COALESCE(NULL, NULL, NULL, 'runoob.com', NULL, 'google.com');
-> runoob.com
CONNECTION_ID() 返回唯一的連線 ID
SELECT CONNECTION_ID();
-> 4292835
CONV(x,f1,f2) 返回 f1 進位制數變成 f2 進位制數
SELECT CONV(15, 10, 2);
-> 1111
CONVERT(s USING cs) 函式將字串 s 的字符集變成 cs
SELECT CHARSET('ABC')
->utf-8

SELECT CHARSET(CONVERT('ABC' USING gbk))
->gbk
CURRENT_USER() 返回當前使用者
SELECT CURRENT_USER();
-> guest@%
DATABASE() 返回當前資料庫名
SELECT DATABASE();
-> runoob
IF(expr,v1,v2) 如果表示式 expr 成立,返回結果 v1;否則,返回結果 v2。
SELECT IF(1 > 0,'正確','錯誤')
->正確
IFNULL(v1,v2) 如果 v1 的值不為 NULL,則返回 v1,否則返回 v2。
SELECT IFNULL(null,'Hello Word')
->Hello Word
ISNULL(expression) 判斷表示式是否為 NULL
SELECT ISNULL(NULL);
->1
LAST_INSERT_ID() 返回最近生成的 AUTO_INCREMENT 值
SELECT LAST_INSERT_ID();
->6
NULLIF(expr1, expr2) 比較兩個字串,如果字串 expr1 與 expr2 相等 返回 NULL,否則返回 expr1
SELECT NULLIF(25, 25);
->
SESSION_USER() 返回當前使用者
SELECT SESSION_USER();
-> guest@%
SYSTEM_USER() 返回當前使用者
SELECT SYSTEM_USER();
-> guest@%
USER() 返回當前使用者
SELECT USER();
-> guest@%
VERSION() 返回資料庫的版本號
SELECT VERSION()
-> 5.6.34