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); 1D. 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语句如下:
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的常见函数我们学习完了,那接下来,我们就来分析一下,在前面讲到的两个函数的案例场景,思考一下需要用到什么样的函数来实现?
1). 数据库中,存储的是入职日期,如 2000-01-01,如何快速计算出入职天数呢? -------->
答案: datediff
2). 数据库中,存储的是学生的分数值,如98、75,如何快速判定分数的等级呢? ---------->
答案: case ... when ...
关键词:
函数是指一段可以直接被另一段程序调用的程序或代码。也就意味着,这一段程序或代码在MySQL中已经给我们提
新华社罗马5月28日电(黎梦青)第106届环意大利自行车赛28日在罗马结束全程,珍宝车队来自斯洛文尼亚车手普
近期出栏毛鸡保持盈利状态,养殖户低价补栏心态积极,鸡苗市场交投节奏加快。截至29日,5月下旬鸡苗均价2 6
在政策、技术创新与应用、公众参与和多方参与与合作机制创新等方面,扬州的“净塑”经验和成果对长三角其他
当地时间5月28日,美国总统拜登在回答记者提问时表示,美国不会彻底取消债务上限。这一表态是在他宣布已经
新华社北京5月28日电2023赛季中超联赛第十轮28日结束5场争夺,北京国安队客场被浙江队逆转,遭遇近7轮首负
稳定为主品质为要——今年一季度房地产市场形势简析,购房,商品房,房地产业,商品住房,房地产市场
海南日报定城5月28日电(记者李豌通讯员程守满朱望佳张博)5月27至28日,2023海南(定安)端午美食文化季之
大华股份:大模型技术提升智慧物联行业生产力,C114讯5月29日消息(颜翊)大华股份近日披露投资者关系活动记
(图片来源经传软件)投资最重要的就是不要亏钱,话是这么讲,但是没有具体的标准的话,实行起来也是一头雾
1、珠海长隆没有水上乐园。2、只有海洋王国和马戏城。3、广州才有水上乐园。4、你想问的是海洋王国吧?*海洋
北京时间5月29日早间消息,据报道,上周五,美国一家公关公司起诉Twitter,因为自马斯克收购Twitter以来,T
记者从甘肃省人社厅获悉,为满足民营企业和新兴业态职称评价需求,甘肃省人社厅面向全省民营企业开展工程系
前不久,刚刚公布的截止到去年年底的数据显示,上海户籍人口当中,60岁以上人口占总人口的比例已经达到了36 8%
1、强调服务的重要性。2、没有范文。3、以下供参考,主要写一下主要的工作内容,如何努力工作,取得的成绩
今天来聊聊关于当代风采人物评选活动已产生最后三名候选人作文题目审题立意,2016年高考全国卷乙卷语文作文
倾听儿童相伴成长暨第一片区幼儿园走进怀北镇中心幼儿园观摩交流为优化教师组织半日活动的能力,有效促进教
1、国产石英表,质量还行,因为机芯都一样,尤其石英表只要不砸一般不会坏。2、基本百年。本文为大家分享到
据“飞常准”消息,大熊猫丫丫已搭乘南航CZ2489航班,于5月28日20:46从上海虹桥机场出发,飞赴北京。该航班预计2
爱尔眼科5月28日公告,公司拟使用自有资金以集中竞价交易方式回购公司部分社会公众股份,用于实施股权激励