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;
相关推荐
Dreamboat¿1 小时前
SQL 注入漏洞
数据库·sql
曹牧2 小时前
Oracle数据库中,将JSON字符串转换为多行数据
数据库·oracle·json
被摘下的星星2 小时前
MySQL count()函数的用法
数据库·mysql
末央&2 小时前
【天机论坛】项目环境搭建和数据库设计
java·数据库
徒 花2 小时前
数据库知识复习07
数据库·作业
素玥3 小时前
实训5 python连接mysql数据库
数据库·python·mysql
jnrjian3 小时前
text index 查看index column index定义 index 刷新频率 index视图
数据库·oracle
瀚高PG实验室3 小时前
审计策略修改
网络·数据库·瀚高数据库
言慢行善3 小时前
sqlserver模糊查询问题
java·数据库·sqlserver
韶博雅3 小时前
emcc24ai
开发语言·数据库·python