目錄
- 一、常見(jiàn)函數(shù)分類(lèi)
- 1.1單行函數(shù):
- 1.2分組函數(shù):
- 二、單行函數(shù)
- 三、數(shù)學(xué)函數(shù)
- 四、日期函數(shù)
- 五、其他函數(shù)
- 六、控制函數(shù)
一、常見(jiàn)函數(shù)分類(lèi)
1.1單行函數(shù):
- 字符函數(shù)
- 字符控制函數(shù)(CONCAT、SUBSTR、LENGTH。。。)
- 大小寫(xiě)控制函數(shù)
- 數(shù)學(xué)函數(shù)
- 日期函數(shù)
- 流程控制函數(shù)
1.2分組函數(shù):
分組函數(shù)功能偏向統(tǒng)計(jì),比如,AVG()、COUNT()、MAX()、MIN()、SUM()
單行函數(shù)與分組函數(shù):
(1)分組函數(shù):主要用來(lái)進(jìn)行統(tǒng)計(jì)、聚合使用到的函數(shù),分組函數(shù)接收多個(gè)輸入,返回一個(gè)輸出。
(2)單行函數(shù):上面提到的字符函數(shù)、數(shù)學(xué)函數(shù)、日期函數(shù)、都屬單行函數(shù)的范疇,單行函數(shù)只對(duì)一行進(jìn)行變換,每行返回一個(gè)結(jié)果。
二、單行函數(shù)
字符函數(shù)
concat:字符連接函數(shù)
substr:截取字符串,
SELECT SUBSTR('李莫愁?lèi)?ài)上了陸展元',7) out_put; // 索引由1開(kāi)始,陸展元
SELECT SUBSTR('李莫愁?lèi)?ài)上了陸展元',1,3) out_put;// 李莫愁
instr:返回子串第一次出現(xiàn)的索引,如果找不到返回0
SELECT INSTR('楊不殷六俠悔愛(ài)上了殷六俠','殷六俠') AS out_put;// 3
trim:去掉左邊與右邊的空格元素
SELECT LENGTH(TRIM(' 張翠山 ')) AS out_put;
SELECT TRIM('aa' FROM 'aaaaaaaaa張aaaaaaaaaaaa翠山aaaaaaaaaaaa') AS out_put;//中間的a并不能去掉
upper:大寫(xiě)轉(zhuǎn)換字符串
lower:小寫(xiě)轉(zhuǎn)換字符串
lpad: 用指定的字符實(shí)現(xiàn)左填充指定長(zhǎng)度
SELECT LPAD('殷素素',2,'*') AS out_put;// 數(shù)字表示指定的長(zhǎng)度
rpad:用指定的字符實(shí)現(xiàn)右填充指定長(zhǎng)度
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
截?cái)?
SELECT TRUNCATE(1.69999,1);// 1.6
取余
SELECT MOD(-10,3); // -1
SELECT MOD(-10,-3);// -1
SELECT MOD(10,-3);// 1
四、日期函數(shù)
返回當(dāng)前系統(tǒng)日期+時(shí)間
SELECT NOW();// 2021-03-16 09:00:35
返回當(dāng)前系統(tǒng)日期,不包含時(shí)間
SELECT CURDATE();// 2021-03-16
返回當(dāng)前時(shí)間,不包含日期
SELECT CURTIME();// 09:00:35
可以獲取指定的部分,年、月、日、小時(shí)、分鐘、秒
SELECT YEAR(NOW()) 年;
SELECT YEAR('1998-1-1') 年;
SELECT MONTH(NOW()) 月;
SELECT MONTHNAME(NOW()) 月;
將字符通過(guò)指定的格式轉(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();// 當(dāng)前數(shù)據(jù)庫(kù)
SELECT USER();// root@localhost
六、控制函數(shù)
IF函數(shù)
SELECT IF(105,'大','小'); //小
case函數(shù)的使用1:case后帶參,表示某一種確定的情況
case 要判斷的字段或表達(dá)式
when 常量1 then 要顯示的值1或語(yǔ)句1;
when 常量2 then 要顯示的值2或語(yǔ)句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 工資級(jí)別
FROM employees;
到此這篇關(guān)于Mysql基礎(chǔ)之常見(jiàn)函數(shù)的文章就介紹到這了,更多相關(guān)mysql常見(jiàn)函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- MySQL空間數(shù)據(jù)存儲(chǔ)及函數(shù)
- MySQL中日期型單行函數(shù)代碼詳解
- MySql關(guān)于null的函數(shù)使用分享
- 詳解Mysql函數(shù)調(diào)用優(yōu)化
- MySQL中sum函數(shù)使用的實(shí)例教程
- MySQL處理JSON常見(jiàn)函數(shù)的使用
- MySQL DATE_ADD和ADDDATE函數(shù)實(shí)現(xiàn)向日期添加指定時(shí)間間隔
- 淺談MySQL函數(shù)