目錄
- 一、常見函數(shù)分類
- 1.1單行函數(shù):
- 1.2分組函數(shù):
- 二、單行函數(shù)
- 三、數(shù)學函數(shù)
- 四、日期函數(shù)
- 五、其他函數(shù)
- 六、控制函數(shù)
一、常見函數(shù)分類
1.1單行函數(shù):
- 字符函數(shù)
- 字符控制函數(shù)(CONCAT、SUBSTR、LENGTH。。。)
- 大小寫控制函數(shù)
- 數(shù)學函數(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ù)學函數(shù)、日期函數(shù)、都屬單行函數(shù)的范疇,單行函數(shù)只對一行進行變換,每行返回一個結果。
二、單行函數(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:大寫轉換字符串
lower:小寫轉換字符串
lpad: 用指定的字符實現(xiàn)左填充指定長度
SELECT LPAD('殷素素',2,'*') AS out_put;// 數(shù)字表示指定的長度
rpad:用指定的字符實現(xiàn)右填充指定長度
replace:替換
三、數(shù)學函數(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()) 月;
將字符通過指定的格式轉換成日期
SELECT STR_TO_DATE('1998-3-2','%Y-%c-%d') AS out_put; // 1998-03-02
將日期轉換成字符
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(105,'大','小'); //小
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;
到此這篇關于Mysql基礎之常見函數(shù)的文章就介紹到這了,更多相關mysql常見函數(shù)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- MySQL空間數(shù)據(jù)存儲及函數(shù)
- MySQL中日期型單行函數(shù)代碼詳解
- MySql關于null的函數(shù)使用分享
- 詳解Mysql函數(shù)調用優(yōu)化
- MySQL中sum函數(shù)使用的實例教程
- MySQL處理JSON常見函數(shù)的使用
- MySQL DATE_ADD和ADDDATE函數(shù)實現(xiàn)向日期添加指定時間間隔
- 淺談MySQL函數(shù)