【SQL】SQL函数

📢 前言

  • 函数 是指一段可以直接被另一段程序调用的程序或代码。主要包括了以下4中类型的函数。
  • 字符串函数
  • 数值函数
  • 日期函数
  • 流程函数

🎄 字符串函数

⭐ 常用函数

函数 功能
CONCAT(S1,S2,...Sn) 字符串拼接,将S1,S2,... Sn拼接成一个字符串
LOWER(str) 将字符串str全部转为小写
UPPER(str) 将字符串 str 全部转为大写
LPAD(str,n,pad) 左填充,用字符串pad对str的左边进行填充,达到n个字符串长度
RPAD(str,n,pad) 右填充,用字符串 pad 对 str 的右边进行填充,达到 n 个字符 串长度
TRIM(str) 去掉字符串头部和尾部的空格
SUBSTRING(str,start,len) 返回从字符串str从start位置起的len个长度的字符串

⭐ 示例

☀ 简单操作

  • 📢 值得注意的是trim是去除前后空格不能去掉中间的空格。
  • 📢 substring第一个位置是 从1开始,而不是0。
sql 复制代码
select concat('Hello','Mysql');
select lower('Linux');
select upper('Linux');
select lpad('01',5,'-');
select rpad('01',5,'-');
select trim(' Hello  Mysql ');
select substring('Hello  Mysql ',1,5);

☀ 由于业务需求变更,企业员工的工号,统一为5位数,目前不足5位数的全部在前面补0。比如: 1号员 工的工号应该为00001。

sql 复制代码
update test.emp set  workno = lpad(workno,5,'0');

🎄 数值函数

⭐ 常用函数

函数 功能
CEIL(x) 向上取整
FLOOR(x) 向下取整
MOD(x,y) 返回x/y的模,也就是余数
RAND() 返回0~1内的随机数
ROUND(x,y) 求参数x的四舍五入的值,保留y位小数

⭐ 示例

☀ 简单操作

  • 📢 随机数可以×或者加上一个数让其保持在某个自定义的区间内。
sql 复制代码
select ceil(1.1);
select floor(1.1);
select mod(7,4);
select rand()*10;
select round(2.345,2);

☀ 通过数据库的函数,生成一个六位数的随机验证码。

sql 复制代码
select lpad(round(rand()*1000000,0),6,'0');
select rpad(round(rand()*1000000,0),6,'0');

🎄 日期函数

⭐ 常用函数

函数 返回起始时间 date1 和 结束时间 date2 之间的天 数 功能
CURDATE() 返回当前日期
CURTIME() 返回当前时间
NOW() 返回当前日期和时间
YEAR(date) 获取指定date的年份
MONTH(date) 获取指定date的月份
DAY(date) 获取指定date的日期
DATE_ADD(date, INTERVAL expr type) 返回一个日期 / 时间值加上一个时间间隔 expr 后的 时间值
DATEDIFF(date1,date2) 返回起始时间 date1 和 结束时间 date2 之间的天 数

⭐ 示例

☀ 简单操作

  • 📢date_add 后面增加的类型是时间单位,比如:year,month,day,week,hour,minute,second
  • 📢 并且这个时间可以是负数的。
sql 复制代码
select curdate();
select curtime();
select now();
select year(now());
select month(now());
select day(now());
select date_add(now(),interval 70 year);
select datediff('2024-10-10','2023-10-09');

☀ 查询所有员工的入职天数,并根据入职天数倒序排序。

sql 复制代码
select name, datediff(now(),entrydate) '天数'  from test.emp order by '天数' desc;

🎄 流程函数

  • 📢 实现条件筛选,从而提高语句的效率。

⭐ 常用函数

函数 功能
IF(value , t , f) 如果 value 为 true ,则返回 t ,否则返回 f
IFNULL(value1 , value2) 如果 value1 不为空,返回 value1 ,否则 返回 value2
CASE WHEN [ val1 ] THEN [res1] ... ELSE [ default ] END 如果 val1 为 true ,返回 res1 , ... 否 则返回 default 默认值
CASE [ expr ] WHEN [ val1 ] THEN [res1] ... ELSE [ default ] END 如果 expr 的值等于 val1 ,返回 res1 , ... 否则返回 default 默认值

⭐ 示例

☀ 简单操作

sql 复制代码
select if(false,'ok','error');
select ifnull('Ok','Default');
select ifnull(null,'Default');

☀ 查询emp表的员工姓名和工作地址

  • 📢 对于展示要求,如果是北京/上海 ----> 一线城市 , 其他 ----> 二线城市
sql 复制代码
select
       name,
       (case when (workaddress='北京' or workaddress = '上海') then '一线城市' else '二线城市' end) '工作地址'
from emp;
select name,if((workaddress='北京' or workaddress = '上海'),'一线城市','二线城市') '工作地址' from emp;
select
       name,
       (case when workaddress='北京' then '一线城市' when workaddress = '上海' then '一线城市' else '二线城市' end) '工作地址'
from emp;

☀ 统计各个学员的成绩

  • 📢 >=85 优秀
  • 📢 >= 60 及格
  • 📢 <60 不及格
  • 首先准备数据
sql 复制代码
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);
注意
  • 📢 这里有个要注意的,当大于等于85匹配,也就是被返回后,将不再参与后续的大于等于60的判断,所有不会影响后续条件的判定。
sql 复制代码
select 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;
相关推荐
Zilliz Planet22 分钟前
GenAI 生态系统现状:不止大语言模型和向量数据库
数据库·人工智能·语言模型·自然语言处理
瓜牛_gn1 小时前
redis详细教程(4.GEO,bitfield,Stream)
数据库·redis·缓存
练习两年半的工程师1 小时前
建立一个简单的todo应用程序(前端React;后端FastAPI;数据库MongoDB)
前端·数据库·react.js·fastapi
新知图书2 小时前
MySQL 9从入门到性能优化-创建触发器
数据库·mysql·性能优化
HEX9CF2 小时前
【SQLite】改善默认输出格式不直观难以阅读问题:通过修改输出设置提升数据可读性
数据库·sqlite
HEX9CF3 小时前
【Linux】SQLite 数据库安装教程(Ubuntu 22.04)
linux·数据库·sqlite
恬淡虚无真气从之3 小时前
django中entity.save(using=)的使用
数据库·python·django
零希3 小时前
正则表达式
java·数据库·mysql
任错错3 小时前
flinksql-Queries查询相关实战
大数据·数据库·mysql·flink·flinksql
Mephisto.java3 小时前
【力扣 | SQL题 | 每日4题】力扣2004, 1454,1613,1709
hive·sql·mysql·leetcode·oracle·database