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 ...
随机推荐
- FBV和CBV的区别(源码分析)
FBV和CBV源码分析 FBV直接调用user方法执行业务代码 CBV相当于在FBV上面封装了一层 from django.contrib import admin from django.urls ...
- Java SpringBoot 7z 压缩、解压
Java SpringBoot 7z 压缩.解压 cmd 7z 文件压缩 7z压缩测试 添加依赖 <dependency> <groupId>org.apache.common ...
- 详解 APISIX Lua 动态调试插件 inspect
作者罗锦华,API7.ai 技术专家/技术工程师,开源项目 pgcat,lua-resty-ffi,lua-resty-inspect 的作者. 原文链接 为什么需要 Lua 动态调试插件? Apac ...
- 关于页面重定向https安全漏洞和服务器SSH加密算法漏洞
1.HTTP 严格传输安全 nginx配置 add_header Strict-Transport-Security "max-age=63072000; includeSubdomains ...
- 【介绍】.NET新加特性介绍
简介 当下的.Net新版本引进了几种新特性,包括全局命名空间引用.可空引用类型和顶级语句.这些特性在一定程度上改善了 .NET 平台的开发效率, 对于短小精干的小程序,这些新的特性无疑可以把开发效 ...
- SpringBoot 集成 SpringSecurity + MySQL + JWT 附源码,废话不多直接盘
SpringBoot 集成 SpringSecurity + MySQL + JWT 无太多理论,直接盘 一般用于Web管理系统 可以先看 SpringBoot SpringSecurity 基于内存 ...
- #Python pandas库,读取模块,代码笔记
日常数据清洗中,利用python清洗的第一步就是读取对应文件,今天一起复盘一下数据读取环节的常规操作. csv和xlsx格式读取类似,所以用csv做案例 X-MIND图
- 2022-12-03:部门工资最高的员工。以下数据Max 和 Jim 在 IT 部门的工资都是最高的,Henry 在销售部的工资最高。sql语句如何写? 输出结果如下: department emp
2022-12-03:部门工资最高的员工.以下数据Max 和 Jim 在 IT 部门的工资都是最高的,Henry 在销售部的工资最高.sql语句如何写? 输出结果如下: department empl ...
- vue全家桶进阶之路13:生命周期
Vue2的生命周期是指Vue实例从创建.挂载.更新.销毁等各个阶段中所经历的一系列过程.Vue2的生命周期共有8个阶段,分别是: beforeCreate:Vue实例被创建之前的阶段,此时Vue实例的 ...
- OpenAI 官宣首个 ChatGPT iOS 应用
最近,OpenAI 宣布推出官方 iOS 应用,允许用户随时随地访问其高人气 AI 聊天机器人,此举也打破了近几个月内苹果 App Store 上充斥似是而非的山寨服务的窘境. 该应用程序是 Chat ...