Mysql基础6-常用数据库函数
一、字符串函数
1、常见Mysql内置字符串函数
- concat(s1,s2,s3,...):字符串拼接,将s1,s2,s3...等拼接成一个字符串
 - 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长度的字符串
 
2、函数示例
示例1:concat(s1,s2,s3,...) 函数
mysql> select concat("hello","world");
+-------------------------+
| concat("hello","world") |
+-------------------------+
| helloworld              |
+-------------------------+
1 row in set (0.00 sec)
示例2:lower(str)
mysql> select lower("Hello");
+----------------+
| lower("Hello") |
+----------------+
| hello          |
+----------------+
1 row in set (0.00 sec)
示例3:upper(str)
mysql> select upper("Hello");
+----------------+
| upper("Hello") |
+----------------+
| HELLO          |
+----------------+
1 row in set (0.00 sec)
示例4:lpad(str,n,pad)|
情况一:n小于原始字符串str的长度,只显示原始字符串的长度n的字符
mysql> select lpad("张三",1,"靓仔");
+---------------------------+
| lpad("张三",1,"靓仔")     |
+---------------------------+
| 张                        |
+---------------------------+
1 row in set (0.00 sec)
情况二:当长度n大于str字符串的原始长度,小于拼接后的字符串长度后,显示原来的字符串str+pad继续补齐到n个字符串
mysql> select lpad("张三",3,"靓仔");
+---------------------------+
| lpad("张三",3,"靓仔")     |
+---------------------------+
| 靓张三                    |
+---------------------------+
1 row in set (0.00 sec)
情况三:如果n大于拼接后的字符串长度,会重复拼接pad字符串
mysql> select lpad("张三",6,"靓仔");
+---------------------------+
| lpad("张三",6,"靓仔")     |
+---------------------------+
| 靓仔靓仔张三              |
+---------------------------+
1 row in set (0.00 sec)
示例5:rpad(str,n,pad)
mysql> select rpad("张三",1,"靓仔");
+---------------------------+
| rpad("张三",1,"靓仔")     |
+---------------------------+
| 张                        |
+---------------------------+
1 row in set (0.00 sec)
mysql> select rpad("张三",3,"靓仔");
+---------------------------+
| rpad("张三",3,"靓仔")     |
+---------------------------+
| 张三靓                    |
+---------------------------+
1 row in set (0.00 sec)
mysql> select rpad("张三",6,"靓仔");
+---------------------------+
| rpad("张三",6,"靓仔")     |
+---------------------------+
| 张三靓仔靓仔              |
+---------------------------+
1 row in set (0.00 sec)
情况处理:同lpad情况
示例6:trim(str)
mysql> select trim(" Hello world ");
+-----------------------+
| trim(" Hello world ") |
+-----------------------+
| Hello world           |
+-----------------------+
1 row in set (0.00 sec)
注意:trim只会取出开始和结尾的空格,不会去除中间的空格。
示例7:substring(str,start,len)
mysql> select substring("hello world", 1, 5);
+--------------------------------+
| substring("hello world", 1, 5) |
+--------------------------------+
| hello                          |
+--------------------------------+
1 row in set (0.00 sec)
注意:截取字符串的索引从1开始
示例8:在table_test中对id重新编号,统一显示五位数,不足五位数的前面补0
原始表test数据
mysql> select * from test;
+------+---------+--------------+-----------+
| id | stu_num | stu_name | stu_score |
+------+---------+--------------+-----------+
| 1 | 1 | 张三 | 90 |
| 2 | 2 | 李四 | 87 |
| 3 | 3 | 王五 | 78 |
| 4 | 14 | 赵六 | 83 |
| 5 | 25 | 王二麻子 | 94 |
+------+---------+--------------+-----------+
5 rows in set (0.00 sec)
修改后的数据
mysql> update test set stu_num = lpad(stu_num,5,'0');
Query OK, 5 rows affected (0.01 sec)
Rows matched: 5 Changed: 5 Warnings: 0 mysql> select * from test;
+------+---------+--------------+-----------+
| id | stu_num | stu_name | stu_score |
+------+---------+--------------+-----------+
| 1 | 00001 | 张三 | 90 |
| 2 | 00002 | 李四 | 87 |
| 3 | 00003 | 王五 | 78 |
| 4 | 00014 | 赵六 | 83 |
| 5 | 00025 | 王二麻子 | 94 |
+------+---------+--------------+-----------+
5 rows in set (0.00 sec)
二、数值函数
1、常见数值函数
- ceil(x):向上取整
 - floor(x):向下取整
 - mod(x,y):返回x/y的模
 - rand():返回0-1内的随机数
 - round(x,y):求参数x的四舍五入的值,保留y位小数
 
2、函数示例
示例1:ceil(x):向上取整
mysql> select ceil(1.1);
+-----------+
| ceil(1.1) |
+-----------+
| 2 |
+-----------+
1 row in set (0.00 sec)
示例2:floor(x):向下取整
mysql> select floor(1.9);
+------------+
| floor(1.9) |
+------------+
| 1 |
+------------+
1 row in set (0.00 sec)
示例3:mod(x,y):返回x/y的模
mysql> select mod(5,2);
+----------+
| mod(5,2) |
+----------+
| 1 |
+----------+
1 row in set (0.00 sec)
示例4:rand():返回0-1内的随机数
mysql> select rand();
+---------------------+
| rand() |
+---------------------+
| 0.20385351237268515 |
+---------------------+
1 row in set (0.00 sec)
示例5:round(x,y):求参数x的四舍五入的值,保留y位小数
mysql> select round(3.1415926,2);
+--------------------+
| round(3.1415926,2) |
+--------------------+
| 3.14 |
+--------------------+
1 row in set (0.00 sec)
示例6:综合案例:通过数据库函数,生成一个六位数的随机验证码
mysql> select rpad(round(rand()*1000000, 0),6,'0');
+--------------------------------------+
| rpad(round(rand()*1000000, 0),6,'0') |
+--------------------------------------+
| 192803 |
+--------------------------------------+
1 row in set (0.00 sec)
说明:
1、rand()生成的小数,乘以1000000,才有可能是有六位整数的小数,所以这个时候需要市容round()四舍五入取整数
2、因为rand()生成的小数有可能是0.999999这样的乘以1000000就是6位整数,也有可能生成的小数是0.000009这样的小数就算乘以1000000也不够六位整数
3、所以还需要使用rpad()函数,如果整数不足六位,就在后面补0
三、日期函数
1、常见日期函数
- curdate():返回当前日期
 - curtime():返回当前时间
 - now():返回当前日期和时间
 - year(date):获取指定date的年份
 - month(date):获取指定date的月份
 - day(date):获取指定date的日期
 - date_add(date,interval expr type):返回一个日期/时间值加上一个时间间隔expr后的时间值
 - datediff(date1,date2):返回起始时间date1和结束时间date2之间的天数
 
2、函数示例
示例1:curdate():返回当前日期
mysql> select curdate();
+------------+
| curdate() |
+------------+
| 2023-07-18 |
+------------+
1 row in set (0.00 sec)
示例2:curtime():返回当前时间
mysql> select curtime();
+-----------+
| curtime() |
+-----------+
| 21:52:43 |
+-----------+
1 row in set (0.00 sec)
示例3:now():返回当前日期和时间
mysql> select now();
+---------------------+
| now() |
+---------------------+
| 2023-07-18 21:53:10 |
+---------------------+
1 row in set (0.00 sec)
示例4:year(date):获取指定date的年份
mysql> select year("2023-07-18 21:53:10");
+-----------------------------+
| year("2023-07-18 21:53:10") |
+-----------------------------+
|                        2023 |
+-----------------------------+
1 row in set (0.01 sec)
示例5:month(date):获取指定date的月份
mysql> select month("2023-07-18 21:53:10");
+------------------------------+
| month("2023-07-18 21:53:10") |
+------------------------------+
|                            7 |
+------------------------------+
1 row in set (0.00 sec)
示例6:day(date):获取指定date的日期
mysql> select day("2023-07-18 21:53:10");
+----------------------------+
| day("2023-07-18 21:53:10") |
+----------------------------+
|                         18 |
+----------------------------+
1 row in set (0.00 sec)
示例7:date_add(date,interval expr type):返回一个日期/时间值加上一个时间间隔expr后的时间值
mysql> select date_add("2023-07-18 21:53:10", interval 2 day);
+-------------------------------------------------+
| date_add("2023-07-18 21:53:10", interval 2 day) |
+-------------------------------------------------+
| 2023-07-20 21:53:10                             |
+-------------------------------------------------+
1 row in set (0.01 sec)
mysql> select date_add("2023-07-18 21:53:10", interval 2 month);
+---------------------------------------------------+
| date_add("2023-07-18 21:53:10", interval 2 month) |
+---------------------------------------------------+
| 2023-09-18 21:53:10                               |
+---------------------------------------------------+
1 row in set (0.00 sec)
mysql> select date_add("2023-07-18 21:53:10", interval 2 year);
+--------------------------------------------------+
| date_add("2023-07-18 21:53:10", interval 2 year) |
+--------------------------------------------------+
| 2025-07-18 21:53:10                              |
+--------------------------------------------------+
1 row in set (0.00 sec)
示例8:datediff(date1,date2):返回起始时间date1和结束时间date2之间的天数
mysql> select datediff("2023-07-18 21:53:10", "2023-07-28 21:53:10");
+--------------------------------------------------------+
| datediff("2023-07-18 21:53:10", "2023-07-28 21:53:10") |
+--------------------------------------------------------+
|                                                    -10 |
+--------------------------------------------------------+
1 row in set (0.00 sec)
mysql> select datediff("2023-07-28 21:53:10", "2023-07-18 21:53:10");
+--------------------------------------------------------+
| datediff("2023-07-28 21:53:10", "2023-07-18 21:53:10") |
+--------------------------------------------------------+
|                                                     10 |
+--------------------------------------------------------+
1 row in set (0.00 sec)
四、流程函数
1、常见流程函数
- if(value, t, f):如果value为true,则返回t,否则返回f
 - ifnull(value1,value2):如果value1不为空,返回value1,否则返回value2
 - case when [val1] then [res1]...else[default] end:如果val1为true,则返回res1,否则返回default默认值
 - case[expr] when [val1] then [res1]...else[default] end:如果expr的值等于val1,返回res1,否则返回默认值
 
2、函数示例
示例1:if(value, t, f):如果value为true,则返回t,否则返回f
mysql> select if(1>2,"ok","no");
+-------------------+
| if(1>2,"ok","no") |
+-------------------+
| no |
+-------------------+
1 row in set (0.00 sec)
示例2:ifnull(value1,value2):如果value1不为空,返回value1,否则返回value2
mysql> select ifnull("ok","default");
+------------------------+
| ifnull("ok","default") |
+------------------------+
| ok                     |
+------------------------+
1 row in set (0.00 sec)
mysql> select ifnull("","default");
+----------------------+
| ifnull("","default") |
+----------------------+
|                      |              注意:空字符串不是null
+----------------------+
1 row in set (0.00 sec)
mysql> select ifnull(null,"default");
+------------------------+
| ifnull(null,"default") |
+------------------------+
| default                |
+------------------------+
1 row in set (0.00 sec)
示例3:case [expr] when [val1] then [res1]...else[default] end:如果val1为true,则返回res1,否则返回default默认值
需求:在table_test中,展示姓名和特色一栏,特色根据address的值来设定,北京特色烤鸭,上海特色蟹黄包,西安特色肉夹馍,其他地方都是红烧肉
table_test表原始数据
mysql> select * from table_test;
+------+--------+------+---------+
| id | name | age | address |
+------+--------+------+---------+
| 1 | 刘一 | 18 | 西安 |
| 2 | 陈二 | 19 | 上海 |
| 3 | 张三 | 21 | 北京 |
| 4 | 李四 | 18 | 北京 |
| 5 | 王五 | 21 | 西安 |
| 6 | 赵六 | 22 | NULL |
+------+--------+------+---------+
6 rows in set (0.00 sec)
mysql> select name ,(case address when "北京" then "烤鸭" when "上海" then "蟹黄包" when "西安" then "肉夹馍" else "红烧肉" end) as "特色" from table_test;
+--------+--------------+
| name | 特色 |
+--------+--------------+
| 刘一 | 肉夹馍 |
| 陈二 | 蟹黄包 |
| 张三 | 烤鸭 |
| 李四 | 烤鸭 |
| 王五 | 肉夹馍 |
| 赵六 | 红烧肉 |
+--------+--------------+
6 rows in set (0.00 sec)
示例4:需求:在学生成绩表中,根据成绩展示优秀,良好一般。
学生成绩表(test)原始数据
mysql> select * from test;
+------+---------+--------------+-----------+
| id | stu_num | stu_name | stu_score |
+------+---------+--------------+-----------+
| 1 | 00001 | 张三 | 90 |
| 2 | 00002 | 李四 | 87 |
| 3 | 00003 | 王五 | 78 |
| 4 | 00014 | 赵六 | 83 |
| 5 | 00025 | 王二麻子 | 94 |
+------+---------+--------------+-----------+
5 rows in set (0.00 sec)
mysql> select stu_name, (case when stu_score>=90 then "优秀" when stu_score >=80 then "良好" when stu_score >=70 then
"一般" when stu_score >=60 then "及格" else "不及格" end) as "成绩" from test;
+--------------+--------+
| stu_name | 成绩 |
+--------------+--------+
| 张三 | 优秀 |
| 李四 | 良好 |
| 王五 | 一般 |
| 赵六 | 良好 |
| 王二麻子 | 优秀 |
+--------------+--------+
5 rows in set (0.00 sec)
Mysql基础6-常用数据库函数的更多相关文章
- MySQL基础操作&&常用的SQL技巧&&SQL语句优化
		
基础操作 一:MySQL基础操作 1:MySQL表复制 复制表结构 + 复制表数据 create table t3 like t ...
 - mysql基础知识&&常用命令
		
了解 什么是数据库?什么是数据管理系统?什么是SQL,他们之间的关系又是什么? 数据库 英文单词DataBase,简称DB,按照一定格式存储数据的一些文件的组合. 顾名思义:存储数据的仓库,实际上就是 ...
 - MySQL基础之   恢复数据和数据库迁移
		
1.mysql命令或者source命令恢复数据 这两个命令在进行恢复数据的时候要检查是否创建数据库.如果数据库不存在,则恢复失败. 数据库迁移 1.相同版本的mysql数据库之间的迁移. mysqld ...
 - MySql 基础知识-常用命令及sql语句
		
一.常用mysql命令行命令 1,启动mysql服务 net start mysql. 停止mysql服务 net stop mysql 2,netstart -na|findstr 330 ...
 - MySql基础(常用)
		
MySQL常用语句 1.查看当前所有数据库 show databases; 2.打开指定的库 use 库名; 3.查看当前库中的所有表 show tables; 4.查看其他库的表 show tabl ...
 - MYSQL基础操作之数据约束与关联查询
		
一.MYSQL约束 1.默认值约束,当字段没有插入值的时候,mysql自动给该字段分配默认值. 默认值的字段允许为空. 对默认值字段也可以插入null. CREATE TABLE STUDENT( I ...
 - MySQL基础之常用函数
		
数学函数的使用 常用数学函数 函数 作用 函数 作用 ceil() 进一取整 abs() 取绝对值 floor() 舍掉小数部分 power() 幂运算 round() 四舍五入 pi() 圆周率 t ...
 - MYSQL基础常见常用语句200条
		
数据库 # 查看所有的数据库 SHOW DATABASES ; # 创建一个数据库 CREATE DATABASE k; # 删除一个数据库 DROP DATABASE k; # 使用这个数据库 US ...
 - MySQL基础2——常用命令
		
注意:MySQL在centos中安装的是5.7版本的,编辑MySQL时会有个报错,需要执行: set @@global.sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN ...
 - MySQL基础学习之数据查询
		
一般查询 SELECT * FROM 表名 SELECT 属性名 FROM 表名 条件查询 SELECT 属性名 FROM 表名 WHERE 条件表达式 查询数据值1,数据值2的表单 SELEC ...
 
随机推荐
- 联系我们html代码
			
Syntor by Aceto 11 Boleyn Court, Manor Park, Runcorn, Chesire WA7 1SR +44 (0) 1928 579865 + 44 (0) 1 ...
 - Puppeteer+RabbitMQ:Node.js 批量加工pdf服务架构设计与落地
			
全文约8500字,阅读时长约10分钟. 智慧作业最近上线「个性化手册」(简称个册)功能,一份完整的个性化手册分为三部分: •学情分析:根据学生阶段性的学习和考试情况进行学情分析.归纳.总结,汇总学情数 ...
 - MAPPO学习笔记(1):从PPO算法开始
			
由于这段时间的学习内容涉及到MAPPO算法,并且我对MAPPO算法这种多智能体算法的信息交互机制不甚了解,于是写了这个系列的笔记,目的是巩固知识,并且进行一些粗浅又滑稽的总结. 1.PPO算法的介绍 ...
 - vue2路由导航守卫(钩子函数)
			
https://router.vuejs.org/zh/guide/advanced/navigation-guards.html#%E5%85%A8%E5%B1%80%E5%89%8D%E7%BD% ...
 - 一天吃透Redis面试八股文
			
Redis连环40问,绝对够全! Redis是什么? Redis(Remote Dictionary Server)是一个使用 C 语言编写的,高性能非关系型的键值对数据库.与传统数据库不同的是,Re ...
 - 如何在SpringBoot项目中兼容Jersey和SpringMVC框架?
			
文章目录 Jersey框架介绍 常用的注解: SpringBoot中SpringMVC兼容Jersey 整合Jersey REST(Representational State Transfer)表象 ...
 - Python潮流周刊#1:如何系统地自学Python?
			
这里记录每周值得分享的 Python 及通用技术内容,部分内容为英文,已在小标题注明.(本期标题取自其中一则分享,不代表全部内容都是该主题,特此声明.) 文章&教程 1.编程语言的错误处理模式 ...
 - Selenium - 浏览器操作
			
Selenium - 浏览器操作 获取浏览器信息 from selenium import webdriver driver = webdriver.Chrome() driver.get(" ...
 - group_concat 自定义聚合查询
			
group_concat
 - Iframe在Vue中的状态保持技术
			
引言 Iframe是一个历史悠久的HTML元素,根据MDN WEB DOCS官方介绍,Iframe定义为HTML内联框架元素,表示嵌套的Browsing Context,它能够将另一个HTML页面嵌入 ...