当前位置:首页 > 文章列表 > 数据库 > MySQL > MySQL函数简介 2

MySQL函数简介 2

来源:SegmentFault 2023-02-24 17:36:03 0浏览 收藏

在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是数据库学习者,那么本文《MySQL函数简介 2》就很适合你!本篇内容主要包括MySQL函数简介 2,希望对大家的知识积累有所帮助,助力实战开发!

6.5 条件判断函数

条件判断函数也被称为控制流程函数,根据满足的条件的不同,执行相应的流程,Mysql中进行条件判断的有IF,IFNULL,和CASE。

6.5.1 IF(expr,v1,v2)函数

IF(expr,v1,v2)如果表达式expr是true(expr0 and exprNULL),则IF()的返回值为v1,否则返回v2。IF()的返回值为数字或字符串值。

SELECT IF(1>2,2,3),IF(1

image.png

如果v1或者v2中只有一个明确是NULL,则IF()函数的结果类型为非NULL表达式结果类型。

6.5.2 IF(v1,v2)函数

IFNULL(v1,v2)加入v1不为NULL,则IFNULL()的值为v1,否则返回值为v2,IFNULL的返回值是数字或者字符串。

SELECT IFNULL(1,2),IFNULL(NULL,10),IFNULL(1/0,'WRONG');

image.png

注意:1/0的结果为空,因此IFNULL(1/0,'wrong')返回wrong.

6.5.3 CASE函数

CASE expr WHEN v1 THEN[WHEN v2 THEN r2][ELSE rn] END.
该函数表示,如果expr值等于某个vn,则返回对应THEN后面的结果,如果与所有值都不相同则返回ELSE后面的rn。

SELECT
    CASE 5
WHEN 1 THEN
    'one'
WHEN 2 THEN
    'two'
ELSE
    'more'
END;

image.png

CASE后面的值为2,与第二条分支语句WHEN后面的值相等,因此返回'two'。

SELECT
    CASE
WHEN 1 

image.png

1

6.6 系统信息函数

Mysql中的系统信息有,数据库的版本号、当前用户名和连接数、系统字符集、最后一个自动生成的ID值。

6.6.1 获取mysql中的版本号,连接数,数据库名的函数。

SELECT VERSION()

image.png

返回指示mysql服务器版本的字符串,这个字符串使用utf8字符集。

SELECT CONNECTION_ID()

image.png

SHOW PROCESSLIST;

image.png

6.6.2 获取用户名的函数

USER(),CURRENT_USER,CURRENT_USER(),SYSTEM_USER()和SESSION_USER()这几个函数返回当前被mysql服务器验证的用户名和主机名组合。一般情况下这几个函数返回值是相同的。

SELECT USER(),CURRENT_USER(),SYSTEM_USER();

image.png

6.6.3 获取字符串的字符集和排序方式的函数

SELECT
CHARSET('abc'),
CHARSET(CONVERT('abc' USING latin1)),
CHARSET(VERSION())

image.png

       SELECT
       collation('abc'),
       COLLATION(CONVERT('abc' USING utf8))

image.png

6.6.4 获取最后一个自动生成的ID值的函数

LAST_INSERT_ID自动返回最后一个INSERT或者UPDATE为AUTO_INCREMENT列设置的第一个发生的值。
  1. 一次插入一条记录

INSERT INTO worker VALUES(NULL,'jimy');
INSERT INTO worker VALUES(NULL,'tony');
SELECT LAST_INSERT_ID();

image.png

image.png
  1. 一次同时插入多条

INSERT INTO worker VALUES(NULL,'kevry'),(NULL,'LILI'),(NULL,'miaomiao');

image.png

6.7 加密函数

加密函数主要用来对数据进行加密和界面处理以保证某些数据不被别人获取,这些数据在保证数据安全时非常有用。

6.7.1 加密函数PASSWORD(str)

PASSWORD(str)从原明文密码str计算并返回加密后的密码字符串,当参数为NULL时,返回NULL。
```
SELECT PASSWORD('newpwd');
```

image.png

PASSWORD函数在MYSQL服务器的鉴定系统中使用;不应该将它用在个人应用程序中。PASSWORD加密是单向的(不可逆)。PASSWORD()执行密码加密与Unix中密码被加密的方式不同。

6.7.2 加密函数MD5(str)

MD5(str)为字符串算出一个MD5 128比特校验和。该值以32位16进制数字的二进制字符串形式返回,若参数为NULL,则返回NULL。
```
SELECT MD5('mypwd');
```    

image.png

6.7.3 加密函数ENCODE(str,pswd_str)

ENCODE(str,pswd_str)使用pswd_str作为密码,加密str。使用DECODE()解密结果,结果是一个和str长度相同的二进制字符串。

    SELECT ENCODE('secret','cry'),LENGTH(ENCODE('secret','cry'));

image.png

可以看到加密后的显示结果为乱码,但加密后的长度和被加密字符串长度相同。

6.7.4 解密函数DECODE(crypt_str,pswd_str)

DECODE(crypt_str,pswd_str)使用pswd_str作为密码,解密加密字符串crypt_str,crypt_str是由ENCODE返回的字符串。

SELECT DECODE(ENCODE('secret','cry'),'cry');

image.png

可以看到,使用相同解密字符串进行解密之后的结果正好为ENCODE函数中被加密的字符串,DECODE函数和ENCODE函数互为反函数。

6.8 其他函数

6.8.1格式化函数FORMAT(x,n)

FORMAT(x,n)将数字x格式化,并以四舍五入的方式保留小数点后x位,结果以字符串的形式返回。若n为0,则返回结果函数不含小数部分。
```
SELECT FORMAT(122232.123456,4),FORMAT(122232.1,4),FORMAT(122232.2,0)
```

image.png

6.8.2 不同进制的数字进行转换函数 CONV(N,from_base,to_base)

CONV(N,from_base,to_base)进行不同进制间的转换。

6.8.3 IP地址与数字相互转换的函数INET_ATON(expr)

INET_ATON(expr) 给出一个作为字符串的网络地址,返回一个代表该地址数值的整数。地址可以是4或8比特地址。

SELECT INET_ATON('209.207.224.40');

image.png

INET_NTOA()将数值转为网络地址。

SELECT INET_NTOA(3520061480);

image.png

6.8.4 重复执行函数BENCHMARK(count,expr)

BENCHMARK(count,expr)函数重复count次执行表达式expr,它可以用于计算MYSQL处理表达式的速度。

SELECT PASSWORD('mypwd');

image.png

执行500000次PASSWORD函数的速度如下:

SELECT BENCHMARK(500000,PASSWORD('mypwd'));

image.png

6.9.1 数学函数

RAND()函数生成的随机数是在0-1之间,要生成0-10之间的随机数,RAND()需要乘以10,如果要求是整数,则还必须舍去结果的小数部分,这里使用ROUND()函数:
```
SELECT ROUND(RAND()*10);
```

image.png

6.9.2 如何从日期时间值中获取年月日等部分日期或者时间值?

MYSQL中,日期时间值以字符串的形式存储在数据标中,因此可以使用字符串函数截取日期时间值的不同部分,例如某个名称为dt的字段有值“2020-10-21 10:21:31”,如果只需要获取年的值,可以输入LEFT(dt,4),这样就获得了字符串左边开始长度为4的子字符串,即YEAR部分的值;
如果要获取月份,可以输入MID(dt,6,2)字符串第6个字符开始,长度为2的子字符串正好为月份值。

终于介绍完啦!小伙伴们,这篇关于《MySQL函数简介 2》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布数据库相关知识,快来关注吧!

版本声明
本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
Debian8(jessie)编译安装mariadb-10.2.30Debian8(jessie)编译安装mariadb-10.2.30
上一篇
Debian8(jessie)编译安装mariadb-10.2.30
2019年总结+文章列表
下一篇
2019年总结+文章列表
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 笔灵AI生成答辩PPT:高效制作学术与职场PPT的利器
    笔灵AI生成答辩PPT
    探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
    22次使用
  • 知网AIGC检测服务系统:精准识别学术文本中的AI生成内容
    知网AIGC检测服务系统
    知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
    32次使用
  • AIGC检测服务:AIbiye助力确保论文原创性
    AIGC检测-Aibiye
    AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
    36次使用
  • 易笔AI论文平台:快速生成高质量学术论文的利器
    易笔AI论文
    易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
    45次使用
  • 笔启AI论文写作平台:多类型论文生成与多语言支持
    笔启AI论文写作平台
    笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
    39次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码