MySQL内置函数使用说明
MySQL函数使用说明
MySQL 是一个流行的关系型数据库管理系统,它提供了许多内置函数来处理和操作数据。这些函数可以简化数据库查询和操作的过程,提高代码的可读性和效率。以下是一些常见的 MySQL 内置函数及其使用说明和示例。
数值函数
ABS()
函数原型:ABS(x)
返回参数x的绝对值。
示例:
SELECT ABS(-5); -- 返回 5
ROUND(x, 保留位数)
函数原型:ROUND(x, d)
将参数x四舍五入到指定的保留位数d。
示例:
SELECT ROUND(3.14159, 2); -- 返回 3.14
CEIL(x)
函数原型:CEIL(x)
返回大于或等于参数x的最小整数。
示例:
SELECT CEIL(3.7); -- 返回 4
FLOOR(x)
函数原型:FLOOR(x)
返回小于或等于参数x的最大整数。
示例:
SELECT FLOOR(3.7); -- 返回 3
TRUNCATE(x, D)
函数原型:TRUNCATE(x, D)
将参数x截断到指定的小数位数D。
示例:
SELECT TRUNCATE(3.14159, 2); -- 返回 3.14
条件函数
IF()
函数原型:IF(condition, true_value, false_value)
根据条件condition返回不同的值。
示例:
SELECT IF(10 > 5, 'true', 'false'); -- 返回 'true'
IFNULL()
函数原型:IFNULL(expression, value)
如果expression不为NULL,则返回expression的值,否则返回value。
示例:
SELECT IFNULL(NULL, 'not null'); -- 返回 'not null'
字符串函数
CONCAT()
函数原型:CONCAT(string1, string2, ..., stringN)
将多个字符串连接为一个字符串。
示例:
SELECT CONCAT('Hello', ' ', 'World'); -- 返回 'Hello World'
CONCAT_WS()
函数原型:CONCAT_WS(separator, string1, string2, ..., stringN)
将多个字符串连接为一个字符串,使用separator分隔。
示例:
SELECT CONCAT_WS(',', 'apple', 'banana', 'orange'); -- 返回 'apple,banana,orange'
LENGTH()
函数原型:LENGTH(string)
返回字符串的长度。
示例:
SELECT LENGTH('Hello'); -- 返回 5
LEFT()
函数原型:LEFT(string, length)
返回字符串左边指定长度的子字符串。
示例:
SELECT LEFT('Hello', 3); -- 返回 'Hel'
RIGHT()
函数原型:RIGHT(string, length)
返回字符串右边指定长度的子字符串。
示例:
SELECT RIGHT('Hello', 3); -- 返回 'llo'
MID()
函数原型:MID(string, start, length)
返回字符串从指定位置开始指定长度的子字符串。
示例:
SELECT MID('Hello', 2, 3); -- 返回 'ell'
REPLACE()
函数原型:REPLACE(string, old_text, new_text)
替换字符串中的某个子字符串。
示例:
SELECT REPLACE('Hello World', 'World', 'Bob'); -- 返回 'Hello Bob'
SUBSTRING()
函数原型:SUBSTRING(string, start, length)
返回字符串从指定位置开始指定长度的子字符串。
示例:
SELECT SUBSTRING('Hello', 2, 3); -- 返回 'ell'
SUBSTRING_INDEX()
函数原型:SUBSTRING_INDEX(string, delimiter, count)
返回字符串中指定子字符串的出现位置,并返回该子字符串。
示例:
SELECT SUBSTRING_INDEX('www.example.com', '.', 2); -- 返回 'www.example'
聚合函数
COUNT()
函数原型:COUNT(expression)
返回表中行的数量。
示例:
SELECT COUNT(*) FROM users; -- 返回 users 表的行数
COUNT_BIG()
函数原型:COUNT_BIG(expression)
返回表中行的数量(不限制结果集的大小)。
示例:
SELECT COUNT_BIG(*) FROM users; -- 返回 users 表的行数
SUM()
函数原型:SUM(expression)
返回表中指定列的总和。
示例:
SELECT SUM(price) FROM orders; -- 返回 orders 表中 price 列的总和
AVG()
函数原型:AVG(expression)
返回表中指定列的平均值。
示例:
SELECT AVG(age) FROM students; -- 返回 students 表中 age 列的平均值
MAX()
函数原型:MAX(expression)
返回表中指定列的最大值。
示例:
SELECT MAX(score) FROM exams; -- 返回 exams 表中 score 列的最大值
MIN()
函数原型:MIN(expression)
返回表中指定列的最小值。
示例:
SELECT MIN(price) FROM products; -- 返回 products 表中 price 列的最小值
GROUP_CONCAT()
函数原型:GROUP_CONCAT(expression, separator)
将多个字符串连接起来,并将它们作为一行显示在结果集中。
示例:
SELECT GROUP_CONCAT(name, ', ') FROM students; -- 返回 students 表中 name 列的所有值,使用逗号分隔
日期和时间函数
DATE_FORMAT()
函数原型:DATE_FORMAT(date, format)
格式化日期时间字符串。
示例:
SELECT DATE_FORMAT(CURRENT_TIMESTAMP, '%Y-%m-%d'); -- 返回当前日期的年、月、日格式
DATE_ADD()
函数原型:DATE_ADD(date, INTERVAL value unit)
将一个日期加上指定的时间间隔。
示例:
SELECT DATE_ADD('2021-01-01', INTERVAL 1 MONTH); -- 返回 '2021-02-01'
DATE_SUB()
函数原型:DATE_SUB(date, INTERVAL value unit)
将一个日期减去指定的时间间隔。
示例:
SELECT DATE_SUB('2021-01-01', INTERVAL 1 DAY); -- 返回 '2020-12-31'
TIME_FORMAT()
函数原型:TIME_FORMAT(time, format)
格式化时间戳字符串。
示例:
SELECT TIME_FORMAT('12:30:45', '%H:%i:%s'); -- 返回 '12:30:45'
UNIX_TIMESTAMP()
函数原型:UNIX_TIMESTAMP([date])
将日期时间字符串转换为 Unix 时间戳。
示例:
SELECT UNIX_TIMESTAMP('2021-01-01 12:00:00'); -- 返回 Unix 时间戳
YEAR()
函数原型:YEAR(date)
提取日期时间字符串中的年份部分。
示例:
SELECT YEAR('2021-01-01'); -- 返回 2021
MONTH()
函数原型:MONTH(date)
提取日期时间字符串中的月份部分。
示例:
SELECT MONTH('2021-01-01'); -- 返回 1
DAY()
函数原型:DAY(date)
提取日期时间字符串中的天数部分。
示例:
SELECT DAY('2021-01-01'); -- 返回 1
HOUR()
函数原型:HOUR(time)
提取日期时间字符串中的小时部分。
示例:
SELECT HOUR('12:30:45'); -- 返回 12
MINUTE()
函数原型:MINUTE(time)
提取日期时间字符串中的分钟部分。
示例:
SELECT MINUTE('12:30:45'); -- 返回 30
SECOND()
函数原型:SECOND(time)
提取日期时间字符串中的秒数部分。
示例:
SELECT SECOND('12:30:45'); -- 返回 45
以上是一些常用的MySQL函数的说明和示例。这些函数可以帮助你更好地处理和操作数据,在MySQL语句中起到重要的作用。使用这些函数可以提高查询效率和数据处理的灵活性。更多函数的详细说明可以参考MySQL官方文档。
相关文章:

MySQL内置函数使用说明
MySQL函数使用说明 MySQL 是一个流行的关系型数据库管理系统,它提供了许多内置函数来处理和操作数据。这些函数可以简化数据库查询和操作的过程,提高代码的可读性和效率。以下是一些常见的 MySQL 内置函数及其使用说明和示例。 数值函数 ABS() 函数原…...

java后端富文本转word,再传递到浏览器下载。
思路参考,以及所有的工具类都使用了》牧羊人大佬的代码《 有帮助的话不用给到我点赞,给大佬点赞即可 这是前端代码,必须使用get。 post后端返回的流浏览器接收不到(具体原因不详)。get无法传递requestBody,…...

【动态规划算法】-回文串问题题型(34-40题)
💖作者:小树苗渴望变成参天大树🎈 🎉作者宣言:认真写好每一篇博客💤 🎊作者gitee:gitee✨ 💞作者专栏:C语言,数据结构初阶,Linux,C 动态规划算法🎄 如 果 你 …...

STM32基础回顾
文章目录 单片机编程的原理GPIO中断EXTI外部中断定时器中断、串口中断 定时器定时器中断配置过程通用定时器输出比较功能:PWM波的生成定时器的输入捕获功能主从触发模式PWMI模式 定时器的编码器接口 DMA简介通信接口USART软件配置流程:1、仅发数据的配置…...

如何解决电脑无声问题:排除故障的几种常见方法
大家好,今天我们来讨论一下处理电脑没有声音的故障。当你突然发现电脑静音无声时,需要逐步排除可能的问题,但总体而言,声音故障是相对容易解决的。接下来,我们将介绍一些排除电脑无声问题的方法。 第一步:…...

Apache RocketMQ 命令注入
漏洞简介 RocketMQ 5.1.0及以下版本,在一定条件下,存在远程命令执行风险。RocketMQ的NameServer、Broker、Controller等多个组件外网泄露,缺乏权限验证,攻击者可以利用该漏洞利用更新配置功能以RocketMQ运行的系统用户身份执行命令…...

二、搜索与图论6:Dijkstra 模板题+算法模板(Dijkstra求最短路 I, Dijkstra求最短路 II,1003 Emergency)
文章目录 算法模板Dijkstra题目代码模板朴素dijkstra算法堆优化版dijkstra 树与图的存储(1) 邻接矩阵:(2) 邻接表:关于e[],ne[],h[]的理解 关于堆的原理与操作 模板题Dijkstra求最短路 I原题链接题目思路题解 Dijkstra求最短路 II原题链接题目思路题解 1…...

ROS2学习(四)进程,线程与节点的关系
节点与节点执行器 节点,英文是node,在ROS2中,节点是一个抽象的实体,它可以代表某种或某类特定功能的抽象集合体,它可以存在于进程中,也可以存在于线程中。所有ROS2的基础功能最基础的载体是节点,所有的通信…...

【物联网】DMA传输原理与实现详解(超详细)
DMA(Direct Memory Access,直接内存访问)是一种计算机数据传输方式,允许外围设备直接访问系统内存,而无需CPU的干预。 文章目录 Part 1: DMA的工作原理配置阶段:数据传输阶段: Part 2: DMA数据…...

Java类集框架(二)
目录 1.Map(常用子类 HashMap,LinkedHashMap,HashTable,TreeMap) 2.Map的输出(Map.Entry,iterator,foreach) 3.数据结构 - 栈(Stack) 4.数据结构 - 队列(Q…...

爬虫008_流程控制语句_if_if else_elif_for---python工作笔记026
然后我们再来看一下这里的,判断,可以看到 再看一个判断,这里的布尔类型 第二行有4个空格,python的格式 注意这里,输入的age是字符串,需要转一下才行 int可以写到int(intput("阿斯顿法师打发地方")) 这样也可以...

【随笔】五周年创作纪念日
今天收到了 CSDN 的创作五周年提示,正好前几天(7.31)我也成功申请了 CSDN 博客专家,趁这个机会分享一下这几年写博客的感受吧 机缘 关注我比较久的读者应该知道我是从学传统工科半路出家搞计算机的,这里的经历还是比…...

7_分类算法—逻辑回归
文章目录 逻辑回归:1 Logistic回归(二分类问题)1.1 sigmoid函数1.2 Logistic回归及似然函数(求解)1.3 θ参数求解1.4 Logistic回归损失函数1.5 LogisticRegression总结 2 Softmax回归(多分类问题࿰…...

【计算机网络】应用层协议 -- DNS协议
文章目录 1. DNS背景2. 域名简介3. 域名解析过程4. 使用dig查看DNS过程 1. DNS背景 DNS(Domain Name System,域名系统)协议,是一个用来将域名转化为IP地址的应用层协议。 TCP/IP当中通过IP地址和端口号的方式,来确定…...
ES6 - 数组新增的一些常用方法
文章目录 1,Array.from()2,Array.of()3,find(),findIndex(),findLast()和findLastIndex()4,Array.fill()5,keys(),values() 和 entries()6,Array.includes()7,…...

【BEV感知】3-BEV开源数据集
3-BEV开源数据集 1 KITTI1.1 KITTI数据怎么采集?1.2 KITTI数据规模有多大?1.3 KITTI标注了哪些目标?1.4 转换矩阵1.5 标签文件 2 nuScenes2.1 nuScenes Vs KITTI2.2 标注文件 1 KITTI KITTI 1.1 KITTI数据怎么采集? 通过车载相机、激光雷达等传感器采集。 只提供了相机正…...

Kafka-Broker工作流程
kafka集群在启动时,会将每个broker节点注册到zookeeper中,每个broker节点都有一个controller,哪个controller先在zookeeper中注册,哪个controller就负责监听brokers节点变化,当有分区的leader挂掉时,contro…...
第八篇-Tesla P40+ChatGLM2+LoRA
部署环境 系统:CentOS-7CPU: 14C28T显卡:Tesla P40 24G驱动: 515CUDA: 11.7cuDNN: 8.9.2.26目的 验证P40部署可行性,只做验证学习lora方式微调创建环境 conda create --name glm-tuning python3.10 conda activate glm-tuning克隆项目 git clone http…...

调用feign返回错误的数据
bug描述: 在一个请求方法中会调用到feign去获取其他的数据。 List<Demo> list aaaFeignApi.getData(personSelectGetParam);在调用的时候,打断点到feign的地方,数据是存在的,并且有15条。但是返回到上面代码的时候数据就…...

【Spring】(二)从零开始的 Spring 项目搭建与使用
文章目录 前言一、Spring 项目的创建1.1 创建 Maven 项目1.2 添加 Spring 框架支持1.3 添加启动类 二、储存 Bean 对象2.1 创建 Bean2.1 将 Bean 注册到 Spring 容器 三、获取并使用 Bean 对象3.1 获取Spring 上下文3.2 ApplicationContext 和 BeanFactory 的区别3.3 获取指定的…...
synchronized 学习
学习源: https://www.bilibili.com/video/BV1aJ411V763?spm_id_from333.788.videopod.episodes&vd_source32e1c41a9370911ab06d12fbc36c4ebc 1.应用场景 不超卖,也要考虑性能问题(场景) 2.常见面试问题: sync出…...

【HarmonyOS 5.0】DevEco Testing:鸿蒙应用质量保障的终极武器
——全方位测试解决方案与代码实战 一、工具定位与核心能力 DevEco Testing是HarmonyOS官方推出的一体化测试平台,覆盖应用全生命周期测试需求,主要提供五大核心能力: 测试类型检测目标关键指标功能体验基…...
【SpringBoot】100、SpringBoot中使用自定义注解+AOP实现参数自动解密
在实际项目中,用户注册、登录、修改密码等操作,都涉及到参数传输安全问题。所以我们需要在前端对账户、密码等敏感信息加密传输,在后端接收到数据后能自动解密。 1、引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId...

YSYX学习记录(八)
C语言,练习0: 先创建一个文件夹,我用的是物理机: 安装build-essential 练习1: 我注释掉了 #include <stdio.h> 出现下面错误 在你的文本编辑器中打开ex1文件,随机修改或删除一部分,之后…...
【C++从零实现Json-Rpc框架】第六弹 —— 服务端模块划分
一、项目背景回顾 前五弹完成了Json-Rpc协议解析、请求处理、客户端调用等基础模块搭建。 本弹重点聚焦于服务端的模块划分与架构设计,提升代码结构的可维护性与扩展性。 二、服务端模块设计目标 高内聚低耦合:各模块职责清晰,便于独立开发…...

Docker 本地安装 mysql 数据库
Docker: Accelerated Container Application Development 下载对应操作系统版本的 docker ;并安装。 基础操作不再赘述。 打开 macOS 终端,开始 docker 安装mysql之旅 第一步 docker search mysql 》〉docker search mysql NAME DE…...
AGain DB和倍数增益的关系
我在设置一款索尼CMOS芯片时,Again增益0db变化为6DB,画面的变化只有2倍DN的增益,比如10变为20。 这与dB和线性增益的关系以及传感器处理流程有关。以下是具体原因分析: 1. dB与线性增益的换算关系 6dB对应的理论线性增益应为&…...

Kafka入门-生产者
生产者 生产者发送流程: 延迟时间为0ms时,也就意味着每当有数据就会直接发送 异步发送API 异步发送和同步发送的不同在于:异步发送不需要等待结果,同步发送必须等待结果才能进行下一步发送。 普通异步发送 首先导入所需的k…...

逻辑回归暴力训练预测金融欺诈
简述 「使用逻辑回归暴力预测金融欺诈,并不断增加特征维度持续测试」的做法,体现了一种逐步建模与迭代验证的实验思路,在金融欺诈检测中非常有价值,本文作为一篇回顾性记录了早年间公司给某行做反欺诈预测用到的技术和思路。百度…...

基于Java+VUE+MariaDB实现(Web)仿小米商城
仿小米商城 环境安装 nodejs maven JDK11 运行 mvn clean install -DskipTestscd adminmvn spring-boot:runcd ../webmvn spring-boot:runcd ../xiaomi-store-admin-vuenpm installnpm run servecd ../xiaomi-store-vuenpm installnpm run serve 注意:运行前…...