SQL-函数

1、字符串函数

sql 复制代码
# 字符函数
select concat('hello' , ' mysql!');
select lower('HELLO');
select upper('hello');
select lpad('01',5,'-');# 左填充
select rpad('01',5,'-');# 右填充
select trim('  hello mysql ! ');# 去除前后空格
select substring('hello mysql!',1,7);# 截取一部分字符前7个,索引从1开始

#  补充工号为5位,前面补充0
desc employee;
select * from employee;
update employee set workno = lpad(workno,5,'0') where workno<10000;

2、数值函数

sql 复制代码
# 数值函数
select ceil(1.7); # 向上取整
select floor(1.1); # 向下取整
select mod(7,4); # 求余数
select rand(); # 0-1之间随机数
select round(2.35677,2); # 四舍五入,保留两位

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

3、日期函数

sql 复制代码
# 日期函数
select curdate();# 当前日期  2024-08-27
select curtime(); # 当前时间
select  now(); # 当前日期和时间 2024-08-27 09:10:02
select year(now()); # 年
select month(now());# 月
select day(now());#日
select date_add(now(),interval 7 day); #2024-09-03 09:09:48
select datediff('2024-09-01','2024-10-02');# 返回相差的天数


# 查询全部人的入职天数,并根据天数倒序排序
select * from employee;
update employee set entrydate='2019-09-07' where workno ='00066';
update employee set entrydate='2019-09-08' where workno ='00067';

select  name,workno,datediff(curtime(),entrydate) days from employee order by days desc;
select  name,workno,datediff(curtime(),entrydate) as 'entrydays' from employee order by entrydays desc;

4、流程函数

sql 复制代码
# 流程函数
select if(true,'ok','error'); # 第一个参数条件语句true则返回第二个参数,否则第三个
select if(1=2,'ok','error');
select if(1=1,'ok','error');
select  ifnull('ok','Default');# 判断第一个参数是否为空,非空返回第一个,否则第二个
select  ifnull(null,'Default');


alter table employee add ip varchar(10) comment '地址';
update employee set ip ='北京' where workno=66;
update employee set ip ='武汉' where workno=67;
# 查询姓名和地址(北京---->政治中心,其他------->金融中心)
select
    name,
    (case ip
        when '北京' then '政治中心'
        when '上海' then '金融中心'
        else '其他'
        end) as 'IP属性'
from employee
order by IP属性 desc;




# 统计成绩给出等级
create table score(
    id int comment 'id',
    name varchar(5) comment '姓名',
    math int comment'数学',
    english int comment '英语',
    chinese int comment'语文'
)comment'学院成绩表';
insert into score (id,name,math,english,chinese)
values(1,'tom',67,46,36),(2,'jim',23,56,78),(3,'alice',78,99,65),(4,'momo',67,87,75);
select
    id,
    (case when math>=85 then 'A'when math>=60 then 'B' else 'C' end) '数学',
    (case when english>=85 then 'A'when english>=60 then 'B' else 'C' end) '英语',
    (case when chinese>=85 then 'A'when chinese>=60 then 'B' else 'C' end) '语文'
from score;
相关推荐
诸神黄昏EX10 分钟前
Android 常用命令和工具解析之GPU相关
android
顾北川_野11 分钟前
Android 布局菜单或按钮图标或Menu/Item设置可见和不可见
android
练习本11 分钟前
android 动画原理分析
android
别拿曾经看以后~12 分钟前
原生Android调用uniapp项目中的方法
android·vue.js·uni-app
Winston Wood12 分钟前
Android Binder技术概览
android·binder·进程通信
m0_7482302112 分钟前
mysql约束和高级sql
数据库·sql·mysql
踏雪羽翼16 分钟前
android 使用实现音效--Equalizer
android·音效·eqequalizer·bassboost·presetreverb
刘艳兵的学习博客19 分钟前
刘艳兵-DBA046-ASSM表空间的全表扫描范围由哪些因素综合确定?
数据库·sql·oracle·刘艳兵
老码沉思录19 分钟前
Android开发实战班 - Android开发基础之 Kotlin语言基础与特性
android·微信·kotlin
2401_8576363921 分钟前
实验室管理技术革新:Spring Boot系统
数据库·spring boot·后端