(七)函数

函数是指一段可以直接被另一段程序调用的程序或代码

比如:

数据库表中,存储的是入职日期,如2001-11-12,如何快速计算入职天数?

数据库表中,存储的是学生的分数值,如98、75,如何快速判定分数的等级?

1.字符串函数

sql 复制代码
-- concat
select concat('hello', 'MySQL');

-- lower
select lower('HELLO');

-- upper
select upper('hello');

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

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

-- trim
select trim(' hello  mysql ');

-- subtring
select substring('hello mysql', 1, 5);

案例:

sql 复制代码
-- 1.由于业务需求变更,企业员工的工号,统一为5位数,目前不足五位数的全部在前面补0, 比如1号员工的工号应该为00001
update emp set workno = lpad(workno, 5, '0');

2.数值函数

sql 复制代码
-- 数值函数
-- ceil
select ceil(1.1);

-- floor
select floor(1.9);

-- mod
select mod(3, 4);

-- rand
select rand();

-- round
select round(2.345, 2);

案例:

sql 复制代码
-- 通过数据库的函数,生成一个六位数的随机验证码
select lpad(round(rand()*1000000, 0), 6, '0');

3.日期函数

sql 复制代码
-- 日期函数
-- curdate
select curdate();

-- curtime
select curtime();

-- now
select now();

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

select month(now());

select day(now());

-- date_add
select date_add(now(), interval 70 YEAR );
select date_add(now(), interval 70 month );
select date_add(now(), interval 70 day );

-- datediff
select datediff('2021-01-06', '2021-01-01');

案例:

sql 复制代码
-- 查询所有员工的入职天数,并根据入职天数倒序排序。
select name, datediff(curdate(), entrydate) as 'entrydays' from emp order by entrydays desc ;

4.流程函数

sql 复制代码
-- 流程控制函数
-- if
select if(false, 'ok', 'error');

-- ifnull
select ifnull('ok', 'default');
select ifnull('', 'default');
select ifnull(null, 'default');

-- case when then else end
-- 需求:查询emp表的员工姓名和工作地址(北京/ 上海 -----》 一线城市 , 其他 --------》 二线城市)
select
    name,
    (case workaddress when '北京' then '一线城市' when '上海' then '一线城市' else '二线城市' end) as '工作地址'
from emp;

案例:

sql 复制代码
-- 案例:统计班级各个学员的成绩,展示的规则如下:
-- >= 85, 展示优秀
-- >= 60, 展示及格
-- 否则, 展示不及格

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', 50,68,69),
                                                        (2,'MARY',80,81,82),
                                                        (3,'JACK',70,71,72);

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;
相关推荐
TheRouter3 小时前
AI Agent 记忆体系建设实战:短期、长期与工作记忆的工程实现
数据库·人工智能·oracle
Omics Pro4 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
唐青枫4 小时前
MySQL EXISTS 详解:存在性判断、NOT EXISTS 与实战示例
sql·mysql
JAVA面经实录9175 小时前
Hibernate面试题库
数据库·oracle·hibernate
迷枫7125 小时前
DM8 目录结构与常用排查入口梳理
服务器·数据库
日光明媚5 小时前
一步生成视频!One-Forcing:DMD + 零成本 GAN,训练 200 步超越多步 SOTA
android·开发语言·kotlin
帅次6 小时前
Android 17 开发者实战:核心更新与应用场景落地指南
android·java·ios·android studio·iphone·android jetpack·webview
Mr.Daozhi6 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
小程故事多_806 小时前
Claude Code自定义workflow skills用法
数据库·人工智能·智能体
大鹏说大话6 小时前
SQL 排序与分组实战:解决“分组后取最新数据“
android·java·数据库