当前位置: 首页 > news >正文

【JavaWeb后端学习笔记】MySQL的常用函数(字符串函数,数值函数,日期函数,流程函数)

MySQL函数

  • 1、字符串函数
  • 2、数值函数
  • 3、日期函数
  • 4、流程函数

1、字符串函数

函数说明
concat(s1, s2, …, sn)字符串拼接,将 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 个长度的字符串,索引从 1 开始
-- concat
select concat('hello', 'MySQL');-- lower
select lower('Hello');-- upper
select upper('Hello');-- lpad
select lpad('hhh', 5, '-');-- rpad
select rpad('hhh', 5, '-');-- trim
select trim('  Hello MySQL!  ');-- substring
select substring('Hello MySQL', 1, 5);

2、数值函数

函数说明
ceil(x)向上取整
floor(x)向下取整
mod(x, y)返回 x/y 的模
rand()返回 0~1 内的随机数
round(x, y)求参数 x 的四舍五入的值,保留 y 为小数
-- ceil
select ceil(1.1);-- floor
select floor(1.1);-- mod
select mod(7, 4);-- rand
select rand();-- round
select round(1.254, 1);

3、日期函数

函数说明
curdate()返回当前日期(年-月-日)
curtime()返回当前时间(时-分-秒)
now()返回当前日期和时间
YEAR(date)获取指定 date 的年份
MONTH(date)获取指定 date 的月份
DAY(date)获取指定 date 的日期
DATE_ADD(date, INTERVAL expr type)返回一个日期/时间值加上一个时间间隔 expr 后的时间值
datediff(date1, date2)返回起始时间 date1 和结束时间 date2 之间的天数
-- curdate
select curdate();-- curtime
select curtime();-- now
select now();-- YEAR
select YEAR(now());-- MONTH
select MONTH(now());-- DAY
select DAY(now());-- DATE_ADD
select DATE_ADD(now(), INTERVAL 10 DAY);-- datediff
select datediff('2021-10-01', '2021-06-01');

4、流程函数

函数说明
if(value, t, f)如果 value 为 true, 则返回 t, 否则返回 f
ifnull(value1, value2)如果 value1 不为空, 返回 value1, 否则返回value2
case when [val1] then [res1] when [val2] then [res2] … else [default] end如果 val1 为 true, 返回 res1,…,否则返回 default 默认值
case [expr] when [val1] then [res1] when [val2] then [res2] … else [default] end如果 expr 的值等于 val1,返回 res1,…,否则返回 default 默认值
-- if(value, t, f)
select if(true, 'True', 'False');
select if(false, 'True', 'False');-- ifnull(value1, value2)
select ifnull('OK', 'Default');
select ifnull('', 'Default');
select ifnull(null, 'Default');-- case when [val1] then [res1] when [val2] then [res2] ... else [default] end
select id, name,(case when math >= 85 then '优秀' when math >= 60 then '及格' else '不及格' end) as math,(case when english >= 85 then '优秀' when english >= 60 then '及格' else '不及格' end) as english,(case when chinese >= 85 then '优秀' when chinese >= 60 then '及格' else '不及格' end) as chinese
from score;-- case [expr] when [val1] then [res1] when [val2] then [res2] ... else [default] end
selectid,name,(case address when '北京' then '一线城市' when '上海' then '一线城市' else '二线城市' end) as address
from tb_emp;
http://www.lryc.cn/news/514098.html

相关文章:

  • 【推送】主流的服务端推送技术的对比
  • 直观解读 JuiceFS 的数据和元数据设计(一)
  • nginx配置文件没有语法颜色
  • PCB层叠结构设计
  • 电子应用设计方案83:智能 AI 打印机系统设计
  • windows安装rsync Shell语句使用rsync
  • Django 模型
  • CentOS — 压缩解压
  • OpenGL变换矩阵和输入控制
  • LCS最长公共子序列C++实现
  • 深入刨析数据结构之排序(上)
  • 【无重复字符的最长子串】
  • Vue3+Element Plus的表格分页实战
  • vue项目搭建规范
  • Mac iTerm2集成DeepSeek AI
  • 检索增强生成(RAG)
  • 【第二部分--Python之基础】03 容器类型的数据
  • 【人工智能机器学习基础篇】——深入详解深度学习之复杂网络结构:卷积神经网络(CNN)、循环神经网络(RNN)、生成对抗网络(GAN)等概念及原理
  • MySQL 入门教程
  • 【sql】CAST(GROUP_CONCAT())实现一对多对象json输出
  • QT:控件属性及常用控件(1)------核心控件及属性
  • 使用 Python结合ffmpeg 实现单线程和多线程推流
  • Linux一些问题
  • 在 Ubuntu 24.04.1 LTS | Python 3.12 环境下部署 Crypto 库
  • HTML5实现好看的二十四节气网页源码
  • C++(9)—类和对象(上) ②实例化
  • Effective C++读书笔记——item2(const,enum,inlines取代#define)
  • 如何科学评估与选择新版本 Python 编程语言和工具
  • 第十届“挑战杯”大学生课外学术科技作品竞赛解析及资料
  • 【门铃工作原理】2021-12-25