成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

MySQL數據庫中的函數怎樣使用?

數據庫 MySQL
函數是指一段可以直接被另一段程序調用的程序或代碼。 也就意味著,這一段程序或代碼在MySQL中已經給我們提供了,我們要做的就是在合適的業務場景調用對應的函數完成對應的業務需求即可。 那么,函數到底在哪兒使用呢?

函數 是指一段可以直接被另一段程序調用的程序或代碼。 也就意味著,這一段程序或代碼在MySQL中已經給我們提供了,我們要做的就是在合適的業務場景調用對應的函數完成對應的業務需求即可。 那么,函數到底在哪兒使用呢?

我們先來看兩個場景:

1). 在企業的OA或其他的人力系統中,經常會提供的有這樣一個功能,每一個員工登錄上來之后都能夠看到當前員工入職的天數。而在數據庫中,存儲的都是入職日期,如2000-11-12,那如果快速計算出天數呢?

2). 在做報表這類的業務需求中,我們要展示出學員的分數等級分布。而在數據庫中,存儲的是學生的分數值,如98/75,如何快速判定分數的等級呢?其實,上述的這一類的需求呢,我們通過MySQL中的函數都可以很方便的實現。

MySQL中的函數主要分為以下四類:字符串函數、數值函數、日期函數、流程函數。

字符串函數

MySQL中內置了很多字符串函數,常用的幾個如下:

演示如下:

A. concat : 字符串拼接

select concat('Hello' , ' MySQL');

B. lower : 全部轉小寫

select lower('Hello');

C. upper : 全部轉大寫

select upper('Hello');

D. lpad : 左填充

select lpad('01', 5, '-');

E. rpad : 右填充

select rpad('01', 5, '-');

F. trim : 去除空格

select trim(' Hello MySQL ');

G. substring : 截取子字符串

select substring('Hello MySQL',1,5);

案例:

由于業務需求變更,企業員工的工號,統一為5位數,目前不足5位數的全部在前面補0。比如: 1號員工的工號應該為00001。

update emp set workno = lpad(workno, 5, '0');

處理完畢后, 具體的數據為:

數值函數

常見的數值函數如下:

演示如下:

A. ceil:向上取整

select ceil(1.1);

B. floor:向下取整

select floor(1.9);

C. mod:取模

select mod(7,4); 1

D. rand:獲取隨機數

select rand();

E. round:四舍五入

select round(2.344,2);

案例:

通過數據庫的函數,生成一個六位數的隨機驗證碼。

思路: 獲取隨機數可以通過rand()函數,但是獲取出來的隨機數是在0-1之間的,所以可以在其基礎上乘以1000000,然后舍棄小數部分,如果長度不足6位,補0。

select lpad(round(rand()*1000000 , 0), 6, '0');

日期函數

常見的日期函數如下:

演示如下:

A. curdate:當前日期

select curdate();

B. curtime:當前時間

select curtime();

C. now:當前日期和時間

select now();

D. YEAR , MONTH , DAY:當前年、月、日

select YEAR(now()); 
select MONTH(now()); 
select DAY(now());

E. date_add:增加指定的時間間隔

select date_add(now(), INTERVAL 70 YEAR );

F. datediff:獲取兩個日期相差的天數

select datediff('2021-10-01', '2021-12-01');

案例:

查詢所有員工的入職天數,并根據入職天數倒序排序。入職天數,就是通過當前日期 - 入職日期,所以需要使用datediff函數來完成。

select name, datediff(curdate(), entrydate) as 'entrydays' from emp order by 
entrydays desc;

流程函數

流程函數也是很常用的一類函數,可以在SQL語句中實現條件篩選,從而提高語句的效率。

演示如下:

A. if

select if(false, 'Ok', 'Error');

B. ifnull

select ifnull('Ok','Default'); 
select ifnull('','Default'); 
select ifnull(null,'Default');

C. case when then else end

需求: 查詢emp表的員工姓名和工作地址 (北京/上海 ----> 一線城市 , 其他 ----> 二線城市)

select
  name,
  ( case workaddress when '北京' then '一線城市' when '上海' then '一線城市' else
'二線城市' end ) as '工作地址'
from emp;

案例:

create table score(
id int comment 'ID',
name varchar(20) comment '姓名',
math int comment '數學',
english int comment '英語',
chinese int comment '語文'
) comment '學員成績表';
insert into score(id, name, math, english, chinese) VALUES (1, 'Tom', 67, 88, 95
), (2, 'Rose' , 23, 66, 90),(3, 'Jack', 56, 98, 76);

具體的SQL語句如下:

select
id,
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的常見函數我們學習完了,那接下來,我們就來分析一下,在前面講到的兩個函數的案例場景,思考一下需要用到什么樣的函數來實現?

1). 數據庫中,存儲的是入職日期,如 2000-01-01,如何快速計算出入職天數呢? -------->

答案: datediff

2). 數據庫中,存儲的是學生的分數值,如98、75,如何快速判定分數的等級呢? ---------->

答案: case ... when ...

責任編輯:華軒 來源: 今日頭條
相關推薦

2011-04-07 09:06:27

MySQL數據庫密碼

2011-03-03 10:45:34

PureftpdMYSQL

2010-06-13 10:18:08

MySQL 數據庫函數

2010-05-21 10:22:37

MySQL數據庫

2011-07-22 16:59:30

MySQL數據庫嵌套查詢

2011-04-13 15:44:12

SQL Server數函數

2021-06-05 21:29:53

數據庫MySQL函數

2010-05-26 09:44:41

MySQL數據庫使用

2010-05-13 14:07:39

MySQL數據庫

2011-03-28 13:25:27

MySQL數據庫哈希加密

2011-04-01 14:34:31

SQL Server數嵌套子查詢

2020-10-09 15:39:57

數據庫工具技術

2011-08-22 13:04:47

SQL Server數函數

2011-08-22 11:39:53

SQL Server數PIVOT

2010-03-30 17:40:59

Oracle數據庫

2011-03-17 17:27:48

Sybase數據庫引擎

2010-06-04 15:32:18

MySQL數據庫

2017-11-27 11:41:06

python數據庫數據分析

2011-01-20 10:39:09

postfixmysql

2009-06-04 15:59:53

Netbeans操作MMySQL數據庫
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 午夜影院在线观看 | 91av视频 | 国产日韩一区二区 | 九九精品在线 | 午夜精品一区二区三区免费视频 | 国产精品一区二区三区久久 | 国产精品久久久久久久久久久免费看 | 最近中文字幕第一页 | 中文字幕一区在线观看视频 | 国产成人精品免费 | 国产精品激情小视频 | 亚洲欧美激情精品一区二区 | 亚洲综合精品 | 精品成人佐山爱一区二区 | 91伊人 | 国产精品a久久久久 | 精品国产99 | 欧美成视频在线观看 | 天天天天操 | 日日碰狠狠躁久久躁96avv | 日韩在线观看一区 | 成人一区精品 | 欧美一区二区免费在线 | 亚洲一区二区三区桃乃木香奈 | 亚洲91精品 | 精品久久久久国产免费第一页 | 九九热这里只有精品6 | 国产精品久久久久久52avav | 亚洲成人精品一区 | 一区二区三区高清在线观看 | 亚洲伊人久久综合 | 国产精品久久久久久 | 9999在线视频 | 91在线免费观看 | 一区二区三区四区在线视频 | 在线看免费 | 在线播放中文 | 国产精品久久久久久久久久 | 亚洲美女在线一区 | 亚洲视频欧美视频 | 国产一区二区精品自拍 |