sql入门4--函数

字符串函数

-----字符串函数-----

concat(s1,s2,....)拼接

select concat('Hello ','Mysql');

#str转换为小写

select lower('HELLO');

str转换为大写

select upper('mysql');

向左侧添加 str 位数 要添加的元素

select lpad('1', 3 ,'-');

向右侧添加 str 位数 要添加的元素

select rpad('2', 3 ,'0');

去除首尾空格

select trim(' 1-1 ');

字符串截取------字符串 起始下标(1起始) 截取几个

select substring('你好啊',2,1);

数值函数

cell--向上取整

select ceil(1.2);

foor--向下取整

select floor(1.2);

mod 取余

select mod(1,2);

rand (0-1之间的随机数)

select rand();

#round ---数四舍五入 保留小数

select round(2.345,2);

随机生成5为位数,验证码

select lpad(round(rand()* 100000,0),5,'0');

日期函数

curdate()--当前日期

select curdate();

curtime()

select curtime();

now()--当前年月日时分秒

select now();

year()--年

select year(now());

month()--月

select month(now());

day()--日

select day(now());

date_add----指定时间到 间隔时间后的 时间

指定时间或当前时间 固定语法interval 60 单为(天-月-年)---当前时间60天后的年月日时分秒

select date_add(now() ,interval 60 day );

datediff 得到两个时间之差

select datediff('2021-12-01','2021-10-01');

获取所有员工入职天数,后降序排序----(别名不用 ' ' 括起来 ---否则降序失效 ,别名带空格特殊字符或保留字则需要 ' ' 引起来)

select name,datediff(curdate(),entrydate) from usertable order by datediff(curdate(),entrydate) desc ;

SELECT name, DATEDIFF(CURDATE(), entrydate) AS 入职天数 FROM usertable ORDER BY 入职天数 desc ;

SELECT name, DATEDIFF(CURDATE(), entrydate) AS zz FROM usertable ORDER BY zz desc ;

流程控制函数-实现条件筛选-提高语句执行效率

if(value , t , f) 如果value为true 则返回t 否则返回f

select if(true,'ok','error');

select if(false,'ok','error');

ifNull(value1 , value2) 如果value1不为空 返回value1 否则返回value2

select ifnull(null,'default');

select ifnull('ok','default');

case when then else end

select name,case worknoaddress when '武汉' then '二线' when '北京' then '一线' else '金庸小说' end as 城市 from usertable;

统计班级学生的成绩

>= 85 优秀 >=60 及格 否则不及格

create table score (

id int comment 'ID',

name varchar(50) comment '姓名',

english int comment '英语',

math int comment '数学',

chinese int comment '语文'

) comment '学员成绩表';

insert into score(id,name,english,math,chinese) values (1,'TOM',67,88,98),(2,'ROSE',23,66,90),(3,'Jack',56,98,76);

select name ,

(case when english >= 85 then '优秀' when english >= 60 then '及格' else '不及格' end) as 英语,

(case when math >= 85 then '优秀' when math >= 60 then '及格' else '不及格' end ) as 数学 ,

( case when chinese >= 85 then '优秀' when chinese >= 60 then '及格' else '不及格' end) as 语文

from score;

相关推荐
a_blue_ice3 小时前
JAVA 面试 MySQL
java·mysql·面试
Java水解6 小时前
【MySQL】数据库基础
后端·mysql
沃夫上校6 小时前
MySQL 中文拼音排序问题
java·mysql
要一起看日出6 小时前
MVCC-多版本并发控制
数据库·mysql·mvcc
Hx__6 小时前
MySQL InnoDB 的 MVCC 机制
数据库·mysql
chat2tomorrow8 小时前
数据采集平台的起源与演进:从ETL到数据复制
大数据·数据库·数据仓库·mysql·低代码·postgresql·etl
依稀i1238 小时前
Spring Boot + MySQL 创建超级管理员
spring boot·mysql
驾驭人生8 小时前
Asp .Net Core 系列:Asp .Net Core 集成 Hangfire+MySQL
数据库·mysql·.netcore
xhbh6669 小时前
不止是DELETE:MySQL多表关联删除的JOIN语法实战详解
数据库·mysql·程序员·mysql删除语句
知其然亦知其所以然9 小时前
面试官微笑发问:第100万页怎么查?我差点当场沉默…
后端·mysql·面试