[MySQL]流程控制函数&加密与解密函数&MySQL信息函数&其他函数

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: [MySQL]流程控制函数&加密与解密函数&MySQL信息函数&其他函数

dead3569791d402196fc110170b7d37b.jpg

1. 流程控制函数

流程处理函数可以根据不同的条件,执行不同的处理流程,可以在SQL语句中实现不同的条件选择。

MySQL中的流程处理函数主要包括IF()、IFNULL()和CASE()函数。

IF(value,value1,value2)

如果value的值为TRUE,返回value1,否则返回value2

SELECT last_name,salary,IF(salary >= 6000,'高工资','低工资') "details"
FROM employees;

SELECT last_name,commission_pct,IF(commission_pct IS NOT NULL,commission_pct,0) "details",
salary * 12 * (1 + IF(commission_pct IS NOT NULL,commission_pct,0)) "annual_sal"
FROM employees;

IFNULL(value1, value2)

如果value1不为NULL,返回value1,否则返回value2

SELECT last_name,commission_pct,IFNULL(commission_pct,0) "details"
FROM employees;

CASE WHEN 条件1 THEN 结果1 WHEN 条件2 THEN 结果2 … [ELSE resultn] END

相当于Java的if…else if…else…

SELECT last_name,salary,CASE WHEN salary >= 15000 THEN '白骨精'
           WHEN salary >= 10000 THEN '潜力股'
           WHEN salary >= 8000 THEN '小屌丝'
           ELSE '草根' END "details",department_id
FROM employees;

CASE expr WHEN 常量值1 THEN 值1 WHEN 常量值1 THEN 值1 … [ELSE 值n] END

相当于Java的switch…case…

# 查询部门号为 10,20, 30 的员工信息,
# 若部门号为 10, 则打印其工资的 1.1 倍,
# 20 号部门, 则打印其工资的 1.2 倍,
# 30 号部门,打印其工资的 1.3 倍数,
# 其他部门,打印其工资的 1.4 倍数
SELECT employee_id,last_name,department_id,salary,CASE department_id WHEN 10 THEN salary * 1.1
                     WHEN 20 THEN salary * 1.2
                     WHEN 30 THEN salary * 1.3
                     ELSE salary * 1.4 END "details"
FROM employees;

2. 加密与解密函数

加密与解密函数主要用于对数据库中的数据进行加密和解密处理,以防止数据被他人窃取。

这些函数在保证数据库安全时非常有用。

加密的操作可以在客户端实现,避免在信息传递给服务端的过程中被他人获取。

PASSWORD(str)

返回字符串str的加密版本,41位长的字符串。加密结果 不可逆 ,常用于用户的密码加密

MySQL8.0中弃用。

对于不可逆的加密,进行验证前后是否一致,可以匹配暗文。多次加密的结果一致。

MD5(str)

返回字符串str的md5加密后的值,也是一种加密方式。若参数为NULL,则会返回NULL 。加密结果 不可逆

对于不可逆的加密,进行验证前后是否一致,可以匹配暗文。多次加密的结果一致。

SHA(str)

从原明文密码str计算并返回加密后的密码字符串,当参数为NULL时,返回NULL。 加密结果 不可逆SHA加密算法比MD5更加安全

对于不可逆的加密,进行验证前后是否一致,可以匹配暗文。多次加密的结果一致。

ENCODE(value,password_seed)

返回使用password_seed作为加密密码,加密value

MySQL8.0中弃用。

DECODE(value,password_seed)

返回使用password_seed作为加密密码,解密value

ENCODE(value,password_seed)函数与DECODE(value,password_seed)函数互为反函数。

MySQL8.0中弃用。

3. MySQL信息函数

MySQL中内置了一些可以查询MySQL信息的函数,这些函数主要用于帮助数据库开发或运维人员更好地对数据库进行维护工作。

VERSION()

返回当前MySQL的版本号

CONNECTION_ID()

返回当前MySQL服务器的连接数

DATABASE(),SCHEMA()

返回MySQL命令行当前所在的数据库

USER(),CURRENT_USER()、SYSTEM_USER(), SESSION_USER()

返回当前连接MySQL的用户名,返回结果格式为 “主机名@用户名”

CHARSET(value)

返回字符串value自变量的字符集

COLLATION(value)

返回字符串value的比较规则

代码示例

SELECT
       VERSION(),
       CONNECTION_ID(),
       DATABASE(),
       SCHEMA(),
       USER(),
       CURRENT_USER(),
       CHARSET('尚硅谷'),
       COLLATION('尚硅谷')
FROM DUAL;

4. 其他函数

FORMAT(value,n)

返回对数字value进行格式化后的结果数据。n表示 四舍五入 后保留到小数点后n位

如果n的值小于或者等于0,则只保留整数部分

SELECT
       FORMAT(123.125,2),
       FORMAT(123.125,0),
       FORMAT(123.125,-2)
FROM DUAL;

CONV(value,from,to)

将value的值进行不同进制之间的转换,value为null返回结果为null。

SELECT
       CONV(16, 10, 2),
       CONV(8888,10,16),
       CONV(NULL, 10, 2)
FROM DUAL;

INET_ATON(ipvalue)

将以点分隔的IP地址转化为一个数字

计算方法:以“192.168.1.100”为例,计算方式为192乘以256的3次方,加上168乘以256的2次方,加上1乘以256,再加上100。

INET_NTOA(value)

将数字形式的IP地址转化为以点分隔的IP地址

INET_NTOA(value) 与INET_ATON(ipvalue) 实现的功能相反

SELECT
       INET_ATON('192.168.1.100'),
       INET_NTOA(3232235876)
FROM DUAL;

BENCHMARK(n,expr)

将表达式expr重复执行n次。用于测试MySQL处理expr表达式所耗费的时间

#BENCHMARK()用于测试表达式的执行效率
SELECT
       BENCHMARK(10000000,MD5('mysql'))
FROM DUAL;

CONVERT(value USING char_code)

将value所使用的字符编码修改为char_code

可以实现字符集的转换

SELECT
       CHARSET('atguigu'),
       CHARSET(CONVERT('atguigu' USING 'gbk'))
FROM DUAL;




相关文章
|
5天前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(2)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
3天前
|
存储 安全 关系型数据库
MYSQL--存储函数
MYSQL--存储函数
|
3天前
|
存储 SQL 关系型数据库
MySQL存储过程和存储函数的使用
MySQL的存储过程和存储函数在功能和用法上有明显的区别。存储过程是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,通过指定名称和参数(如果有)来调用执行,可以返回多个值或结果集,但不直接返回值。而存储函数则是一个有返回值的特殊存储过程,它返回一个值或表对象,可以直接嵌入SQL语句中使用,如SELECT语句中。两者都是为了提高SQL代码的重用性和性能,但使用场景和方式有所不同。
|
5天前
|
存储 关系型数据库 MySQL
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(4)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
5天前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(3)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
3天前
|
存储 SQL 安全
网络安全与信息安全:漏洞、加密与意识的三重奏
本文旨在探讨网络安全与信息安全领域的三个核心要素:网络漏洞、加密技术和安全意识。通过分析这些要素的重要性、当前面临的挑战以及应对策略,文章意在为读者提供深入理解并促进对网络安全和信息安全重要性的认识。我们将看到,尽管技术不断进步,但人为因素仍然是安全体系中最薄弱的环节。
|
3天前
|
SQL 安全 算法
网络安全与信息安全:漏洞、加密和安全意识的深度解析
在数字化时代,网络安全与信息安全已成为全球焦点。本文深入探讨网络安全漏洞的种类和防护措施,介绍加密技术在数据保护中的关键作用,强调安全意识在日常生活和工作中的重要性。通过案例分析和技术解读,我们揭示了保持网络安全的最佳实践和未来趋势。
|
9天前
|
SQL 安全 算法
网络安全的盾牌:加密技术与安全意识的双重保障
【6月更文挑战第6天】在数字化时代,网络安全已成为保护个人隐私和企业数据的关键。本文深入探讨了网络安全的两个重要支柱:加密技术和安全意识。我们将分析常见的网络安全漏洞,揭示加密技术如何为数据提供坚固的保护屏障,并强调提升个人和组织的安全意识对于防范网络攻击的重要性。通过结合技术手段和人为因素,我们可以构建一个更加安全的网络环境。
|
9天前
|
SQL 安全 网络安全
数字世界的守护者:网络安全漏洞、加密技术与安全意识的探索
在数字化浪潮中,网络安全成为维护信息完整性和隐私保护的关键防线。本文深入探讨了网络安全的核心问题——包括常见的网络漏洞、先进的加密技术以及公众的安全意识,旨在揭示这些因素如何共同塑造我们的数字环境。通过分析具体的安全事件和防御策略,文章提供了对现代网络威胁的深刻见解,并强调了个人和企业为抵御网络攻击所需采取的预防措施。
|
1天前
|
SQL 安全 算法
网络安全与信息安全:从漏洞到加密技术的全方位解析
本文将详细探讨网络安全与信息安全的各个方面,包括常见的安全漏洞、先进的加密技术以及提升安全意识的重要性。通过具体案例和技术细节,帮助读者更好地理解如何保护个人和企业的信息安全。

推荐镜像

更多