Mysql基礎之常見函數
一、常見函數分類
1.1單行函數:
- 字符函數
- 字符控制函數(CONCAT、SUBSTR、LENGTH。。。)
- 大小寫控制函數
- 數學函數
- 日期函數
- 流程控制函數
1.2分組函數:
分組函數功能偏向統計,比如,AVG()、COUNT()、MAX()、MIN()、SUM()
單行函數與分組函數:
(1)分組函數:主要用來進行統計、聚合使用到的函數,分組函數接收多個輸入,返回一個輸出。
(2)單行函數:上面提到的字符函數、數學函數、日期函數、都屬單行函數的范疇,單行函數隻對一行進行變換,每行返回一個結果。
二、單行函數
字符函數
concat:字符連接函數
substr:截取字符串,
SELECT SUBSTR('李莫愁愛上瞭陸展元',7) out_put; // 索引由1開始,陸展元 SELECT SUBSTR('李莫愁愛上瞭陸展元',1,3) out_put;// 李莫愁
instr:返回子串第一次出現的索引,如果找不到返回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: 用指定的字符實現左填充指定長度
SELECT LPAD('殷素素',2,'*') AS out_put;// 數字表示指定的長度
rpad:用指定的字符實現右填充指定長度
replace:替換
三、數學函數
四舍五入 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
四、日期函數
返回當前系統日期+時間 SELECT NOW();// 2021-03-16 09:00:35 返回當前系統日期,不包含時間 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;
五、其他函數
SELECT VERSION(); // sql版本 SELECT DATABASE();// 當前數據庫 SELECT USER();// root@localhost
六、控制函數
IF函數 SELECT IF(10<5,'大','小'); //小 case函數的使用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函數的使用2:case後不帶參數,表示一種模糊的區間 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基礎之常見函數的文章就介紹到這瞭,更多相關mysql常見函數內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- None Found