MySQL——第三章 函数

MySQL------第三章 函数

  • 3.1字符串函数
  • [3.2 数值函数](#3.2 数值函数)
  • [3.3 日期函数](#3.3 日期函数)
  • [3.4 流程函数](#3.4 流程函数)

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

3.1字符串函数

函数 功能
CONCAT(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个长度的字符串

SELECT 函数(参数)

sql 复制代码
select concat('Hello', ' world');
select lower('Hello');
select upper('Hello');

select lpad('01', 5, '+');
select rpad('02', 5, '-');

select substring('Hello Wrold', 2, 3);
select trim('   001  jdka  ');

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

3.2 数值函数

函数 功能
CELL(x) 向上取整
FLOOR(x) 向下取整
MOD(x,y) 返回 x/y 的模
RAND() 返回0~1内的随机数
ROUND(x,y) 求参数 x 的四舍五入的值,保留 y 位小数
sql 复制代码
-- 数值函数
select ceil(1.5);

select floor(1.5);

select mod(10,4);

select rand();

select round(8.8888888,2);

-- 生成6位数的随机验证码
select lpad(round(rand()*1000000,0),6,'0');

3.3 日期函数

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

select year(now());
select month(now());
select day(now());

select date_add(now(),interval 90 month );
select date_add(now(),interval 90 year);

select datediff('2024-1-1',now());

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

3.4 流程函数

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

select ifnull('ok','Error');
select ifnull(null,'Error');

select
   name,
   case workaddress when '北京' then '一线城市' when '上海' then '一线城市' else '二线城市' end
from emp;


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);
select
   id,
   name,
   case when math >= 85 then '优秀' when math >= 60 then '及格' else '不及格' end as '数学',
   case when english >= 85 then '优秀' when math >= 60 then '及格' else '不及格' end as '英语',
   case when chinese >= 85 then '优秀' when math >= 60 then '及格' else '不及格' end as '语文'
from score;
相关推荐
2501_945423541 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
gameboy0313 小时前
从MySQL迁移到PostgreSQL的完整指南
数据库·mysql·postgresql
xdl25993 小时前
Spring Boot中集成MyBatis操作数据库详细教程
数据库·spring boot·mybatis
回到原点的码农3 小时前
Spring Data JDBC 详解
java·数据库·spring
zb200641203 小时前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
CSharp精选营3 小时前
SQL Server安装避坑:这8个奇葩报错你遇到过几个?
数据库·sql server·安装指南·避坑
一勺菠萝丶4 小时前
Flowable + Spring 集成踩坑:流程结束监听器查询历史任务为空 & 获取不到审批意见
java·数据库·spring
RDCJM4 小时前
mysql表添加索引
数据库·mysql
czlczl200209255 小时前
Redis命令处理逻辑模型
数据库·redis·缓存
楼兰胡杨5 小时前
面试题|MySQL 的 3 层主键索引最多能支撑多少数据量
mysql·面试题