MySQL函数

MySQL函数简介

MySQL 函数是 MySQL 数据库提供的内部函数,这些内部函数可以帮助用户更加方便地处理表中的数据。函数就像预定的公式一样存放在数据库里,每个用户都可以调用已经存在的函数来完成某些功能。

提示:函数就是输入值然后得到相应的输出结果,输入值称为参数(parameter),输出值称为返回值。

函数可以很方便的地实现业务逻辑的重用,并且 MySQL 数据库允许用户自己创建函数,以适应实际的业务操作。正确使用函数会让读者在编写 SQL 语句时起到事半功倍的效果。

MySQL 函数用来对数据表中的数据进行相应的处理,以便得到用户希望得到的数据,使 MySQL 数据库的功能更加强大。

MySQL 函数包括数学函数、字符串函数、日期和时间函数、条件判断函数、系统信息函数和加密函数等。这些函数不仅能帮助用户做很多事情,比如字符串的处理、数值的运算、日期的运算等,还可以帮助开发人员编写出简单快捷的 SQL 语句。

SELECT、INSERT、UPDATE 和 DELETE 语句及其子句(例如 WHERE、ORDER BY、HAVING 等)中都可以使用 MySQL 函数。例如,数据表中的某个数据是负数,现在需要将这个数据显示为整数,这时就可以在 SELECT 语句中使用绝对值函数。

下面介绍这几类函数的使用范围。

  • 数学函数主要用于处理数字。这类函数包括绝对值函数、正弦函数、余弦函数和获得随机数的函数等。
    在这里插入图片描述

  • 字符串函数主要用于处理字符串。其中包括字符串连接函数、字符串比较函数、将字符串的字母都变成小写或大写字母的函数和获取子串的函数等。
    在这里插入图片描述

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

  • 条件判断函数主要用于在 SQL 语句中控制条件选择。其中包括 IF 语句、CASE 语句和 WHERE 语句等。

IF(expr,v1,v2)函数

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

SELECT IF(1>2,2,3),IF(1<2,'YES','NO'),IF(STRCMP('TEST','TEST1'),'NO','YES');

在这里插入图片描述
如果v1或者v2中只有一个明确是NULL,则IF()函数的结果类型为非NULL表达式结果类型。

IF(v1,v2)函数

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

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

在这里插入图片描述
注意:1/0的结果为空,因此IFNULL(1/0,‘wrong’)返回wrong.

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;

在这里插入图片描述
CASE后面的值为2,与第二条分支语句WHEN后面的值相等,因此返回’two’。

  • 系统信息函数主要用于获取 MySQL 数据库的系统信息。其中包括获取数据库名的函数、获取当前用户的函数和获取数据库版本的函数等。

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

SELECT VERSION()

在这里插入图片描述
返回指示mysql服务器版本的字符串,这个字符串使用utf8字符集。

SELECT CONNECTION_ID()

在这里插入图片描述
SHOW PROCESSLIST;
在这里插入图片描述

获取用户名的函数

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

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

在这里插入图片描述

  • **加密函数主要用于对字符串进行加密解密。**其中包括字符串加密函数和字符串解密函数等。

加密函数PASSWORD(str)

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

SELECT PASSWORD('newpwd');

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

加密函数MD5(str)

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

SELECT MD5('mypwd');

在这里插入图片描述

加密函数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');

在这里插入图片描述
可以看到,使用相同解密字符串进行解密之后的结果正好为ENCODE函数中被加密的字符串,DECODE函数和ENCODE函数互为反函数。

  • 其他函数主要包括格式化函数和锁函数等。

格式化函数FORMAT(x,n)

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

SELECT FORMAT(122232.123456,4),FORMAT(122232.1,4),FORMAT(122232.2,0)

在这里插入图片描述

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

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

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

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

SELECT INET_ATON('209.207.224.40');

在这里插入图片描述
INET_NTOA()将数值转为网络地址。

SELECT INET_NTOA(3520061480);

在这里插入图片描述

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

BENCHMARK(count,expr)函数重复count次执行表达式expr,它可以用于计算MYSQL处理表达式的速度。
SELECT PASSWORD(‘mypwd’);
在这里插入图片描述
执行500000次PASSWORD函数的速度如下:
SELECT BENCHMARK(500000,PASSWORD(‘mypwd’));
image.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值