【MySQL】一些内置函数(时间函数、字符串函数、数学函数等,学会了有妙用)

内置函数

  • 前言
  • 正式开始
    • 时间函数
      • 显示当前日期、时间、日期时间的
      • 日期计算
      • 相差多少天
      • 示例
        • 创建一张表,记录生日
      • 留言表
    • 字符串函数
      • charset
      • concat
      • instr(string, substring)
      • ucase和lcase
      • left(string, length)
      • length求字符串长度
      • replace(str, search_str, replace_str)
      • trim、ltrim、rtrim
      • 一些示例
        • 要求显示exam_result表中的信息,显示格式:“XXX的语文是XXX分,数学XXX分,英语XXX分"
        • 求学生表中学生姓名占用的字节数
        • 将EMP表中所有名字中有S的替换成'上海'
        • 截取EMP表中ename字段的第二个到第三个字符
        • 以首字母小写的方式显示所有员工的姓名
    • 数学函数
      • abs
      • bin
      • hex
      • conv(num, from_base, to_base)
      • ceiling 和 floor
      • format(一个小数, 指定小数位数)
      • mod
      • rand
    • 其他函数
      • user
      • database
      • md5
      • ifnull(val1, val2)

在这里插入图片描述

前言

MySQL中内置类很多函数,这些函数可以让我们在进行数据统计、查表、建表的时候更加方便,本篇将MySQL中的内置函数分为四类,分别是:

  • 时间函数

  • 字符串函数

  • 数学函数

  • 其他函数

正式开始

时间函数

讲下面这些(先不用细看):
在这里插入图片描述

简单介绍介绍。

首先声明一点,日期是指年月日,时间是指时分秒,日期时间是年月日时分秒。这在我前面的博客也是说过的。

显示当前日期、时间、日期时间的

current_date,当前日期,就是返回你调用这个函数时的日期:
在这里插入图片描述
不加括号也行,不过既然叫了函数那就最好把括号带上。

【注意】这些内置函数都要搭配着select使用,不然显示不出来:
在这里插入图片描述

关于select我就不说了,在前面博客已经详细说过了。

current_time,当前时间,就是返回你调用这个函数时的时间:
在这里插入图片描述
就不演示不带括号的了。

current_timestamp(),当前时间戳,时间和日期都会显示:
在这里插入图片描述
我前面在讲数据类型的时候,有个类型就叫做timestamp,默认值就是插入数据时的时间戳。

还有一个和这个时间戳很像,就是now:
在这里插入图片描述
其实就和current_timestamp一样的效果。

日期计算

两个,一个加一个减。

date_add,可以加年、月、日、时、分、秒。
在这里插入图片描述
还可以搭配前面的now来用:
在这里插入图片描述
会自动按照你给的类型来计算,类型不同结果也就不同。注意interval不能掉,还有类型也不能掉。

date_sub同理,就不说了。

相差多少天

date_diff,这个是计算两个日期之间相差多少天:
在这里插入图片描述

这个是用前者前去后者,故会出现负数的情况:
在这里插入图片描述

也可以嵌套调用:
在这里插入图片描述

统计工龄的时候就可以用这个函数。

时间的接口就讲这么些来两个例子。

示例

创建一张表,记录生日

生日一般精确到年月日就可以了,时分秒这里就不记录了。

创表:
在这里插入图片描述
里面的这些类型什么的我就不讲了,我前面的博客中有。

插入点数据:
在这里插入图片描述
因为id是自增的,所以不用手动插入。

再来嵌套调用:
在这里插入图片描述

能不能插入纯时分秒的呢?
在这里插入图片描述
竟然可以。

再来试一个:
在这里插入图片描述
竟然也可以。

我为啥说竟然呢?
因为我前面在讲数据类型的时候说过数据类型其实算是一种约束,MySQL对于数据匹配的要求是很严格的,但这里并没有那么严格,像隐式类型转换,把这当成例外。

其实可以理解成所有的时间函数底层用的都是一个函数,不过是要哪个显示哪个罢了。不过建议插入的时候类型为日期就用日期插,不要加时间。

留言表

平时很多软件都有评论区,评论有一个很重要的字段就是时间,比如说xxx发布于2023-10-23,其实原理就是客户点击发送,数据发送到后台服务器后,后台服务器将其转为sql语句对数据库做插入动作,这里就简单实现一个。

在这里插入图片描述

插入点数据:
在这里插入图片描述

这样就能把评论内容和评论时间拿到手。

如果显示时只想显示日期,就在sendtime外套个date就行:
在这里插入图片描述

再插入点:
在这里插入图片描述

来个问题:统计2分钟内发布过的帖子。
怎么确定表中的哪些数据是两分钟以内的?
找到当前时间的两分钟前的时间,假如说当前时间是 t 0 t_0 t0,当前时间的2分钟前是 t 1 t_1 t1,所以 t 1 t_1 t1的值就是 t 0 − 2 t_0 - 2 t02,对应图中就应该是这样:
在这里插入图片描述

此时在 t 1 ∼ t 0 t_1 \sim t_0 t1t0之内的帖子就是我们想要的,那这之中的帖子在时间上有什么特点呢?假如说帖子的时间是 t t t,那么就是这样:
在这里插入图片描述

这里t一定是小于 t 0 t_0 t0的,这点对于所有的帖子都会满足。

那么就好说了,只要让 t > t 1 t > t_1 t>t1就行了,也就是 t > t 0 − 2 t > t_0 - 2 t>t02,那么就会有两种解法:
t > t 0 − 2 t > t_0 - 2 t>t02 t + 2 > t 0 t + 2 > t_0 t+2>t0

都来试一试,插入点数据:
在这里插入图片描述

然后筛选:
在这里插入图片描述

再重新插入点:
在这里插入图片描述

筛选:
在这里插入图片描述

筛选:
在这里插入图片描述

可以看到都是ok的。

字符串函数

讲这些:
在这里插入图片描述

charset

charset,查看字符集:
在这里插入图片描述

在这里插入图片描述

再用一下我前面博客定义的一张表:
在这里插入图片描述

在这里插入图片描述

都是utf8的。因为我的配置文件搞了默认的字符集。

再显示一下数字的:
在这里插入图片描述

concat

concat,追加的函数,只要是字符串就能追加,不管字符串的内容,有点像C中的strcat,来点例子:
在这里插入图片描述

在这里插入图片描述

里面可以有多个串:
在这里插入图片描述

没啥难的。

instr(string, substring)

这个函数是用来查询substring是否在string中,如果在就会返回其在第一个字符的位置,如果不在就返回0。

例子:
在这里插入图片描述
这里1234在abcde12345efg中,1在其中的第六个位置,这里是从1开始的,不是从0开始的。

再来个不存在的:
在这里插入图片描述

有点像find_in_set,这个是用来查找某一项是否在一个集合当中,如果在会返回其在集合中的位置,如果不在会返回0。想了解一下的可以看我这篇博客:【MySQL】数据类型

ucase和lcase

这两个是用来转大小写的,u是up,转大;l是low,转小。

转大写:
在这里插入图片描述

其中不是字母的就不会管。

转小写:
在这里插入图片描述

left(string, length)

这个函数用来取string左边的length个字符。

演示:
在这里插入图片描述

那有没有right?
在这里插入图片描述
有的。

length求字符串长度

在这里插入图片描述

这里编码会导致结果有点和你想的不一样:
在这里插入图片描述

因为utf8下一个汉字占用3个字节。而且utf8还是变长的编码,一部分是1字节的,比如说我在其中加上一点英文字母:
在这里插入图片描述
其中你好占用6字节,abc占用3字节。

replace(str, search_str, replace_str)

这个函数在str中找到searche_str字符串并将searche_str替换成replace_str。

例如:
在这里插入图片描述

这里将123456789中的567替换成了你好。

trim、ltrim、rtrim

这三个用来去掉左右两边字符串的空格。

trim是两边都去掉,ltrim是只去掉左边的,rtrim是只去掉右边的。
在这里插入图片描述

有时可能因为网络传输而导致传输的字符串左右两侧出现一些空格,此时不能让这些左右两侧的空格保存在数据库中,不然如果是用户的密码的话,用户后面就没法认证了,而且如果出现了这种问题还很难查出来问题所在,因为空格不可显。此时就可以用trim剪掉两边的空格,来避免这些问题。

一些示例

下面的所有示例都要用到刚刚讲的一些内置函数。

要求显示exam_result表中的信息,显示格式:“XXX的语文是XXX分,数学XXX分,英语XXX分"

下面的两个例子,基于这张表的:
在这里插入图片描述

就是改一下打印格式,打印的时候不要像上面表中那样分格打印,而是全部拼接到一块,假如说是为了发短信要这样搞。

直接用一个concat:
在这里插入图片描述
但是这样搞出来很难看,加点东西:
在这里插入图片描述
这样就可以将所有的内容拼接一块发出去,没人对应一条信息。

求学生表中学生姓名占用的字节数

其实就是用length。
在这里插入图片描述

还是因为utf8中一个汉字3个字节。

再强调一下:length函数返回字符串长度,以字节为单位。如果是多字节字符则计算多个字节数;如果是单字节字符则算作一个字节。比如:字母,数字算作一个字节,中文表示多个字节数(与字符集编码有关)

将EMP表中所有名字中有S的替换成’上海’

下面的三个例子基于我前一篇中搞的这张表:
在这里插入图片描述

将EMP表中所有名字中有S的替换成’上海’,就是用replace:
在这里插入图片描述
这些内置函数并不会影响原表中的数据。

截取EMP表中ename字段的第二个到第三个字符

不能用left或者right,二者取不到中间的数,不过嵌套调用也能实现,不过比较麻烦。

用substring,这个函数前面没说,其实就和C++中string的substr一样,取子串的。
在这里插入图片描述

以首字母小写的方式显示所有员工的姓名

嵌套调用一下:
在这里插入图片描述
其中substring如果没有给第三个参数,就会将指定子串位置后面的所有子串全部返回。

用left拿到第一个字符,然后转成小写,再和后面的字符串拼接。

数学函数

这些:
在这里插入图片描述

演示一下:

abs

求绝对值的:
在这里插入图片描述

bin

求二进制的:

在这里插入图片描述

hex

求十六进制的:

在这里插入图片描述

conv(num, from_base, to_base)

指定num从from_base进制转换成to_base进制:

在这里插入图片描述
其实这里覆盖了前面的两个进制转换。

ceiling 和 floor

一个向上取整(ceiling,天花板的意思),一个向下取整(floor,地板)。说说啥意思。这两个都是针对小数的。

向上取整:只要有小数部分,就直接取大的值,比如说2.1,就直接直接转成3。转成最近的大的数。再比如说-2.1,那就回转成-2,转成比原数大的最近的整数,也就是-2。看这张图:
在这里插入图片描述
如果是2.5,向上取整就是3,如果是-2.9,线上取整为-2。
这就是向上取整。

向下取整,只要有小数,就取小的值,比如说下图中2.1,取的是2,-2.1取的是-3:
在这里插入图片描述
如果是-2.9,向下取整为-3,如果是2.9,向下取整为2。

看这两个函数的例子,向上的:
在这里插入图片描述

向下的:
在这里插入图片描述

还有两中取整,一种是0向取整,还有一种是小学都学过的四舍五入。

0向取整,其实也很常见,就是直接舍弃掉小数部分,在C语言中很常见,比如两个整数的除法,9/2,得到的数应该是4.5,但是语言中是直接去掉0.5,得到4。再比如说-3.6,0向取整就是-3,图是这样的:
在这里插入图片描述

format(一个小数, 指定小数位数)

这个是对于小数有用,指定多少位小数:
在这里插入图片描述

上面就是保留两位小数。

再来个保留五位小数的:
在这里插入图片描述

mod

取模的函数:
在这里插入图片描述
关于负数取模咋做的我这里就不说了,重点不在这,不会的同学自行搜一搜。

rand

产生随机数的函数,产生的数的范围是[0, 1.0):
在这里插入图片描述

如果你想要你指定范围的数,乘以几然后加加减减就行,比如说我想要0 ~ 100的:
在这里插入图片描述

如果不想要小数部分就直接用format:
在这里插入图片描述

其他函数

user

查询当前以什么身份登录:
在这里插入图片描述

database

当前选中的是哪个数据库:
在这里插入图片描述

md5

加密的东西,其实也不算加密,就是形成一个数据摘要,我前面在讲HTTPS的时候带过一嘴:
在这里插入图片描述
这个函数会形成一个摘要,所有的字符串形成的摘要都是等长的,但基本上不可能出现两个不同字符串产生相同摘要的情况,但是同一个字符串的摘要是相同的:
在这里插入图片描述

两个字符串哪怕是差了一个字符结果也都会相差很多:
在这里插入图片描述

一般数据库中不会直接保存用户的登录密码,一般都是先形成摘要然后再保存到数据库中,这样如果数据库被黑了,其中的数据黑客拿到后没法轻松的获取到用户的密码,这样用户的重要信息就不会泄漏。用户登录的时候是用密码先形成摘要,然后如果数据库有这个摘要就会登陆成功,如果没有这个摘要就认证失败。

还有一个password函数:
在这里插入图片描述

形成的摘要更长,password用的也是比md5多一点。

password形成的摘要也都是等长的。

ifnull(val1, val2)

这个函数和三木运算符有点像,如果val1是NULL就会返回val2,如果不是NULL就会返回val1,就好比val1 == NULL ? val2 :val1。

例子:
在这里插入图片描述

在这里插入图片描述
这个函数有些地方还是很有用的,我下一篇讲符合查询的时候就会用到。

这篇就介绍这么多。

到此结束。。。

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

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

相关文章

Python实现视频字幕时间轴格式转换

自己喜欢收藏电影,有时网上能找到的中文字幕文件都不满足自己电影版本。在自己下载的压制版电影中已内封非中文srt字幕时,可以选择自己将srt的时间轴转为ass并替换ass中的时间轴。自己在频繁 复制粘贴改格式的时候想起可以用Python代码完成转换这一操作&…

Windows配置全局代理

一. Windows下为PowerShell/CMD/Git设置代理 —————————————————————————————————————————————————————— 二. [WinError 10061] 由于目标计算机积极拒绝,无法连接。 keyerror:192。 HTTP Error 403: Forbidd…

TikTok科技前沿:探索短视频创新应用

随着科技的不断发展,短视频平台TikTok已经不仅仅是一个简单的社交娱乐平台,更成为了数字创意和技术创新的前沿阵地。本文将深入探讨TikTok在科技前沿的探索,揭示短视频平台如何借助先进技术实现创新,以及这些创新对数字时代的影响…

Altium Designer学习笔记4

学会添加库。 元器件添加成功。 放置TYPE-C元器件。 绘制网络标识和电源端口,并且添加文字备注。 修改元器件的属性。

华为ac+fit无线2层漫游配置案例

ap的管理dhcp在ac上,业务dhcp在汇聚交换机上、并且带2层漫游 R1: interface GigabitEthernet0/0/0 ip address 11.1.1.1 255.255.255.0 ip route-static 12.2.2.0 255.255.255.0 11.1.1.2 ip route-static 192.168.0.0 255.255.0.0 11.1.1.2 lsw1: vlan batch 100…

【深度学习实验】注意力机制(二):掩码Softmax 操作

文章目录 一、实验介绍二、实验环境1. 配置虚拟环境2. 库版本介绍 三、实验内容0. 理论介绍a. 认知神经学中的注意力b. 注意力机制: 1. 注意力权重矩阵可视化(矩阵热图)2. 掩码Softmax 操作a. 导入必要的库b. masked_softmaxc. 实验结果 ​ …

论文《A recurrent latent variable model for sequential data》笔记:详解VRNN

A recurrent latent variable model for sequential data 背景 1 通过循环神经网络的序列建模 循环神经网络(RNN)可以接收一个可变长度的序列 x ( x 1 , x 2 , . . . , x T ) x (x_1, x_2, ..., x_T) x(x1​,x2​,...,xT​)作为输入,并通…

MATLAB 模型预测控制(MPC)控制入门 —— 设计并仿真 MPC 控制器

系列文章目录 MATLAB 模型预测控制(MPC) 文章目录 系列文章目录前言一、使用 MPC Designer 设计控制器1.1 CSTR 模型1.2 导入被控对象并定义 MPC 结构1.3 定义输入和输出通道属性1.4 配置仿真场景1.5 配置控制器水平线1.6 定义输入约束条件1.7 指定控制…

SpringBoot-Docker容器化部署发布

在生产环境都是怎么部署 Spring Boot? 打成 jar 直接一键运行打成 war 扔到 Tomcat 容器中运行容器化部署 一、准备Docker 在 CentOS7 上安装好 Docker 修改 Docker 配置,开启允许远程访问 Docker 的功能,开启方式很简单,修改 /usr/lib/s…

第四代可燃气体监测仪:可燃气体监测仪在燃气管网中的作用有哪些

燃气管网如同城市的血脉,纵横交错着覆盖在每一寸土地。然而如此复杂的管网,仅靠人工巡查难免有些力不从心。毕竟人工监测的范围有其局限性,难以做到全方位、全天候的紧密监测,难免会有疏忽和遗漏。如何将安全隐患消灭于萌芽状态&a…

Linux CentOS 8(DNS的配置与管理)

Linux CentOS 8(DNS的配置与管理) 目录 一、DNS相关知识1.1 DNS简介1.2 DNS的解析原理1.3 DNS解析 二、DNS服务器部署2.1 不使用chroot模式启动DNS2.2 使用chroot模式DNS 三、DNS配置文件详解3.1 主配文件详解3.2 区域数据库文件详解 四、项目实施4.1 主…

【每日OJ —— 225.用队列实现栈(队列)】

每日OJ —— 225.用队列实现栈(队列) 1.题目:225.用队列实现栈(队列)2.解法2.1.解法讲解:2.1.1.算法讲解2.1.2.代码实现2.1.3.提交通过展示 1.题目:225.用队列实现栈(队列&#xff0…

php伪随机数

利用工具 php_mt_seed <?php // php 7.2function white_list() {return mt_rand();}echo white_list(), "\n";echo white_list(), "\n";echo white_list(), "\n"; 输入命令&#xff1a; ./php_mt_seed 1035656029 <?phpmt_srand(181095…

关于校园网使用罗技flow功能

目录 情况概述问题及解决方案 情况概述 我目前设备是一台Macbook air m1处理器&#xff0c;学校给配了一台windows台式&#xff0c;台式机不能连蓝牙&#xff0c;不能连wifi&#xff0c;只能用网线&#xff0c;我的需求是想让mac和windows共用一套键鼠&#xff0c;在了解到罗技…

echarts 实现3D立体柱状图示例

该示例有如下几个特点&#xff1a; ①实现tooltip自定义样式&#xff08;echarts 实现tooltip提示框样式自定义-CSDN博客&#xff09; ②数据为0时&#xff0c;顶部四边形不展示 ③legend图标设置为自定义图片 【第②也是一个难点&#xff0c;我没有找到其他解决办法&#xff…

从小米14安装不上应用说起【适配64位】

一、原因 某天早上&#xff0c;同事突然对我说我换了小米14pro手机但是安装不了公司的打卡软件&#xff0c;怎么办呀。一时间&#xff0c;我也不知道原因&#xff0c;看到给我发的安装不上的截图陷入了沉思。随即打开在git仓库里找到这个项目&#xff0c;到本地编译打开&#…

对比学习15篇顶会论文及代码合集,2023最新

对比学习&#xff08;contrastive learning&#xff09;是现在无监督学习中一种常用的学习机制&#xff0c;它可以在没有标签的数据上进行学习&#xff0c;避免依赖大量标签数据&#xff0c;从而帮助我们更好地理解和利用数据集中的信息&#xff0c;提高模型的性能和表现。 作…

【前端学java】java中的字符串操作(10)

往期回顾&#xff1a; 【前端学java】JAVA开发的依赖安装与环境配置 &#xff08;0&#xff09;【前端学 java】java的基础语法&#xff08;1&#xff09;【前端学java】JAVA中的packge与import&#xff08;2&#xff09;【前端学java】面向对象编程基础-类的使用 &#xff08…

springcloud学生选课系统源码

开发技术&#xff1a; jdk1.8&#xff0c;mysql5.7&#xff0c;idea&#xff0c;nodejs&#xff0c;vscode springcloud springboot mybatis vue elementui 功能介绍&#xff1a; 学生&#xff1a; 登录&#xff0c;统计分析&#xff0c;选课&#xff08;查看课程及选择&a…

API网关那些事【架构新知系列】

目前随着云原生ServiceMesh和微服务架构的不断演进&#xff0c;网关领域新产品不断出现&#xff0c;各种网关使用的技术&#xff0c;功能和应用领域也不断扩展&#xff0c;在各有所长的前提下也有很多功能重合&#xff0c;网上各种技术PR文章&#xff0c;评测资料和网关落地实践…