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