[轉帖]SQL函數大全,史上最全,值得收藏!
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
:SQL函數大全,史上最全,值得收藏! 爆肝整理5k字SQL函數大全,分類清晰,絕對值得收藏,想不起來用什么函數看它就沒錯了! 不多廢話,直接上干貨。 1、聚合函數 2、數字函數 3、字符串函數 4、日期函數 5、轉換函數 6、系統函數 7、條件函數 8、加密函數 根據我的理解,SQL函數可以劃分成上述的8個類別,接下來將一一為大家介紹。 一、聚合函數AVG(col) 返回指定列中所有的平均值。僅用于數字列并自動忽略NULL值。 COUNT(col) 返回指定列中非NULL值的數量??捎糜跀底趾妥址?。 COUNT(*) 返回表中的行數(包括有NULL值的列)。 MAX(col) 返回指定列中的最大值,忽略NULL值。可用于數字、字符和日期時間列。 MIN(col) 返回指定列中的最小值,忽略NULL值??捎糜跀底?、字符和日期時間列。 SUM(col) 返回指定列中所有的總和,忽略NULL值。僅用于數字列。 二、數字函數ACOS(float_expr) 返回角(以弧度表示),它的余弦值近似于指定的浮點表達式。 ASIN(float_expr) 返回角(以弧度表示),它的正弦值近似于指定的浮點表達式。 ATAN(float_expr) 返回角(以弧度表示),它的正切值近似于指定的浮點表達式。 ATN2(float_expr1, float_expr2) 返回角(以弧度表示),它的正切值在兩個近似的浮點表達式之間。 COS(float_expr) 返回以浮點表達式表示的近似于指定角度(以弧度表示)的余弦三角函數的值。 COT(float_expr) 返回以浮點表達式表示的近似于指定角度(以弧度表示)的余切三角函數的值。 SIN(float_expr) 返回以浮點表達式表示的近似于指定角度(以弧度表示)的正弦三角函數的值。 TAN(float_expr) 返回以浮點表達式表示的近似于指定角度(以弧度表示)的正切三角函數的值。 ABS(num_expr) 返回數值表達式的絕對值。 CEILING(num_expr) 返回大于或等于數值表達式的最小整數。 FLOOR(num_expr) 返回小于或等于數值表達式的最大整數。 DEGREES(num_expr)返回數值表達式表示的弧度值對應的度值。 RADIANS(num_expr) 返回數值表達式表示的度值對應的弧度值。 EXP(float_expr) 根據指定的近似浮點表達式,返回指數值。 LOG(float_expr) 根據指定的近似浮點表達式,返回自然對數值。 LOG10(float_expr) 根據指定的近似浮點表達式,返回以10為底的對數。 POWER(num_expr,y) 返回冪為y的數值表達式的值。 SQRT(float_expr) 返回指定的近似浮點表達式的平方根。 SQUARE(float_expr) 返回浮點表達式的平方值。 PI() 返回常量值3.141592653589793。 RAND([seed]) 隨機返回的0到1之間的近似浮點值,可以對seed指定為整數表達式(可選)。 ROUND(num_expr,length) 對數值表達式截取指定的長度,返回四舍五入后的值。 SIGN(num_expr) 對正數執行+1操作,對負數和零執行-1操作。 三、字符串函數主要用于char和varchar數據類型。 Expr1+expr2 返回兩個表達式的組合形式的字符串。 CONCAT(char_expr1, char_expr2, char_exprn) 返回連接的字符串。 ASCII(char_expr) char_expr可以是文字字符,字符串表達式或列。如果char_expr有多個字符,則該函數返回其最左側字符的ASCII代碼值。 CHAR(int_expr) 返回到之間的整數表達式的ASCⅡ字符值。如果輸入的值不在有效范圍內,則返回NULL。 CHARINDEX('pattern',char_expr) 返回字符表達式中指定模式的起始位置。 PATINDEX('%pattern%',expr) 返回表達式中模式第一次出現的起始位置。返回表示不存在模式形式。 FIELD(char_expr, char_expr1, char_expr2, char_expr3,...) 在char_expr之后的字符串中尋找char_expr,并返回出現的索引位置。 DIFFERENCE(char_expr1,char_expr2) 根據比較兩個字符表達式的相似度,返回到之間的值。表示匹配度最佳。 SOUNDEX(char_expr) 評估兩個字符串的相似度后得到的位代碼。 LEN(char_expr) 返回字符表達式的長度。 LOWER(char_expr) 將字符表達式全部轉換為小寫。 UPPER(char_expr) 將字符表達式全部轉換為大寫。 LTRIM(char_expr) 返回刪除掉前面空格的字符表達式。 RTRIM(char_expr) 返回刪除掉其后空格的字符表達式。 TRIM(char_expr ) 返回刪除掉開頭和結尾空格的字符表達式。 SPACE(int_expr) 返回包含指定空格數的字符串。 REPLICATE(input_string,count) 返回重復指定次數的字符表達式產生的字符串。 RIGHT(char_expr,int_expr) 返回從字符表達式最右端起根據指定的字符個數得到的字符。 STUFF(char_expr1,start,length,char_expr2) 使用字符表達式替換字符表達式的一部分字符,從指定的位置開始替換指定的長度。 SUBSTRING(char_expr,start,length) 返回從字符表達式的指定位置開始,截取指定長度得到的字符集。 STR(float_expr[,length[,decimal]]) 返回浮點表達式的字符串表示法。 OCT(char_expr) 返回八進制參數的字符串表示。 REVERSE(char_expr) 反轉字符表達式。 四、日期函數1、獲取時間GETDATE() 當前的系統日期。 select GETDATE() -- 2019-05-07 18:34:27.343 #獲取當前日期還可使用CURRENT_TIMESTAMP()、LOCALTIME()、LOCALTIMESTAMP()。 DATENAME(日期部分,date) 返回日期中日期部分的字符串形式。 select DATENAME(dw,GETDATE()) -- 星期二 注:DATENAME 和 DATEPART 的區別,返回的值類型不同,一個是VARCHAR一個是INT,另外就是星期會用本地語言來表示 DATEPART(日期部分,date) 返回日期中指定的日期部分的整數形式。 select DATEPART(dw,GETDATE()) -- (返回今天是一周中的第幾天):3 YEAR(date) 返回指定日期的年份數值 select YEAR(GETDATE()) -- 2019 MONTH(date)返回指定日期的月份數值 DAY(date)返回指定日期的天數值 還可使用EXTRACT()抽取日期。 # 對于時間2021-04-02 09:25:29,分別獲取其年、月、日、時、分、秒 select EXTRACT(YEAR from NOW()); # 2021 select EXTRACT(MONTH from NOW()); # 4 select EXTRACT(DAY from NOW()); # 2 select EXTRACT(HOUR from NOW()); # 9 select EXTRACT(MINUTE from NOW()); # 25 select EXTRACT(SECOND from NOW()); # 29 # 或者從日期格式字符串中獲取 select EXTRACT(SECOND from '2021-04-02 10:37:14.123456'); # 14 2、增加、減少日期# 時間減少1小時(前一小時) select date_sub(now(), INTERVAL 1 hour); # 日期增加1天 select date_add(now(), INTERVAL 1 day); # 其他間隔 YEAR、MONTH、DAY、HOUR、MINUTE、SECOND 以下較全的MySQL日期函數加示例可做參考(原文鏈接:https://blog.csdn.net/qinshijangshan/article/details/72874667 -- MySQL日期時間處理函數 -- 當前日期:2017-05-12(突然發現今天512,是不是會拉防空警報) select NOW() from DUAL;-- 當前日期時間:2017-05-12 11:41:47 -- 在MySQL里也存在和Oracle里類似的dual虛擬表:官方聲明純粹是為了滿足select ... from...這一習慣問題,mysql會忽略對該表的引用。 -- 那么MySQL中就不用DUAL了吧。 select NOW();-- 當前日期時間:2017-05-12 11:41:55 -- 除了 now() 函數能獲得當前的日期時間外,MySQL 中還有下面的函數: select CURRENT_TIMESTAMP();-- 2017-05-15 10:19:31 select CURRENT_TIMESTAMP;-- 2017-05-15 10:19:51 select LOCALTIME();-- 2017-05-15 10:20:00 select LOCALTIME;-- 2017-05-15 10:20:10 select LOCALTIMESTAMP();-- 2017-05-15 10:20:21(v4.0.6) select LOCALTIMESTAMP;-- 2017-05-15 10:20:30(v4.0.6) -- 這些日期時間函數,都等同于 now()。鑒于 now() 函數簡短易記,建議總是使用 now()來替代上面列出的函數。 select SYSDATE();-- 當前日期時間:2017-05-12 11:42:03 -- sysdate() 日期時間函數跟 now() 類似, -- 不同之處在于:now() 在執行開始時值就得到了;sysdate() 在函數執行時動態得到值。 -- 看下面的例子就明白了: select NOW(), SLEEP(3), NOW(); select SYSDATE(), SLEEP(3), SYSDATE(); select CURDATE();-- 當前日期:2017-05-12 select CURRENT_DATE();-- 當前日期:等同于 CURDATE() select CURRENT_DATE;-- 當前日期:等同于 CURDATE() select CURTIME();-- 當前時間:11:42:47 select CURRENT_TIME();-- 當前時間:等同于 CURTIME() select CURRENT_TIME;-- 當前時間:等同于 CURTIME() -- 獲得當前 UTC 日期時間函數 select UTC_TIMESTAMP(), UTC_DATE(), UTC_TIME() -- MySQL 獲得當前時間戳函數:current_timestamp, current_timestamp() select CURRENT_TIMESTAMP, CURRENT_TIMESTAMP();-- 2017-05-15 10:32:21 | 2017-05-15 10:32:21 -- MySQL 日期時間 Extract(選?。?函數 SET @dt = '2017-05-15 10:37:14.123456'; select DATE(@dt);-- 獲取日期:2017-05-15 select TIME('2017-05-15 10:37:14.123456');-- 獲取時間:10:37:14.123456 select YEAR('2017-05-15 10:37:14.123456');-- 獲取年份 select MONTH('2017-05-15 10:37:14.123456');-- 獲取月份 select DAY('2017-05-15 10:37:14.123456');-- 獲取日 select HOUR('2017-05-15 10:37:14.123456');-- 獲取時 select MINUTE('2017-05-15 10:37:14.123456');-- 獲取分 select SECOND('2017-05-15 10:37:14.123456');-- 獲取秒 select MICROSECOND('2017-05-15 10:37:14.123456');-- 獲取毫秒 select QUARTER('2017-05-15 10:37:14.123456');-- 獲取季度 select WEEK('2017-05-15 10:37:14.123456');-- 20 (獲取周) select WEEK('2017-05-15 10:37:14.123456', 7);-- ****** 測試此函數在MySQL5.6下無效 select WEEKOFYEAR('2017-05-15 10:37:14.123456');-- 同week() select DAYOFYEAR('2017-05-15 10:37:14.123456');-- 135 (日期在年度中第幾天) select DAYOFMONTH('2017-05-15 10:37:14.123456');-- 5 (日期在月度中第幾天) select DAYOFWEEK('2017-05-15 10:37:14.123456');-- 2 (日期在周中第幾天;周日為第一天) select WEEKDAY('2017-05-15 10:37:14.123456');-- 0 select WEEKDAY('2017-05-21 10:37:14.123456');-- 6(與dayofweek()都表示日期在周的第幾天,只是參考標準不同,weekday()周一為第0天,周日為第6天) select YEARWEEK('2017-05-15 10:37:14.123456');-- 201720(年和周) select EXTRACT(YEAR from '2017-05-15 10:37:14.123456'); select EXTRACT(MONTH from '2017-05-15 10:37:14.123456'); select EXTRACT(DAY from '2017-05-15 10:37:14.123456'); select EXTRACT(HOUR from '2017-05-15 10:37:14.123456'); select EXTRACT(MINUTE from '2017-05-15 10:37:14.123456'); select EXTRACT(SECOND from '2017-05-15 10:37:14.123456'); select EXTRACT(MICROSECOND from '2017-05-15 10:37:14.123456'); select EXTRACT(QUARTER from '2017-05-15 10:37:14.123456'); select EXTRACT(WEEK from '2017-05-15 10:37:14.123456'); select EXTRACT(YEAR_MONTH from '2017-05-15 10:37:14.123456'); select EXTRACT(DAY_HOUR from '2017-05-15 10:37:14.123456'); select EXTRACT(DAY_MINUTE from '2017-05-15 10:37:14.123456');-- 151037(日時分) select EXTRACT(DAY_SECOND from '2017-05-15 10:37:14.123456');-- 15103714(日時分秒) select EXTRACT(DAY_MICROSECOND from '2017-05-15 10:37:14.123456');-- 15103714123456(日時分秒毫秒) select EXTRACT(HOUR_MINUTE from '2017-05-15 10:37:14.123456');-- 1037(時分) select EXTRACT(HOUR_SECOND from '2017-05-15 10:37:14.123456');-- 103714(時分秒) select EXTRACT(HOUR_MICROSECOND from '2017-05-15 10:37:14.123456');-- 103714123456(日時分秒毫秒) select EXTRACT(MINUTE_SECOND from '2017-05-15 10:37:14.123456');-- 3714(分秒) select EXTRACT(MINUTE_MICROSECOND from '2017-05-15 10:37:14.123456');-- 3714123456(分秒毫秒) select EXTRACT(SECOND_MICROSECOND from '2017-05-15 10:37:14.123456');-- 14123456(秒毫秒) -- MySQL Extract() 函數除了沒有date(),time() 的功能外,其他功能一應具全。 -- 并且還具有選取‘day_microsecond' 等功能。 -- 注意這里不是只選取 day 和 microsecond,而是從日期的 day 部分一直選取到 microsecond 部分。 select DAYNAME('2017-05-15 10:37:14.123456');-- Monday(返回英文星期) select MONTHNAME('2017-05-15 10:37:14.123456');-- May(返回英文月份) select LAST_DAY('2016-02-01');-- 2016-02-29 (返回月份中最后一天) select LAST_DAY('2016-05-01');-- 2016-05-31 -- DATE_ADD(date,INTERVAL expr type) 從日期加上指定的時間間隔 -- type參數可參考:http://www.w3school.com.cn/sql/func_date_sub.asp select DATE_ADD('2017-05-15 10:37:14.123456',INTERVAL 1 YEAR);-- 表示:2018-05-15 10:37:14.123456 select DATE_ADD('2017-05-15 10:37:14.123456',INTERVAL 1 QUARTER);-- 表示:2017-08-15 10:37:14.123456 select DATE_ADD('2017-05-15 10:37:14.123456',INTERVAL 1 MONTH);-- 表示:2017-06-15 10:37:14.123456 select DATE_ADD('2017-05-15 10:37:14.123456',INTERVAL 1 WEEK);-- 表示:2017-05-22 10:37:14.123456 select DATE_ADD('2017-05-15 10:37:14.123456',INTERVAL 1 DAY);-- 表示:2017-05-16 10:37:14.123456 select DATE_ADD('2017-05-15 10:37:14.123456',INTERVAL 1 HOUR);-- 表示:2017-05-15 11:37:14.123456 select DATE_ADD('2017-05-15 10:37:14.123456',INTERVAL 1 MINUTE);-- 表示:2017-05-15 10:38:14.123456 select DATE_ADD('2017-05-15 10:37:14.123456',INTERVAL 1 SECOND);-- 表示:2017-05-15 10:37:15.123456 select DATE_ADD('2017-05-15 10:37:14.123456',INTERVAL 1 MICROSECOND);-- 表示:2017-05-15 10:37:14.123457 -- DATE_SUB(date,INTERVAL expr type) 從日期減去指定的時間間隔 select DATE_SUB('2017-05-15 10:37:14.123456',INTERVAL 1 YEAR);-- 表示:2016-05-15 10:37:14.123456 select DATE_SUB('2017-05-15 10:37:14.123456',INTERVAL 1 QUARTER);-- 表示:2017-02-15 10:37:14.123456 select DATE_SUB('2017-05-15 10:37:14.123456',INTERVAL 1 MONTH);-- 表示:2017-04-15 10:37:14.123456 select DATE_SUB('2017-05-15 10:37:14.123456',INTERVAL 1 WEEK);-- 表示:2017-05-08 10:37:14.123456 select DATE_SUB('2017-05-15 10:37:14.123456',INTERVAL 1 DAY);-- 表示:2017-05-14 10:37:14.123456 select DATE_SUB('2017-05-15 10:37:14.123456',INTERVAL 1 HOUR);-- 表示:2017-05-15 09:37:14.123456 select DATE_SUB('2017-05-15 10:37:14.123456',INTERVAL 1 MINUTE);-- 表示:2017-05-15 10:36:14.123456 select DATE_SUB('2017-05-15 10:37:14.123456',INTERVAL 1 SECOND);-- 表示:2017-05-15 10:37:13.123456 select DATE_SUB('2017-05-15 10:37:14.123456',INTERVAL 1 MICROSECOND);-- 表示:2017-05-15 10:37:14.123455 -- 經特殊日期測試,DATE_SUB(date,INTERVAL expr type)可放心使用 select DATE_SUB(CURDATE(),INTERVAL 1 DAY);-- 前一天:2017-05-11 select DATE_SUB(CURDATE(),INTERVAL -1 DAY);-- 后一天:2017-05-13 select DATE_SUB(CURDATE(),INTERVAL 1 MONTH);-- 一個月前日期:2017-04-12 select DATE_SUB(CURDATE(),INTERVAL -1 MONTH);-- 一個月后日期:2017-06-12 select DATE_SUB(CURDATE(),INTERVAL 1 YEAR);-- 一年前日期:2016-05-12 select DATE_SUB(CURDATE(),INTERVAL -1 YEAR);-- 一年后日期:20178-06-12 -- MySQL date_sub() 日期時間函數 和 date_add() 用法一致,并且可以用INTERNAL -1 xxx的形式互換使用; -- 另外,MySQL 中還有兩個函數 subdate(), subtime(),建議,用 date_sub() 來替代。 -- MySQL 另類日期函數:period_add(P,N), period_diff(P1,P2) -- 函數參數“P” 的格式為“YYYYMM” 或者 “YYMM”,第二個參數“N” 表示增加或減去 N month(月)。 -- MySQL period_add(P,N):日期加/減去N月。 select PERIOD_ADD(201705,2), PERIOD_ADD(201705,-2);-- 201707 20170503 -- period_diff(P1,P2):日期 P1-P2,返回 N 個月。 select PERIOD_DIFF(201706, 201703);-- -- datediff(date1,date2):兩個日期相減 date1 - date2,返回天數 select DATEDIFF('2017-06-05','2017-05-29');-- 7 -- TIMEDIFF(time1,time2):兩個日期相減 time1 - time2,返回 TIME 差值 select TIMEDIFF('2017-06-05 19:28:37', '2017-06-05 17:00:00');-- 02:28:37 -- MySQL日期轉換函數 select TIME_TO_SEC('01:00:05'); -- 3605 select SEC_TO_TIME(3605);-- 01:00:05 -- MySQL (日期、天數)轉換函數:to_days(date), from_days(days) select TO_DAYS('0000-00-00'); -- NULL select TO_DAYS('2017-06-05'); -- 736850 select from_DAYS(0); -- '0000-00-00' select from_DAYS(736850); -- '2017-06-05' -- MySQL Str to Date (字符串轉換為日期)函數:str_to_date(str, format) select STR_TO_DATE('06.05.2017 19:40:30', '%m.%d.%Y %H:%i:%s');-- 2017-06-05 19:40:30 select STR_TO_DATE('06/05/2017', '%m/%d/%Y'); -- 2017-06-05 select STR_TO_DATE('2017/12/3','%Y/%m/%d') -- 2017-12-03 select STR_TO_DATE('20:09:30', '%h:%i:%s') -- NULL(超過12時的小時用小寫h,得到的結果為NULL) -- 日期時間格式化 select DATE_FORMAT('2017-05-12 17:03:51', '%Y年%m月%d日 %H時%i分%s秒');-- 2017年05月12日 17時03分51秒(具體需要什么格式的數據根據實際情況來;小寫h為12小時制;) select TIME_FORMAT('2017-05-12 17:03:51', '%Y年%m月%d日 %H時%i分%s秒');-- 0000年00月00日 17時03分51秒(time_format()只能用于時間的格式化) -- STR_TO_DATE()和DATE_FORMATE()為互逆操作 -- MySQL 獲得國家地區時間格式函數:get_format() -- MySQL get_format() 語法:get_format(date|time|datetime, 'eur'|'usa'|'jis'|'iso'|'internal' -- MySQL get_format() 用法的全部示例: select GET_FORMAT(DATE,'usa'); -- '%m.%d.%Y' select GET_FORMAT(DATE,'jis'); -- '%Y-%m-%d' select GET_FORMAT(DATE,'iso'); -- '%Y-%m-%d' select GET_FORMAT(DATE,'eur'); -- '%d.%m.%Y' select GET_FORMAT(DATE,'internal'); -- '%Y%m%d' select GET_FORMAT(DATETIME,'usa'); -- '%Y-%m-%d %H.%i.%s' select GET_FORMAT(DATETIME,'jis'); -- '%Y-%m-%d %H:%i:%s' select GET_FORMAT(DATETIME,'iso'); -- '%Y-%m-%d %H:%i:%s' select GET_FORMAT(DATETIME,'eur'); -- '%Y-%m-%d %H.%i.%s' select GET_FORMAT(DATETIME,'internal'); -- '%Y%m%d%H%i%s' select GET_FORMAT(TIME,'usa'); -- '%h:%i:%s %p' select GET_FORMAT(TIME,'jis'); -- '%H:%i:%s' select GET_FORMAT(TIME,'iso'); -- '%H:%i:%s' select GET_FORMAT(TIME,'eur'); -- '%H.%i.%s' select GET_FORMAT(TIME,'internal'); -- '%H%i%s' -- MySQL 拼湊日期、時間函數:makdedate(year,dayofyear), maketime(hour,minute,second) select MAKEDATE(2017,31); -- '2017-01-31' select MAKEDATE(2017,32); -- '2017-02-01' select MAKETIME(19,52,35); -- '19:52:35' -- MySQL 時區(timezone)轉換函數:convert_tz(dt,from_tz,to_tz) select CONVERT_TZ('2017-06-05 19:54:12', '+08:00', '+00:00'); -- 2017-06-05 11:54:12 -- MySQL (Unix 時間戳、日期)轉換函數 -- unix_timestamp(), unix_timestamp(date), from_unixtime(unix_timestamp), from_unixtime(unix_timestamp,format) -- 將具體時間時間轉為timestamp select UNIX_TIMESTAMP();-- 當前時間的時間戳:1494815779 select UNIX_TIMESTAMP('2017-05-15');-- 指定日期的時間戳:1494777600 select UNIX_TIMESTAMP('2017-05-15 10:37:14');-- 指定日期時間的時間戳:1494815834 -- 將時間戳轉為具體時間 select from_UNIXTIME(1494815834);-- 2017-05-15 10:37:14 select from_UNIXTIME(1494815834, '%Y年%m月%d日 %h時%分:%s秒');-- 獲取時間戳對應的格式化日期時間 -- MySQL 時間戳(timestamp)轉換、增、減函數 select TIMESTAMP('2017-05-15');-- 2017-05-15 00:00:00 select TIMESTAMP('2017-05-15 08:12:25', '01:01:01');-- 2017-05-15 09:13:26 select DATE_ADD('2017-05-15 08:12:25', INTERVAL 1 DAY);-- 2017-05-16 08:12:25 select TIMESTAMPADD(DAY, 1, '2017-05-15 08:12:25');-- 2017-05-16 08:12:25; MySQL timestampadd() 函數類似于 date_add()。 select TIMESTAMPDIFF(YEAR, '2017-06-01', '2016-05-15');-- -1 select TIMESTAMPDIFF(MONTH, '2017-06-01', '2016-06-15');-- -11 select TIMESTAMPDIFF(DAY, '2017-06-01', '2016-06-15');-- -351 select TIMESTAMPDIFF(HOUR, '2017-06-01 08:12:25', '2016-06-15 00:00:00');-- -8432 select TIMESTAMPDIFF(MINUTE, '2017-06-01 08:12:25', '2016-06-15 00:00:00');-- -505932 select TIMESTAMPDIFF(SECOND, '2017-06-01 08:12:25', '2016-06-15 00:00:00');-- -30355945 SQL中日期的表示方法及有效范圍,如下:
五、轉換函數1、下列兩個函數用于將(任何類型的)值轉換為指定的數據類型。CONVERT(data_type[(length)], expression [, style]) expression - 要轉換的表達式。 datatype - 要將表達式轉換為的數據類型。 format - 可選-指定日期和時間格式的整數代碼,用于在日期/時間/時間戳數據類型和字符數據類型之間進行轉換。 CAST(expression AS datatype(length)) expression - 要轉換的表達式。 datatype - 要將表達式轉換為的數據類型。 length - 可選。結果數據類型的長度(對于 char、varchar、nchar、nvarchar、binary 和 varbinary) CAST 和 CONVERT 提供相似的功能,但語法不同。在時間轉化中一般用convert,因為它比cast多了一個style,可以根據需要轉化成不同的時間格式。 2、日期相關的轉換函數# 轉換日期格式: DATE_FORMAT(date, format) select DATE_FORMAT(now(),'%Y-%m-%d %H:%i:%s'); select DATE_FORMAT(now(),'%Y-%m-%d %H:00:00'); #字符串轉日期格式 str_to_date(date, format) select str_to_date('2021-04-02 10:37:14', '%Y-%m-%d %H:%i:%s'); # 2021-04-02 10:37:14 3、其他FORMAT(column_name,format) 用于對字段的顯示進行格式化。 INET_ATON(ip) 返回IP地址的數字表示。 INET_NTOA(num) 返回數字所代表的IP地址。 六、系統函數用于返回元數據或相關配置設置。 COALESCE(expr1,expr2, xprN) 返回第一個非NULL表達式。 COL_LENGTH('table_name','column_name') 返回列的長度。 COL_NAME(table_id,column_id) 返回指定的表中的列名。 DATALENGTH('expr') 返回任何數據類型的實際長度。 DB_ID([‘database_name']) 返回數據庫的標識號。 DB_NAME([database_id]) 返回數據庫的名稱。 GETANSINULL([‘database_name']) 返回數據庫的默認空性(Nullability)。 HOST_ID() 返回工作站的標識號。 HOST_NAME() 返回工作站的名稱。 IDENT_INCR('table_or_view') 有新的記錄添加入到表中時計數加。 IDENT_SEED('table_or_view') 返回標識列的起始編號。 INDEX_COL('table_name',index_id,key_id) 返回索引的列名。 ISNULL(expr,value) 使用指定的值替換的NULL表達式。 NULLIF(expr1,expr2) Expr1與Expr2相等時,返回Null。 OBJECT_ID('obj_name') 返回數據庫對象標識號。 OBJECT_NAME('object_id') 返回數據庫對象名。 STATS_DATE(table_id,index_id) 返回上次更新指定索引的統計的日期。 SUSER_SID([‘login_name']) 返回用戶的登錄標識號。 SUSER_ID([‘login_name']) 返回用戶的登錄標識號。這個函數類似于SUSER_SID()函數,并且保留了向后的兼容性。 SUSER_SNAME([server_user_id]) 返回用戶的登錄標識號。 SUSER_NAME([server_user_id]) 返回用戶的登錄標識號。這個函數類似于SUSER_SNAME()函數,并且保留了向后的兼容性。 USER_ID('user_name') 返回用戶的數據庫標識號。 USER_NAME(['user_id']) 返回用戶的數據庫名稱。 七、條件函數條件函數有兩類,一類是CASE(),另一類是IF()。 1、CASE()case()函數有兩種形式,分為簡單型和搜索型 簡單搜索: CASE V0 WHEN V1 THEN E1 WHEN V2 THEN E2 WHEN VN THEN EN ELSE ED END; 復雜搜索: CASE WHEN condition1 THEN result1 WHEN condition2 THEN result2 WHEN conditionN THEN resultN ELSE result END; 簡單的case表達式沒有搜索型case表達式靈活,因為無法指定自己的條件,而搜索型case表達式可以包含范圍條件、不等條件、使用and/or/not組合多個條件,所以,除最簡單的邏輯之外,一般推薦使用搜索型case表達式。 2、IF()IF(condition, value_if_true, value_if_false) condition -- 要進行判斷的值 value_if_true -- condition為真時返回的值 value_if_false -- condition為假時返回的值 IF()函數還衍生出了IFNULL()、NULLIF()函數。 八、加密函數AES_ENCRYPT(str,key) 返回用密鑰key對字符串str利用高級加密標準算法加密后的結果,調用AES_ENCRYPT的結果是一個二進制字符串,以BLOB類型存儲 AES_DECRYPT(str,key) 返回用密鑰key對字符串str利用高級加密標準算法解密后的結果 DECODE(str,key) 使用key作為密鑰解密加密字符串str ENCRYPT(str,salt) 使用UNIXcrypt()函數,用關鍵詞salt(一個可以惟一確定口令的字符串,就像鑰匙一樣)加密字符串str ENCODE(str,key) 使用key作為密鑰加密字符串str,調用ENCODE()的結果是一個二進制字符串,它以BLOB類型存儲 MD5() 計算字符串str的MD5校驗和 PASSWORD(str) 返回字符串str的加密版本,這個加密過程是不可逆轉的,和UNIX密碼加密過程使用不同的算法。 SHA() 計算字符串str的安全散列算法(SHA)校驗和 該文章在 2023/12/7 17:31:47 編輯過 |
關鍵字查詢
相關文章
正在查詢... |