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;
相关推荐
时差95325 分钟前
【面试题】Hive 查询:如何查找用户连续三天登录的记录
大数据·数据库·hive·sql·面试·database
让学习成为一种生活方式27 分钟前
R包下载太慢安装中止的解决策略-R语言003
java·数据库·r语言
晨曦_子画33 分钟前
编程语言之战:AI 之后的 Kotlin 与 Java
android·java·开发语言·人工智能·kotlin
Mephisto.java33 分钟前
【大数据学习 | kafka高级部分】kafka的优化参数整理
大数据·sql·oracle·kafka·json·database
秋意钟1 小时前
MySQL日期类型选择建议
数据库·mysql
孤客网络科技工作室1 小时前
AJAX 全面教程:从基础到高级
android·ajax·okhttp
山海青风1 小时前
第七篇: BigQuery中的复杂SQL查询
sql·googlecloud
Dxy12393102162 小时前
python下载pdf
数据库·python·pdf
Mr Lee_2 小时前
android 配置鼠标右键快捷对apk进行反编译
android
桀桀桀桀桀桀2 小时前
数据库中的用户管理和权限管理
数据库·mysql