目錄
一、字符串函數
1、常用的字符串函數
2、函數演示
3、具體案例
二、數值函數
1、常用的數值函數
2、函數演示
3、具體案例
三、日期函數
1、常用的日期函數
2、函數演示
3、具體案例
四、流程函數
1、常用的流程函數
2、函數演示
3、具體案例
????????在MySQL中,函數是預先定義好的程序,能夠接收零個或多個輸入參數,接著進行特定運算,最終返回一個結果。
? ? ? ? 也就意味著,這一段程序或代碼在MySQL中已經給我們提供了,我們要做的就是在合適的場景調用對應的函數完成對應的需求即可。
? ? ? ? MySQL主要用于DML?(數據操作語言)與DQL?(數據查詢語言),在 DDL (數據定義語言)和 DCL (數據控制語言)中幾乎沒有什么使用場景。
????????MySQL中的函數主要分為以下四類: 字符串函數、數值函數、日期函數、流程函數。以下是對這四類函數的詳細介紹。
一、字符串函數
1、常用的字符串函數
????????MySQL中內置了很多字符串函數,常用的幾個如下:
2、函數演示
(1)concat : 字符串拼接
select concat('Hello' , ' MySQL');
(2)lower : 全部轉小寫
select lower('Hello');
(3)upper : 全部轉大寫
select upper('Hello');
(4)lpad : 左填充
select lpad('01', 5, '-');
(5)rpad : 右填充
select rpad('01', 5, '-');
(6)trim : 去除空格
select trim(' Hello MySQL ');
(7)substring : 截取子字符串
select substring('Hello MySQL',1,5);
3、具體案例
????????由于業務需求變更,企業員工的工號,統一為5位數,目前不足5位數的全部在前面補0。比如: 1號員工的工號應該為00001。
update emp set workno = lpad(workno, 5, '0');
二、數值函數
1、常用的數值函數
常用的數值函數如下:
2、函數演示
(1)ceil:向上取整
select ceil(1.1);
(2)floor:向下取整
select floor(1.9);
(3)mod:取模
select mod(7,4);
(4)rand:獲取隨機數(0 ~ 1)
select rand();
(5)round:四舍五入
select round(2.344,2);
3、具體案例
????????通過數據庫的函數,生成一個六位數的隨機驗證碼。
????????思路: 獲取隨機數可以通過rand()函數,但是獲取出來的隨機數是在0-1之間的,所以可以在其基礎上乘以1000000,然后舍棄小數部分,如果長度不足6位,補0。
select lpad(round(rand()*1000000 , 0), 6, '0');
三、日期函數
1、常用的日期函數
常見的日期函數如下:
2、函數演示
(1)curdate:當前日期
select curdate();
(2)curtime:當前時間
select curtime();
(3)now:當前日期和時間
select now();
(4)year , month , day:當前年、月、日
select year(now());select month(now());select day(now());
(5)date_add:增加指定的時間間隔
select date_add(now(), interval 70 YEAR );
--其中date的值是一個符合'xxxx-xx-xx'形式的日期即可,也可以是函數
(6)datediff:獲取兩個日期相差的天數
select datediff('2021-10-01', '2021-12-01');
--是前面的日期減去后面的日期
3、具體案例
? ? ? ? 查詢所有員工的入職天數,并根據入職天數倒序排序。
????????思路:入職天數,就是通過當前日期 - 入職日期,所以需要使用 datediff 函數來完成。
select name, datediff(curdate(), entrydate) as 'entrydays'
from emp
order by entrydays desc;
四、流程函數
1、常用的流程函數
????????流程函數也是常用的一類函數,可以在SQL語句中實現條件篩選,從而提高語句的效率。
? ? ? ? 最后兩個函數的基本形式是:case when then else end,作用是進行條件分支的判斷。
? ? ? ? 上面的第三個函數用于范圍匹配,當vall是真的時候,返回res1,否則返回default;上面的第四個函數用于具體的值的判斷,當expr是vall的時候,返回res1,否則返回default。
2、函數演示
(1)if
select if(false, 'Ok', 'Error');
(2)ifnull
select ifnull('Ok','Default');select ifnull('','Default');select ifnull(null,'Default');
????????第二個 SQL 語句中的 ' ' 并非空值 null。在 SQL 里,' ' 代表空字符串,它屬于一個有實際內容的值,只是內容為空。
????????而 ifnull 函數的用途是檢驗第一個參數是否為 null ,若為 null 則返回第二個參數;若不是 null,就返回第一個參數。
(3)case when then else end
? ? ? ? 查詢emp表的員工姓名和工作地址,北京/上海顯示為一線城市,其他顯示為二線城市。
selectname,(case workaddress when '北京' then '一線城市' when '上海' then '一線城市' else '二線城市' end ) as '工作地址'
from emp;
3、具體案例
我們現在有這樣一個表:
? ? ? ? 要求成績按如下展示:85分及以上顯示優秀,60分及以上顯示及格,否則顯示不及格。
selectid,name,(case when math >= 85 then '優秀' when math >=60 then '及格' else '不及格' end ) '數學',(case when english >= 85 then '優秀' when english >=60 then '及格' else '不及格' end ) '英語',(case when chinese >= 85 then '優秀' when chinese >=60 then '及格' else '不及格' end ) '語文'
from score;
?????????以上即為MySQL 函數(入門版)的全部內容,創作不易,麻煩三連支持一下唄~??
?