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页面嵌入 ...