溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Mysql中有哪些常見的函數(shù)

發(fā)布時間:2021-04-30 15:29:59 來源:億速云 閱讀:128 作者:Leah 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細(xì)講解有關(guān)Mysql中有哪些常見的函數(shù),文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

一、常見函數(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ù):主要用來進(jìn)行統(tǒng)計、聚合使用到的函數(shù),分組函數(shù)接收多個輸入,返回一個輸出。

(2)單行函數(shù):上面提到的字符函數(shù)、數(shù)學(xué)函數(shù)、日期函數(shù)、都屬單行函數(shù)的范疇,單行函數(shù)只對一行進(jìn)行變換,每行返回一個結(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: 用指定的字符實(shí)現(xiàn)左填充指定長度

SELECT LPAD('殷素素',2,'*') AS out_put;// 數(shù)字表示指定的長度

rpad:用指定的字符實(shí)現(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ù)

返回當(dāng)前系統(tǒng)日期+時間
SELECT NOW();// 2021-03-16 09:00:35

返回當(dāng)前系統(tǒng)日期,不包含時間
SELECT CURDATE();// 2021-03-16

返回當(dāng)前時間,不包含日期
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();// 當(dāng)前數(shù)據(jù)庫
SELECT USER();// root@localhost

六、控制函數(shù)

IF函數(shù)
SELECT IF(10<5,'大','小'); //小

case函數(shù)的使用1:case后帶參,表示某一種確定的情況

case 要判斷的字段或表達(dá)式
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中有哪些常見的函數(shù)就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI