Mysql基礎(chǔ)之常見函數(shù)
一、常見函數(shù)分類
1.1單行函數(shù):
- 字符函數(shù)
- 字符控制函數(shù)(CONCAT、SUBSTR、LENGTH。。。)
- 大小寫控制函數(shù)
- 數(shù)學(xué)函數(shù)
- 日期函數(shù)
- 流程控制函數(shù)
1.2分組函數(shù):
分組函數(shù)功能偏向統(tǒng)計,比如,AVG()、COUNT()、MAX()、MIN()、SUM()
單行函數(shù)與分組函數(shù):
(1)分組函數(shù):主要用來進行統(tǒng)計、聚合使用到的函數(shù),分組函數(shù)接收多個輸入,返回一個輸出。
(2)單行函數(shù):上面提到的字符函數(shù)、數(shù)學(xué)函數(shù)、日期函數(shù)、都屬單行函數(shù)的范疇,單行函數(shù)只對一行進行變換,每行返回一個結(jié)果。
二、單行函數(shù)
字符函數(shù)
concat:字符連接函數(shù)
substr:截取字符串,
SELECT SUBSTR('李莫愁愛上了陸展元',7) out_put; // 索引由1開始,陸展元 SELECT SUBSTR('李莫愁愛上了陸展元',1,3) out_put;// 李莫愁
instr:返回子串第一次出現(xiàn)的索引,如果找不到返回0
SELECT INSTR('楊不殷六俠悔愛上了殷六俠','殷六俠') AS out_put;// 3
trim:去掉左邊與右邊的空格元素
SELECT LENGTH(TRIM(' 張翠山 ')) AS out_put; SELECT TRIM('aa' FROM 'aaaaaaaaa張aaaaaaaaaaaa翠山aaaaaaaaaaaa') AS out_put;//中間的a并不能去掉
upper:大寫轉(zhuǎn)換字符串
lower:小寫轉(zhuǎn)換字符串
lpad: 用指定的字符實現(xiàn)左填充指定長度
SELECT LPAD('殷素素',2,'*') AS out_put;// 數(shù)字表示指定的長度
rpad:用指定的字符實現(xiàn)右填充指定長度
replace:替換
三、數(shù)學(xué)函數(shù)
四舍五入 SELECT ROUND(-1.55);// -2 SELECT ROUND(1.567,2);// 指定字符精度 1.56 向上取整 SELECT CEIL(-1.02);// -1 向下取整 SELECT FLOOR(-9.99);// -10 截斷 SELECT TRUNCATE(1.69999,1);// 1.6 取余 SELECT MOD(-10,3); // -1 SELECT MOD(-10,-3);// -1 SELECT MOD(10,-3);// 1
四、日期函數(shù)
返回當前系統(tǒng)日期+時間 SELECT NOW();// 2021-03-16 09:00:35 返回當前系統(tǒng)日期,不包含時間 SELECT CURDATE();// 2021-03-16 返回當前時間,不包含日期 SELECT CURTIME();// 09:00:35 可以獲取指定的部分,年、月、日、小時、分鐘、秒 SELECT YEAR(NOW()) 年; SELECT YEAR('1998-1-1') 年; SELECT MONTH(NOW()) 月; SELECT MONTHNAME(NOW()) 月; 將字符通過指定的格式轉(zhuǎn)換成日期 SELECT STR_TO_DATE('1998-3-2','%Y-%c-%d') AS out_put; // 1998-03-02 將日期轉(zhuǎn)換成字符 SELECT DATE_FORMAT(NOW(),'%y年%m月%d日') AS out_put;
五、其他函數(shù)
SELECT VERSION(); // sql版本 SELECT DATABASE();// 當前數(shù)據(jù)庫 SELECT USER();// root@localhost
六、控制函數(shù)
IF函數(shù) SELECT IF(10<5,'大','小'); //小 case函數(shù)的使用1:case后帶參,表示某一種確定的情況 case 要判斷的字段或表達式 when 常量1 then 要顯示的值1或語句1; when 常量2 then 要顯示的值2或語句2; SELECT salary 原始工資,department_id, CASE department_id WHEN 30 THEN salary*1.1 WHEN 40 THEN salary*1.2 WHEN 50 THEN salary*1.3 ELSE salary END AS 新工資 FROM employees; case函數(shù)的使用2:case后不帶參數(shù),表示一種模糊的區(qū)間 SELECT salary, CASE WHEN salary>20000 THEN 'A' WHEN salary>15000 THEN 'B' WHEN salary>10000 THEN 'C' ELSE 'D' END AS 工資級別 FROM employees;
到此這篇關(guān)于Mysql基礎(chǔ)之常見函數(shù)的文章就介紹到這了,更多相關(guān)mysql常見函數(shù)內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。