MySQL(四)——常用函数

news2024/9/21 9:42:56

文章目录

  • 函数
    • 字符串函数
    • 数值函数
    • 日期函数
    • 流程函数

函数

函数,是指一段可以直接被另一段程序调用的程序或代码。

MySQL中内置了许多函数,我们只需在合适的场景下调用它们即可,调用函数查询结果直接使用SELECT即可,并且可以嵌套使用:

SELECT functions(parameters);
  • functions:函数
  • parameters:参数

为了避免多张截图堆叠的问题,我们在直接演示环节使用代码块并使用注释来展示函数结果。


字符串函数

常用字符串函数:

函数功能
CONCAT(S1, S2, …Sn)字符串拼接,将S1,S2,… Sn拼接成一个字符串
LOWER(str)将字符串 str 全部转为小写
UPPER(str)将字符串 str 全部转为大写
LPAD(str, len, pad)左填充,用字符串 pad 对 str 的左边进行填充,达到 len 个字符串长度
RPAD(str, len, pad)右填充,用字符串 pad 对 str 的右边进行填充,达到 len 个字符串长度
TRIM(str)去掉字符串头部和尾部的空格
SUBSTRING(str, start, len)返回字符串 str 从 start 位置起的 len 个长度的字符串,第一个字符的位置是1
  • 对于字符串函数,MySQL能够自动处理非字符串类型的参数,并将它们转换为字符串后再进行指定操作

直接演示

SELECT CONCAT('Hello', ' MySQL!');
SELECT CONCAT(123, 12.5);
/* 
结果1:Hello MySQL!
结果2:12312.5
*/

SELECT LOWER('Hello MySQL!');
SELECT LOWER(123);
/*
结果1:hello mysql!
结果2:123
*/

SELECT UPPER('Hello MySQL!');
SELECT UPPER(12.3);
/*
结果1:HELLO MYSQL!
结果2:12.3
*/

SELECT LPAD(1, 5, 0);
SELECT LPAD('ok', 3, 'o');
/*
结果1:00001
结果2:ook
*/

SELECT RPAD(1, 5, 0);
SELECT RPAD('ok', 3, 'o');
/*
结果1:10000
结果2:oko
*/

SELECT TRIM('  i am fine.  ');
/*
结果:i am fine.
*/

SELECT SUBSTRING('Hello MySQL!', 1, 5);
SELECT SUBSTRING(123456, 2, 4);
/*
结果1:Hello
结果2:2345
*/

场景演示

对于下表,修改id数据列的格式:3位数,不够的左边填充0:

在这里插入图片描述

在这里插入图片描述


数值函数

常用数值函数:

函数功能
CEIL(x)向上取整
FLOOR(x)向下取整
MOD(x, y)返回 x/y 的模
RAND()返回 0~1 内的随机数
ROUND(x, y)求参数 x 的四舍五入的值,保留 y 位小数

直接演示

SELECT CEIL(1.1);
# 结果:2

SELECT FLOOR(1.9);
# 结果:1

SELECT MOD(5, 11);
# 结果:5

SELECT RAND();
# 结果:0~1的随机数,例如,某次执行的结果为0.9047801484398359

SELECT ROUND(12.55, 1);
# 结果:12.6

场景演示

查询所有人的成绩,要求查询结果中成绩没有小数位,四舍五入:

在这里插入图片描述


日期函数

常用日期函数:

函数功能
CURDATE()返回当前日期 YYYY-MM-DD
CURTIME()返回当前时间 HH:MM:SS
NOW()返回当前日期和时间 YYYY-MM-DD HH:MM:SS
YEAR(date)获取指定 date 的年份
MONTH(date)获取指定 date 的月份
DAY(date)获取指定 date 的日期
DATE_ADD(date, INTERVAL expr type)返回一个日期/时间值加上一个时间间隔 expr 后的时间值
DATEDIFF(date1, date2)返回起始时间 date1 和结束时间 date2 之间间隔的天数
  • DATE_ADD(date, INTERVAL expr type)参数含义如下
    1. date这是你想要添加时间间隔的原始日期。 它可以是一个日期或日期时间表达式,比如一个 DATEDATETIMETIMESTAMP 类型的列,或者是一个日期字符串(在能够被MySQL解析为有效日期的情况下)。
    2. INTERVAL:这是一个关键字,用于指示接下来的参数是一个时间间隔。 它告诉MySQL你想要对前面的日期进行加法操作,并且接下来的参数将定义这个加法操作的具体内容。
    3. expr这是你想要添加到原始日期上的时间间隔的数量。 它应该是一个整数或整数表达式。例如,如果你想要添加3天,那么 expr 就是 3
    4. type这是时间间隔的单位。 它告诉MySQL你想要以什么单位来添加时间间隔。type 可以是多种不同的值,比如 DAYMONTHYEARHOURMINUTESECOND 等。这个参数决定了 expr 的具体含义。例如,如果 typeDAY,那么 expr 就是天数;如果 typeMONTH,那么 expr 就是月数。

直接演示

SELECT CURDATE();           -- 输出当前日期,本次运行时日期为2024-08-18

SELECT CURTIME();           -- 输出当前时间,本次运行时时间为20:49:44

SELECT NOW();               -- 输出当前日期和时间,本次运行时为2024-08-18 20:50:17

SELECT YEAR('2023-04-01');  -- 输出: 2023  
SELECT YEAR('20230401');    -- 输出: 2023(注意:这取决于MySQL的SQL模式,有时需要确保字符串能被正确解析为日期)  
SELECT YEAR(CURDATE());     -- 输出当前日期的年份  本次运行为2024
SELECT YEAR(NOW());         -- 输出当前日期和时间的年份(仅提取年份部分),本次运行为2024

SELECT MONTH('2023-04-01');  -- 输出: 4  
SELECT MONTH('20230401');    -- 输出: 4(注意:这取决于MySQL的SQL模式,有时需要确保字符串能被正确解析为日期)  
SELECT MONTH(CURDATE());     -- 输出当前日期的月份  本次运行为8
SELECT MONTH(NOW());         -- 输出当前日期和时间的月份(仅提取年份部分),本次运行为8

SELECT DAY('2023-04-01');  -- 输出: 1 
SELECT DAY('20230401');    -- 输出: 1(注意:这取决于MySQL的SQL模式,有时需要确保字符串能被正确解析为日期)  
SELECT DAY(CURDATE());     -- 输出当前日期的'日期'  本次运行为18
SELECT DAY(NOW());         -- 输出当前日期和时间的'日期'(仅提取年份部分),本次运行为18

SELECT DATE_ADD('2021-11-10', INTERVAL 5 DAY);     -- 结果为:2021-11-15
SELECT DATE_ADD('2021-11-10', INTERVAL 5 MONTH);   -- 结果为:2022-04-10
SELECT DATE_ADD(NOW(), INTERVAL 5 YEAR);           -- 此次结果为:2029-08-18 21:03:18

SELECT DATEDIFF('2011-03-30', '2010-01-12');       -- 结果为:442
SELECT DATEDIFF('2011-03-30', '2012-01-12');       -- 结果为:-288(所以实际上是左参数‘减去’右参数,早 - 晚 = 负数)

场景演示

比如有张学生信息表,其中有个入学时间的字段,我们想查询学生的入学了多长时间,并按照时间降序排序,就会写出类似如下语句:

SELECT name, DATEDIFF(NOW(), en_time) 时间 FROM student ORDER BY 时间 DESC;

流程函数

常用流程函数:

函数功能
IF(value, t, f)如果 value 为 true,返回 t,否则返回 f
IFNULL(value1, value2)如果 value 不为空,返回 value1,否则返回 value2
CASE WHEN [val1] THEN [ret1]… ELSE [default] END如果 val1 为 true,返回 ret1,… 否则返回 default
CASE [expr] WHEN [val1] THEN [ret1]… ELSE [default] END如果 expr 的值等于 val1,返回 ret1,… 否则返回 default
  • 在SQL的CASE语句中,条件是从上到下依次评估的,一旦找到满足条件的分支,就会执行该分支的语句并结束CASE表达式的评估。

直接演示

SELECT IF(20 > 11, 'OK', 'NO');   -- 结果为:OK
SELECT IF(20 < 11, 20, 11);       -- 结果为:11

SELECT IFNULL(NULL, 12);          -- 结果为:12
SELECT IFNULL(10, 12);            -- 结果为:10

SELECT CASE WHEN 66 > 90 THEN 'one' WHEN 66 > 80 THEN 'two' ELSE 'default' END;   -- 结果为:default
SELECT CASE WHEN 66 > 60 THEN 'one' WHEN 66 > 50 THEN 'two' ELSE 'default' END;   -- 结果为:one

SELECT CASE 43 WHEN 20 THEN 1 WHEN 43 THEN 2 ELSE 3 END;             -- 结果为:2
SELECT CASE 'mysql' WHEN 'nosql' THEN 1 WHEN 43 THEN 2 ELSE 3 END;   -- 结果为:3 

场景演示

查询学生成绩,要求:1. >= 90 显示优秀 2. >= 60 显示及格 3. 否则,显示不及格,如下:
在这里插入图片描述


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2051225.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

电子电气架构---主流主机厂电子电气架构华山论剑(上)

我是穿拖鞋的汉子&#xff0c;魔都中坚持长期主义的汽车电子工程师。 老规矩&#xff0c;分享一段喜欢的文字&#xff0c;避免自己成为高知识低文化的工程师&#xff1a; 屏蔽力是信息过载时代一个人的特殊竞争力&#xff0c;任何消耗你的人和事&#xff0c;多看一眼都是你的不…

递归--数据结构--黑马

递归 总结一句话&#xff0c;上手直接多刷Leetcode&#xff0c;比看这个更有用。 定义 递归是一种解决计算问题的方法&#xff0c;其中解决方案取决于同一类问题的更小子集。 例如&#xff0c;单链表递归遍历的例子&#xff1a; void f(Node node) {if (node null) {retu…

class_2:数学运算和注释

1、运算符优先级 2、导入算数库 import matha -1 b -2 c 3 #一元二次方程 delta b ** 2 -4*a*c print((-b math.sqrt(delta))/(2*a)) print((-b - math.sqrt(delta))/(2*a)) 3、注释

KEEPALIVED高可用集群知识大全

目录 一、KEEPALIVED高可用集群简介 1、Keepalived 高可用集群的工作原理 2、Keepalived 高可用集群的作用 二、KEEPALIVED部署 1、网络配置 2、软件安装与启动 3、配置虚拟路由器 4、效果实现 三、启用keepalived日志功能 四、KEEPALIVED的几种工作模式 1、KEEPALI…

【多线程】初步认识Thread类及其应用

&#x1f490;个人主页&#xff1a;初晴~ &#x1f4da;相关专栏&#xff1a;多线程 / javaEE初阶 上篇文章我们简单介绍了什么是进程与线程&#xff0c;以及他们之间的区别与联系&#xff0c;实际应用中还是以多线程编程为主的&#xff0c;所以这篇文章就让我们更加深入地去剖…

深入理解Python range()函数与for循环的完美配合

文末赠免费精品编程资料~~ 今天我们要聊的是一个超级实用且基础的功能组合——range() 函数和 for 循环。无论你是刚开始学习Python&#xff0c;还是已经有点基础&#xff0c;这篇文章都将帮助你更深入地理解和掌握这两个工具。 1. 什么是 range()&#xff1f; range() 是Py…

YOLOV8网络结构|搞懂head

head里面的模块之前在backbone出现过的&#xff0c;有conv和c2f&#xff0c;还有concat是新的&#xff0c;就是用来做连接的&#xff0c;就是把几个通道的输出给连接起来&#xff0c;有C,H,W三个维度的&#xff0c;就看最后连接的参数&#xff0c;是按照哪个方向把他们加起来&a…

【C++从小白到大牛】布隆过滤器

布隆过滤器的提出 布隆过滤器概念 布隆过滤器的原理&#xff1a; 布隆过滤器的运作的总体过程&#xff1a; 布隆过滤器的插入 原码 布隆过滤器的查找 布隆过滤器删除 关于布隆过滤器的面试题&#xff1a; 1. 给两个文件&#xff0c;分别有100亿个query&#xff0c;我们…

EmguCV学习笔记 VB.Net 4.2 二值化

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 教程VB.net版本请访问&#xff1a;EmguCV学习笔记 VB.Net 目录-CSDN博客 教程C#版本请访问&#xff1a;EmguCV学习笔记 C# 目录-CSD…

K8S资源之PVPVC

概念 类似于Docker的数据卷挂载&#xff0c;将Pod中重要的文件挂载到宿主机上&#xff0c;如果Pod发生崩溃等情况自愈时&#xff0c;保证之前存储的数据没有丢失。 如上图中&#xff0c;将各个Pod中的目录挂载到存储层&#xff0c;如果Pod宕机后自愈均从存储层获取之前的数据…

STM32——I2C和SPI波形分析

波形分析 I2C波形 //写命令 void OLED_WR_CMD(uint8_t cmd) { HAL_I2C_Mem_Write(&hi2c1 ,0x78,0x00,I2C_MEMADD_SIZE_8BIT,&cmd,1,0x100); } //写数据 void OLED_WR_DATA(uint8_t data) { HAL_I2C_Mem_Write(&hi2c1 ,0x78,0x40,I2C_MEMADD_SIZE_8BIT,&am…

【Linux线程】线程的深度解析(线程是什么?线程与进程区别是什么?)

目录 一、前言 二、 什么是线程 &#x1f4a7;线程的引入&#x1f4a7; &#x1f4a7;线程的基本概念 &#x1f4a7; &#x1f4a7;线程的理解 &#x1f4a7; &#x1f4a7;进程与线程的关系&#x1f4a7; &#x1f4a7;程序如何划分&#xff08;重拾页表、见一下LWP&…

行业分析---AI时代是不断更新自身技术还是会利用新技术?

1 背景 最近有两个热点新闻&#xff0c;&#xff08;1&#xff09;“孟晚舟建议不要选和机器竞争的职业&#xff0c;根本不是它的对手”&#xff1b;&#xff08;2&#xff09;“周鸿祎建议萝卜快跑把无人出租车卖给司机&#xff0c;可实现三赢”。 技术的变革在互联网领域是比…

QT翻金币小游戏(含音频图片文件资源)

目录 QT翻金币小游戏 音频图片资源文件获取 效果展示 图片 视频 实现代码 main.cpp mymainwindow.h mymainwindow.cpp startscene.h startscene.cpp selectscene.cpp playscene.h playscene.cpp mypushbutton.h mypushbutton.cpp dataconfig.h dataconfig.cpp QT…

音频剪辑用什么工具?试试这三款

音乐&#xff0c;是情感的传递者&#xff0c;是灵魂的慰藉。作为一名音乐人&#xff0c;我一直在探索如何更好地捕捉和表达音乐的精髓。在这个数字化的时代&#xff0c;音频剪辑软件成为了我们表达创意的重要工具。今天&#xff0c;我想从一个音乐人的角度&#xff0c;分享我使…

C语言每日好题(3)

有任何不懂的问题可以评论区留言&#xff0c;能力范围内都会一一回答 #define _CRT_SECURE_NO_WARNING #include <stdio.h> #include <string.h> int main(void) {if ((strlen("abc") - strlen("abcdef")) > 0)printf(">\n")…

CentOS 7 下载/安装

下载 centos安装包下载_开源镜像站-阿里云centos安装包是阿里云官方提供的开源镜像免费下载服务&#xff0c;每天下载量过亿&#xff0c;阿里巴巴开源镜像站为包含centos安装包的几百个操作系统镜像和依赖包镜像进行免费CDN加速&#xff0c;更新频率高、稳定安全。https://mir…

SpringBoot(一)

1.Spring Boot概要 1.1 SpringBoot介绍 随着动态语言的流行&#xff08;Ruby、Scala、Node.js&#xff09;, Java的开发显得格外的笨重&#xff1b;繁多的配置、低下的开发效率、复杂的部署流程以及第三方技术整合难度大。 在上述环境下&#xff0c;Spring Boot由此诞生&#…

每天五分钟计算机视觉:搭建人脸识别的Siamese深度神经网络模型

本文重点 前面的一篇文章中介绍了关于一次学习的问题,解决一次学习问题的关键在于学习到一个函数d,这个d可以计算出两张图片中的人脸是不是同一个人。那么我们需要搭建什么样的神经网络才可以让模型学习出这样的函数d呢?本文我们介绍一下Siamese神经网络结构,它可以帮助我…

快速上手体验MyPerf4J监控springboot应用(docker版快速开始-本地版)

使用MyPerf4J监控springboot应用 快速启动influxdb时序数据库日志收集器telegrafgrafana可视化界面安装最终效果 项目地址 项目简介: 一个针对高并发、低延迟应用设计的高性能 Java 性能监控和统计工具。 价值 快速定位性能瓶颈快速定位故障原因 快速启动 监控本地应用 idea配…