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;
相关推荐
眠修14 分钟前
MongoDB 数据库应用
数据库·mongodb
wh_xia_jun1 小时前
mybatis xml 配置中,jdbcType=VARCHAR 的作用
数据库·oracle·tomcat
程序猿小D2 小时前
第24节 Node.js 连接 MongoDB
数据库·mongodb·npm·node.js·编辑器·vim·express
意疏2 小时前
深入解析MySQL Join算法原理与性能优化实战指南
mysql·算法·性能优化
fictionist2 小时前
动态 Web 开发技术入门篇
java·服务器·开发语言·笔记·学习·mysql·spring
果子⌂3 小时前
PostgreSQL --数据库操作
linux·数据库·postgresql
SeaTunnel3 小时前
如何将SeaTunnel MySQL-CDC与Databend 高效整合?格式与方案全解析
数据库·mysql·开源·数据集成·seatunnel·databend
在肯德基吃麻辣烫3 小时前
《Redis》持久化
数据库·redis·缓存
顾三殇4 小时前
【自考】《计算机信息管理课程实验(课程代码:11393)》华师自考实践考核题型解析说明:C++ 与 mysql 实践题型与工具实践题分析
c++·mysql·华师自考实践考核题型分析