MYSQL加密和压缩函数详解和实战(含示例)

MySQL提供了多种加密和压缩方式,可以帮助保护数据库中的敏感数据。以下是一些常见的MySQL加密和压缩方法参考:

建议收藏以备后续用到查阅参考

目录

一、AES_ENCRYPT AES加密

二、AES_DECRYPT AES解密

三、COMPRESS 压缩字符串

四、UNCOMPRESS 解压COMPRESS压缩字符串

五、UNCOMPRESSED_LENGTH 取压缩字符串的原始字符串的长度

六、MD5 md5加密

七、RANDOM_BYTES 随机生成指定长度字符串

八、SHA 字符串的SHA-1 160 位校验和

九、SHA1 字符串的SHA-1 160 位校验和

十、SHA2 给定字符串的 SHA-2 摘要

十一、STATEMENT_DIGEST 取SQL的哈希值

十二、STATEMENT_DIGEST_TEXT 取SQL的规范语句摘要


一、AES_ENCRYPT AES加密

MySQL AES_ENCRYPT() 函数使用 AES 加密算法加密一个字符串。

语法:

SELECT AES_ENCRYPT(str, key_str)

参数说:

  • str:必需的。一个要加密的字符串。

  • key_str:必需的。密钥。

返回值:

  • 加密后的二进制字符串。
  • 返回 NULL情况:任意参数为 NULL。

示例:

mysql> SELECT  AES_ENCRYPT('hello', '123456'), AES_ENCRYPT(null, '123456'), AES_ENCRYPT('hello', NULL);
+--------------------------------+-----------------------------+----------------------------+
| AES_ENCRYPT('hello', '123456') | AES_ENCRYPT(null, '123456') | AES_ENCRYPT('hello', NULL) |
+--------------------------------+-----------------------------+----------------------------+
| ÈòIL&WÅæ4@s´                   | NULL                        | NULL                       |
+--------------------------------+-----------------------------+----------------------------+
1 row in set (0.00 sec)

二、AES_DECRYPT AES解密

MySQL AES_DECRYPT() 函数使用 AES 加密算法解密一个由 AES_ENCRYPT() 加密后的字符串。

语法:

SELECT AES_DECRYPT(crypt_str, key_str)

参数说明:

  • crypt_str:必需的。一个要加密的字符串。
  • key_str:必需的。密钥。

返回值:

  • 解密后的原始明文字符串。
  • 返回 NULL情况:任意参数为 NULL。

示例:

SELECT AES_DECRYPT(AES_ENCRYPT('hello', 'abcde'), 'abcde'),    // helloAES_DECRYPT(AES_ENCRYPT('hello', 'abcde'), null);       // NULL

三、COMPRESS 压缩字符串

MySQL COMPRESS() 函数压缩一个字符串并返回压缩后的二进制字符串。
要解压缩 COMPRESS() 函数压缩后的内容,请使用 UNCOMPRESS() 函数。

语法:

COMPRESS(str)

参数说明:

  • str:必需的。一个要压缩的字符串。

返回值:

  • 压缩后的二进制字符串。
  • 返回 NULL情况:参数为 NULL。

示例:

mysql> SELECT COMPRESS('hello'), LENGTH(COMPRESS('hello')),COMPRESS(''),LENGTH(COMPRESS(''));
+-------------------+---------------------------+--------------+----------------------+
| COMPRESS('hello') | LENGTH(COMPRESS('hello')) | COMPRESS('') | LENGTH(COMPRESS('')) |
+-------------------+---------------------------+--------------+----------------------+
|    x??H??? ,      |                        17 |              |                    0 |
+-------------------+---------------------------+--------------+----------------------+

        看似压缩后的字符串比原字符串还要长。

        下面用函数REPEAT 函数来生成指定长度的字符串再压缩看。

mysql> SELECT LENGTH(REPEAT('abc', 1000)),  LENGTH(COMPRESS(REPEAT('abc', 1000)));
+-----------------------------+---------------------------------------+
| LENGTH(REPEAT('abc', 1000)) | LENGTH(COMPRESS(REPEAT('abc', 1000))) |
+-----------------------------+---------------------------------------+
|                        3000 |                                    33 |
+-----------------------------+---------------------------------------+

        压缩效果:3000长度的字符串压缩后长度为33

四、UNCOMPRESS 解压COMPRESS压缩字符串

MySQL UNCOMPRESS() 函数解压缩 COMPRESS() 函数压缩后的字符串。

语法:

UNCOMPRESS(str_to_uncompress)

参数说明:

  • str_to_uncompress:必需的。一个要解压缩的字符串。

返回值:

  • 解压缩指定的字符串 str_to_uncompress,并将结果作为二进制字符串返回。
  • 返回 NULL情况:参数为 NULL。

示例:

mysql> SELECT UNCOMPRESS(COMPRESS('abcdefghjiklmnopqrstuvwxtz')),COMPRESS('abcdefghjiklmnopqrstuvwxtz');
+----------------------------------------------------+----------------------------------------+
| UNCOMPRESS(COMPRESS('abcdefghjiklmnopqrstuvwxtz')) | COMPRESS('abcdefghjiklmnopqrstuvwxtz') |
+----------------------------------------------------+----------------------------------------+
| abcdefghjiklmnopqrstuvwxtz                         |    x?KLJNIMK????????/(,*.)-+?(? ?}     |
+----------------------------------------------------+----------------------------------------+

五、UNCOMPRESSED_LENGTH 取压缩字符串的原始字符串的长度

MySQL UNCOMPRESSED_LENGTH() 函数返回一个压缩的字符串的原始字符串的长度。

语法:

UNCOMPRESSED_LENGTH(compressed_str)

参数说明:

  • compressed_str:必需的。一个使用 COMPRESS() 函数压缩后的字符串。

返回值:

  • 一个压缩的字符串的原始字符串的长度。
  • 返回 NULL情况:参数为NULL。

示例:

mysql> SELECT UNCOMPRESSED_LENGTH(COMPRESS('abcdefghjiklmnopqrstuvwxtz')),COMPRESS('abcdefghjiklmnopqrstuvwxtz');
+-------------------------------------------------------------+----------------------------------------+
| UNCOMPRESSED_LENGTH(COMPRESS('abcdefghjiklmnopqrstuvwxtz')) | COMPRESS('abcdefghjiklmnopqrstuvwxtz') |
+-------------------------------------------------------------+----------------------------------------+
|                                                          26 |    x?KLJNIMK????????/(,*.)-+?(? ?}     |
+-------------------------------------------------------------+----------------------------------------+

六、MD5 md5加密

MySQL MD5() 函数计算一个给定字符串的 MD5 摘要,并将结果作为一个 32 位的由十六进制字符组成的字符串返回。

语法:

MD5(str)

参数说明:

  • str:必需的。一个要计算 MD5 值的字符串。

返回值:

  • 32 位的由十六进制字符组成的字符串。
  • 返回 NULL情况:参数为 NULL。

示例:

mysql> SELECT MD5('abc');
+----------------------------------+
| MD5('abc')                       |
+----------------------------------+
| 900150983cd24fb0d6963f7d28e17f72 |
+----------------------------------+

七、RANDOM_BYTES 随机生成指定长度字符串

MySQL RANDOM_BYTES() 函数随机生成一个指定长度的的二进制串。

语法:

RANDOM_BYTES(len)

参数说明:

  • len:必需的。一个要计算 RANDOM_BYTES 值的字符串。

返回值:

  • 一个长度为 len 的由随机字节产生的字符串。
  • 返回 NULL情况:参数 len 为 NULL。

示例:

mysql> SELECT RANDOM_BYTES(10),LENGTH(RANDOM_BYTES(10)),RANDOM_BYTES(NULL);
+------------------+--------------------------+--------------------+
| RANDOM_BYTES(10) | LENGTH(RANDOM_BYTES(10)) | RANDOM_BYTES(NULL) |
+------------------+--------------------------+--------------------+
| ?m	 ??        |                       10 | NULL               |
+------------------+--------------------------+--------------------+

八、SHA 字符串的SHA-1 160 位校验和

MySQL SHA() 函数计算并返回给定字符串的 SHA-1 160 位校验和。 SHA() 函数与 MD5() 函数类似,也是一种计算摘要的函数。
MySQL SHA() 函数等效于 SHA1() 函数。

语法:

SHA(str)

参数说明:

  • str:必需的。一个要计算 SHA-1 160 位校验和的字符串。

返回值:

  • 指定字符串的 SHA-1 160 位校验和。(40 位的由十六进制字符组成的字符串)
  • 返回 NULL情况:参数为NULL。

示例:

mysql> SELECT SHA('hello'),SHA(NULL);
+------------------------------------------+-----------+
| SHA('hello')                             | SHA(NULL) |
+------------------------------------------+-----------+
| aaf4c61ddcc5e8a2dabede0f3b482cd9aea9434d | NULL      |
+------------------------------------------+-----------+

九、SHA1 字符串的SHA-1 160 位校验和

MySQL SHA1() 函数计算并返回给定字符串的 SHA-1 160 位校验和。 SHA1() 函数与 MD5() 函数类似,也是一种计算摘要的函数。
MySQL SHA1() 函数等效于 SHA() 函数。

十、SHA2 给定字符串的 SHA-2 摘要

MySQL SHA2() 函数计算并返回给定字符串的 SHA-2 摘要,包括: SHA-224, SHA-256, SHA-384, 和 SHA-512 算法。
SHA2() 函数与 MD5() 函数类似,也是一种计算摘要的函数。

语法:

SHA2(str, hash_length)

参数说明:

  • str:必需的。一个要计算 SHA-2 校验和的字符串。
  • hash_length:必需的。哈希长度,可用值包括 224256384512 和 0 (相当于 256), 分别对应了 SHA-224, SHA-256, SHA-384, 和 SHA-512 算法。

返回值:

  • 一个由十六进制字符组成的字符串,它是指定字符串的 SHA-2 摘要。

示例:

mysql> SELECT SHA2('hello', 224),SHA2(NULL, 1);
+----------------------------------------------------------+---------------+
| SHA2('hello', 224)                                       | SHA2(NULL, 1) |
+----------------------------------------------------------+---------------+
| ea09ae9cc6768c50fcee903ed054556e5bfc8347907f12598aa24193 | NULL          |
+----------------------------------------------------------+---------------+

十一、STATEMENT_DIGEST 取SQL的哈希值

MySQL STATEMENT_DIGEST() 函数计算以字符串形式给定的 SQL 语句的语句摘要哈希值并返回。

语法:

STATEMENT_DIGEST(sql_stmt)

参数说明:

  • sql_stmt:必需的。一个要计算语句摘要哈希值的字符串。

返回值:

  • 以字符串形式给定的 SQL 语句的语句摘要哈希值。

示例:

mysql> SELECT STATEMENT_DIGEST('SELECT 1'),STATEMENT_DIGEST(NULL);
+------------------------------------------------------------------+------------------------+
| STATEMENT_DIGEST('SELECT 1')                                     | STATEMENT_DIGEST(NULL) |
+------------------------------------------------------------------+------------------------+
| d1b44b0c19af710b5a679907e284acd2ddc285201794bc69a2389d77baedddae | NULL                   |
+------------------------------------------------------------------+------------------------+

十二、STATEMENT_DIGEST_TEXT 取SQL的规范语句摘要

MySQL STATEMENT_DIGEST_TEXT() 函数返回以字符串形式给定的 SQL 语句的规范语句摘要。

语法:

STATEMENT_DIGEST_TEXT(sql_stmt)

参数说明:

  • sql_stmt:必需的。一个要计算规范语句摘要的字符串。

返回值:

  • SQL 语句的规范语句摘要。
  • 返回 NULL情况:任意参数为 NULL。

示例:

mysql> SELECT STATEMENT_DIGEST_TEXT('SELECT * FROM t WHERE a = 1'),STATEMENT_DIGEST_TEXT(NULL);
+------------------------------------------------------+-----------------------------+
| STATEMENT_DIGEST_TEXT('SELECT * FROM t WHERE a = 1') | STATEMENT_DIGEST_TEXT(NULL) |
+------------------------------------------------------+-----------------------------+
| SELECT * FROM `t` WHERE `a` = ?                      | NULL                        |
+------------------------------------------------------+-----------------------------+

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

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

相关文章

JavaScript WebApi 一(详讲)

基础知识在前面的部分已经讲过了,大家如果没有学习过JavaScript的可以去看一下 1.DOM 引入 在JavaScript中,DOM(文档对象模型)提供了一种表示和操作HTML文档的方式。在DOM中,文档被表示为一个由节点组成的树形结构。…

nodejs最新电商jd m端h5st 4.2签名算法4.2版本逆向,jd API接口,jd商品数据采集

前言: jd m端使用最新的h5st 4.2签名算法,与h5st 4.1版本有很大的不同。在这儿分析一下,供大家参考。 一、目标地址(Base64解码) aHR0cHM6Ly9zby5tLmpkLmNvbS93YXJlL3NlYXJjaC5hY3Rpb24/a2V5d29yZD0lRTklOTklQTQlRTYlQjklQkYlRTYlOUMlQkEmc2…

java编程:给定⼀组正整数数组M,找出M数组中N项和为给定数S。如果有多对N项数字的和都等于 S,则输出N个数的乘积最⼩的哪⼀项,没有则返回空

题目: 编程题:给定⼀组正整数数组M,找出M数组中N项和为给定数S。如果有多对N项数字的和都等于 S,则输出N个数的乘积最⼩的哪⼀项,没有则返回空; 程序如下: 测试主程序: 先看下测试示…

Linux系统centos7防火墙firewall开放IP及端口命令

CentOS7使用的是firewall防火墙,不再是原来的iptables 防火墙基础命令 1:查看firewall防火墙状态 firewall-cmd --state //或 systemctl status firewalld2:打开防火墙 systemctl start firewalld3:关闭防火墙 systemctl sto…

如何利用CHAT 进行扩写?

问CHAT:开发利用这些矿产资源的同时,我们也不能忽视环境保护的重要性。要以科学、合理、绿色环保的原则为指导,保护好帕米尔高原的生态环境,实现其可持续发展,以取得全局上的真正利益,按照以上文字进行简单…

实体类转SQL工具类

主要的目标是简化开发人员在有实体类的情况下时做的重复性工作,提高开发效率。 单个实体类的转换工具类 1.EntityToTableConverter工具类 import java.io.FileWriter; import java.io.IOException; import java.lang.reflect.Field; import java.math.BigDecimal…

java 偏向锁 10个课题

于Hotpot JVM中的偏向锁,大部分开发者都比较熟悉或者至少听说过。那我们用下面10个关于偏向锁的进阶问题,检验一下自己离精通还有多远。 如何判断当前锁对象为偏向锁偏向锁如何判断锁重入当代码运行至synchronized修饰的代码块时,符合什么条件才会尝试获取偏向锁线程进入偏向…

esp32-s3部署yolox_nano进行目标检测

ESP32-S3部署yolox_nano进行目标检测 一、生成模型部署项目01 环境02 配置TVM包03 模型量化3.1预处理3.2 量化 04 生成项目 二、烧录程序 手上的是ESP32-S3-WROOM-1 N8R8芯片,整个链路跑通了,但是识别速度太慢了,20秒一张图,所以暂…

3D数字孪生场景编辑器

在线工具推荐: 3D数字孪生场景编辑器 - GLTF/GLB材质纹理编辑器 - 3D模型在线转换 - Three.js AI自动纹理开发包 - YOLO 虚幻合成数据生成器 - 三维模型预览图生成器 数字孪生的强大功能来自于将真实世界的资产与真实世界的数据联系起来,因此您可以…

C# WPF上位机开发(开篇)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 之前很少用到c#语言,大部分时间都用c/c,主要是它可以兼顾上位机qt开发以及嵌入式开发。所以,用c/c是比较合理的…

Vue3-路由

VueRouter4路由语法解析 1.创建路由实例由createRouter实现 2.路由模式 1)history模式使用createWebHistory():地址栏不带# 2)hash模式使用createWebHashHistory():地址栏带# 3)参数是基础路径,默认/ …

latex中算法的几种模板

latex中算法的几种模板_latex算法模板-CSDN博客文章浏览阅读6.2k次,点赞3次,收藏45次。latex中几种算法模板_latex算法模板https://blog.csdn.net/weixin_50514171/article/details/125136121?spm1001.2014.3001.5506

【JavaEE】多线程 (2) --线程安全

目录 1. 观察线程不安全 2. 线程安全的概念 3. 线程不安全的原因 4. 解决之前的线程不安全问题 5. synchronized 关键字 - 监视器锁 monitor lock 5.1 synchronized 的特性 5.2 synchronized 使⽤⽰例 1. 观察线程不安全 package thread; public class ThreadDemo19 {p…

mysql数据库基本概念简介

概述 为什么要使用数据库? 答:实现数据的持久化。 数据库存储类型多样,存储量大。由于其他文件等介质。 概念 DB:database(数据库),保存数据的仓库,本质是一个文件系统。 DBMS:数据库管理系统,常说的Mysql数…

无公网IP下,如何实现公网远程访问MongoDB文件数据库

文章目录 前言1. 安装数据库2. 内网穿透2.1 安装cpolar内网穿透2.2 创建隧道映射2.3 测试随机公网地址远程连接 3. 配置固定TCP端口地址3.1 保留一个固定的公网TCP端口地址3.2 配置固定公网TCP端口地址3.3 测试固定地址公网远程访问 前言 MongoDB是一个基于分布式文件存储的数…

抖音本地生活服务商申请条件

抖音的本地生活服务商目前有两种,一种是可以做全国的服务商,我们一般叫抖音本地生活服务商,一种是区域优待服务商,也就是后面出来的服务商,这两种服务商的申请方式大同小异。 相同的地方就是都需要给平台交保证金。抖…

网站监控有什么作用?

科技改变生活,科技的发展让我们的生活越来越精彩丰富,数据中心机房监控系统也可以称为“自我监控系统”,主要是针对机房所有的设备及环境进行集中监控和管理的,其监控对象构成机房的各个子系统:动力系统、环境系统、消…

CV计算机视觉每日开源代码Paper with code速览-2023.11.23

点击CV计算机视觉,关注更多CV干货 论文已打包,点击进入—>下载界面 点击加入—>CV计算机视觉交流群 1.【基础网络架构:Transformer】White-Box Transformers via Sparse Rate Reduction: Compression Is All There Is? 论文地址&am…

【Java】文件I/O-字节流转换成字符流

上文中我们讲了Reader,Writer,InputStream,OutputStream这四种流的基本用法🔢 【Java】文件I/O-文件内容操作-输入输出流-Reader/Writer/InputStream/OutputStream四种流 其中InputStream和OutputStream两个类涉及到的都是byte&…

rabbitMQ对消息不可达处理-备份交换机/备份队列

生产者发送消息,在消息不可达指定队列时,可以借助扇出类型交换机(之前写过消息回退的处理方案,扇出交换机处理的方案优先级高于消息回退)处理不可达消息,然后放置一个备份队列,供消费者处理不可…