【实用教程】MySQL内置函数
1 背景
在MySQL查询等操作过程中,我们需要根据实际情况,使用其提供的内置函数。今天我们就来一起来学习下这些函数,在之后的使用过程中更加得心应手。
2 MySQL函数
2.1 字符串函数
常用的函数如下:
| concat(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) | 去掉字符串头部和尾部的空格 |
| substr(str,start,len) | 截取从字符串str从start位置起的len个长度的字符串 |
| concat(s1,s2,…sn) | 字符串拼接 |
| lower(str) | 将字符串str全部转换为小写 |
| ## group_concat(…) | 函数用于将查询结果集中的多行数据连接成一个字符串 |
简单使用实例:
select concat('hello','world');select lower('Hello');select upper('hello');select lpad('hello',10,'-');select rpad('hello',10,'-');select trim(' hello w '); -- 从第一位开始截取,截取5位
select substr('hello world',1,5);`
使用场景:
由于业务需求变更,人员的id,统一为5位数,不足5位数的全部在前边补0,比如1的人员id需要修改为00001;
-- 使用lpad进行填充select lpad(id, 5, '0') as id from user;
注意 concat 和group_concat的使用:
CONCAT 函数:CONCAT 函数用于连接两个或多个字符串。它接受任意数量的参数,将这些参数按顺序连接起来,并返回一个包含所有参数连接结果的字符串。例如:
SELECT CONCAT('Hello', ' ', 'World'); -- 输出: 'Hello World'
GROUP_CONCAT 函数:GROUP_CONCAT 函数用于将查询结果集中的多行数据连接成一个字符串。它通常与 GROUP BY 语句一起使用,用于将分组后的多行数据连接成一个字符串,每个分组的数据用指定的分隔符隔开。如:
SELECT GROUP_CONCAT(column_name SEPARATOR ', ') FROM table_name GROUP BY group_column;
在这个例子中,column_name 是需要连接的列,group_column 是分组的列,SEPARATOR 是用于分隔连接结果的字符串。
2.2 数值函数
常用的数值函数如下(在实际工作中使用较少):
| ceil(x) | 向上取整 |
|---|---|
| floor(x) | 向下取整 |
| mod(x,y) | 返回x/y的模 |
| rand() | 返回0~1内的随机数 |
| round(x,y) | 求参数x的四舍五入的值,保留y位小数 |
2.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之间的天数 |
| date_format(date, format) | 将日期格式化为指定格式 |
简单使用实例:
select curdate();
select curtime();
select now();
select year('2023-07-21 12:31:45');
select month('2023-07-21 12:31:45');
select day('2023-07-21 12:31:45'); -- 获取当前时间往后推10年的时间
select date_add(now(), interval 10 year); select datediff('2023-07-21 12:31:45', '2020-07-21 0:0:45');
date_format中一些常用的日期格式化符号:
-
%Y:四位年份(例如:2023)
-
%m:两位月份(01 到 12)
-
%d:两位日期(01 到 31)
-
%H:24小时制的小时(00 到 23)
-
%i:两位分钟(00 到 59)
-
%s:两位秒数(00 到 59)
如果你想将日期字段 order_date 格式化为 'YYYY-MM-DD' 的形式,你可以这样使用 DATE_FORMAT 函数
SELECT DATE_FORMAT(order_date, ‘%Y-%m-%d’) AS formatted_date FROM orders;
在这个查询中,order_date 会被格式化成 ‘YYYY-MM-DD’ 的形式,并且结果会以 formatted_date 的别名返回。
还可以使用 DATE_FORMAT 函数来处理日期时间字段,例如将日期时间字段格式化为 'YYYY-MM-DD HH:MM:SS' 的形式:
SELECT DATE_FORMAT(order_datetime, ‘%Y-%m-%d %H:%i:%s’) AS formatted_datetime FROM orders;
2.4 流程控制函数
常用的流程控制函数如下:
| 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,否则返回default默认值 |
select *, if(city = '北京','bj','other')
as city_name
from user; select *,
case when city = '北京' then 'bj' else 'other' end
as city_name2
from user;
3 其他注意
使用MySQL内置函数时,确实有一些需要注意的地方,特别是在处理大量数据时,可以影响查询的效率:
3.1 索引的使用:
- 如果在查询条件中使用了函数,可能会导致索引无法使用。例如,WHERE YEAR(date_column) = 2023 中的YEAR()函数可能导致无法使用date_column上的索引。在可能的情况下,尽量避免在查询条件中使用数。
3.2 函数的嵌套:
- 函数的嵌套使用可能会增加查询的复杂度。例如,嵌套了多层函数的查询可能会导致性能下降。在编写复杂查询时,确保函数的嵌套使用合理,不要过度复杂化查询。
3.3 数据类型转换:
- 函数可能引发数据类型转换,这可能导致不必要的性能开销。例如,在字符串和数字之间进行转换可能会消耗一定的性能。在使用函数时,注意函数返回值的数据类型,尽量避免不必要的数据类型转换。
3.4 使用合适的函数:
- 使用合适的函数能够提高查询的效率。例如,在字符串拼接时,使用CONCAT()函数通常比使用+运算符更高效。了解函数的具体功能和适用场景,选择合适的函数可以提高查询性能。
3.5 聚合函数的合理使用:
- 当使用聚合函数(如SUM()、COUNT()等)时,注意是否需要在查询中使用GROUP BY语句。不合理的聚合函数使用可能导致结果不符合预期,也可能导致性能下降。
3.6 使用EXPLAIN语句分析查询计划:
- 使用EXPLAIN语句可以分析查询的执行计划,了解MySQL是如何执行查询的。通过分析查询计划,可以发现是否有不合理的函数使用或索引未使用等问题,从而优化查询性能。
总之,合理使用MySQL内置函数是可以提高查询效率的,但在使用时需要根据具体情况选择合适的函数,同时,通过使用EXPLAIN语句分析查询计划,可以帮助你发现潜在的性能问题并进行优化。
关注我,我们一起学习。

相关文章:
【实用教程】MySQL内置函数
1 背景 在MySQL查询等操作过程中,我们需要根据实际情况,使用其提供的内置函数。今天我们就来一起来学习下这些函数,在之后的使用过程中更加得心应手。 2 MySQL函数 2.1 字符串函数 常用的函数如下: concat(s1,s2,…sn)字符串…...
第十二节——ref
一、概念 ref 被用来给DOM元素或子组件注册引用信息。引用信息会根据父组件的 $refs 对象进行注册。如果在普通的DOM元素上使用,引用信息就是元素; 如果用在子组件上,引用信息就是组件实例。 注意:只要想要在Vue中直接操作DOM元素ÿ…...
少儿编程 2023年9月中国电子学会图形化编程等级考试Scratch编程四级真题解析(判断题)
2023年9月scratch编程等级考试四级真题 判断题(共10题,每题2分,共20分) 11、运行程序后,变量"result"的值是6 答案:对 考点分析:考查积木综合使用,重点考查自定义积木的使用 图中自定义积木实现的功能是获取两个数中最大的那个数并存放在result变量中,左…...
【设计模式三原则】
设计模式三原则 单一职责原则开放封闭原则依赖倒转原则里氏代换原则 我们在进行程序设计的时候,要尽可能地保证程序的可扩展性、可维护性和可读性,所以需要使用一些设计模式,这些设计模式都遵循了以下三个原则,下面来依次为大家介…...
600MW发电机组继电保护自动装置的整定计算及仿真
摘要 随着科技的发展,电力已成为最重要的资源之一,如何保证电力的供应对于国民经济发展和人民生活水平的提高都有非常重要的意义。在电能输送过程中,发电机组是整个过程中最重要的一个基本元素,在电力系统中的输送和分配中被广泛应…...
【蓝桥每日一题]-字符串(保姆级教程 篇1)#atcoder324C~E题
今天来讲字符串题型 目录 题目:atcoder324C题 思路: 题目:atcoder324D题 思路: 题目:atcoder324E题 思路: 题目:atcoder324C题 给一个T字符串,然后给出n个S串,对…...
4.2.1 SQL语句、索引、视图、存储过程
怎么执行一条select语句 1.连接器 接收连接-》管理连接-》校验用户信息 2.查询缓存 kv存储,命中直接返回,否则继续执行 8.0已经删除 3.分析器 词法句法分析生成语法树 4.优化器 指定执行计划,选择查询成本最小的计划 5.执行器 根据执行计划&a…...
1992-2021年全国各地级市经过矫正的夜间灯光数据(GNLD、VIIRS)
1992-2021年全国各地级市经过矫正的夜间灯光数据(GNLD、VIIRS) 1、时间:1992-2021年3月,其中1992-2013年为年度数据,2013-2021年3月为月度数据 2、来源:DMSP、VIIRS 3、范围:分区域汇总&…...
机器人的触发条件有什么区别,如何巧妙的使用
简介 维格机器人触发条件,分为3个,分别是: 有新表单提交时、有记录满足条件时、有新的记录创建时 。 看似3个,其实是能够满足我们非常多的使用场景。 本篇将先介绍3个条件的触发条件,然后再列举一些复杂的触发条件如何用现有的触发条件来满足 注意: 维格机器人所有的…...
【Qt6】QStringList
2023年10月31日,周二上午 QStringList 是 Qt 中的一个类,用于存储一组字符串。它提供了一些方便的方法来操作和管理字符串列表。 QStringList 可以用于存储任意数量的字符串,并提供了一些常用的操作,例如添加、删除、查找、排序等…...
代码随想录算法训练营第五十三天|309.最佳买卖股票时机含冷冻期 ● 714.买卖股票的最佳时机含手续费
309. 买卖股票的最佳时机含冷冻期 int maxProfit(int* prices, int pricesSize){int len pricesSize;int dp[len][4];dp[0][0] -prices[0];dp[0][1] 0;dp[0][2] 0;dp[0][3] 0;for (int i 1; i < pricesSize; i){dp[i][0] fmax(dp[i-1][0], fmax(dp[i-1][1] - prices…...
厚黑学笔记
厚黑学 我现在的情况就是在听书听到一半,但在软件上看书已经看完了,厚黑学要讲的东西大概已经摸清楚了。 总体来说,厚黑学里面的章节内容有一点沾边的嫌疑(看完后的想法),但这本书还是有值得阅读的,但主讲…...
IDEA MyBatisX插件介绍
一、前言 前几年写代码的时候,要一键生成DAO、XML、Entity基础代码会采用第三方工具,比如mybatis-generator-gui等,现在IDEA或Eclipse都有对应的插件,像IDEA中MyBatisX就是一个比较好用的插件。 二、MyBatisX安装配置使用 MyBa…...
【PyQt学习篇 · ②】:QObject - 神奇的对象管理工具
文章目录 QObject介绍Object的继承结构测试QObject对象名称和属性QObject对象名称和属性的操作应用场景 QObject父子对象QObject父子对象的操作 QObject的信号与槽QObject的信号与槽的操作 QObject介绍 在PyQt中,QObject是Qt框架的核心对象之一。QObject是一个基类…...
【AcWing】1.1.3二分搜索
一、二分搜索 1、查找数的范围 原题链接 这道题看似是二分搜索的题目,实则就是二分搜索。与一般的搜索不同的是,若查找元素重复,则分别返回重复元素的左端下标和右端下标,若不存在则返回“-1 -1。我们常用的二分搜索是返回的…...
【Python第三方包】串口通信(pySerial包)
文章目录 前言一、串口的基本使用1.1 配置串口基本信息1.2 读取串口数据1.3 写串口1.4 关闭串口二、示例代码2.1 示例1: 从串口读取数据2.2 示例2: 向串口写入数据总结前言 串口通信是许多嵌入式和物联网应用中的关键组成部分。Python 提供了许多第三方库来简化串口通信的实现…...
VS Code2023安装教程(最新最详细教程)附网盘资源
目录 一.简介 二.安装步骤 三.VS Code 使用技巧 网盘资源见文末 一.简介 VS Code是一个由微软开发的跨平台的轻量级集成开发环境(IDE),被广泛用于编写各种编程语言的代码。它支持多种编程语言,并且可以通过插件扩展功能。 以…...
最优值函数
一、最优状态值函数 解决强化学习任务大致上意味着找到一种政策,能够在长期内实现很多奖励。对于有限MDPs,我们可以精确地定义一种最优政策,其定义如下。值函数定义了政策的一种部分排序。如果一个政策的预期回报大于或等于另一个政策π0在所…...
软考系统架构师知识点集锦十:计算机网络、数学与经济管理、知识产权与标准化
一、计算机网络 1.1、考情分析 2.1 TCP/IP协议簇 2.1.1常见协议及功能 网际层是整个TCP/IP体系结构的关键部分,其功能是使主机可以把分组发往任何网络并使分组独立地传向目标。 POP3: 110 端口,邮件收取SMTP: 25 端口,邮件发送FTP: 20数据端口/21控制…...
风云七剑攻略,最强阵容搭配
今天的风云七剑攻略最强阵容搭配给大家推荐以神仙斋减怒回血为主的阵容。 关注【娱乐天梯】,获取内部福利号 首先,这个角色在这个阵容当中,所有的角色当中,他的输出系数是最高的,已经达到了200%的层次,而且…...
测试微信模版消息推送
进入“开发接口管理”--“公众平台测试账号”,无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息: 关注测试号:扫二维码关注测试号。 发送模版消息: import requests da…...
Flask RESTful 示例
目录 1. 环境准备2. 安装依赖3. 修改main.py4. 运行应用5. API使用示例获取所有任务获取单个任务创建新任务更新任务删除任务 中文乱码问题: 下面创建一个简单的Flask RESTful API示例。首先,我们需要创建环境,安装必要的依赖,然后…...
java 实现excel文件转pdf | 无水印 | 无限制
文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...
系统设计 --- MongoDB亿级数据查询优化策略
系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log,共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题,不能使用ELK只能使用…...
渲染学进阶内容——模型
最近在写模组的时候发现渲染器里面离不开模型的定义,在渲染的第二篇文章中简单的讲解了一下关于模型部分的内容,其实不管是方块还是方块实体,都离不开模型的内容 🧱 一、CubeListBuilder 功能解析 CubeListBuilder 是 Minecraft Java 版模型系统的核心构建器,用于动态创…...
大学生职业发展与就业创业指导教学评价
这里是引用 作为软工2203/2204班的学生,我们非常感谢您在《大学生职业发展与就业创业指导》课程中的悉心教导。这门课程对我们即将面临实习和就业的工科学生来说至关重要,而您认真负责的教学态度,让课程的每一部分都充满了实用价值。 尤其让我…...
学习STC51单片机32(芯片为STC89C52RCRC)OLED显示屏2
每日一言 今天的每一份坚持,都是在为未来积攒底气。 案例:OLED显示一个A 这边观察到一个点,怎么雪花了就是都是乱七八糟的占满了屏幕。。 解释 : 如果代码里信号切换太快(比如 SDA 刚变,SCL 立刻变&#…...
均衡后的SNRSINR
本文主要摘自参考文献中的前两篇,相关文献中经常会出现MIMO检测后的SINR不过一直没有找到相关数学推到过程,其中文献[1]中给出了相关原理在此仅做记录。 1. 系统模型 复信道模型 n t n_t nt 根发送天线, n r n_r nr 根接收天线的 MIMO 系…...
springboot整合VUE之在线教育管理系统简介
可以学习到的技能 学会常用技术栈的使用 独立开发项目 学会前端的开发流程 学会后端的开发流程 学会数据库的设计 学会前后端接口调用方式 学会多模块之间的关联 学会数据的处理 适用人群 在校学生,小白用户,想学习知识的 有点基础,想要通过项…...
【网络安全】开源系统getshell漏洞挖掘
审计过程: 在入口文件admin/index.php中: 用户可以通过m,c,a等参数控制加载的文件和方法,在app/system/entrance.php中存在重点代码: 当M_TYPE system并且M_MODULE include时,会设置常量PATH_OWN_FILE为PATH_APP.M_T…...
