当前位置: 首页 > news >正文

青岛网站设计工作室合肥网络营销公司

青岛网站设计工作室,合肥网络营销公司,织梦网站专题页面如何做,html网站源代码MySQL提供了多种加密和压缩方式,可以帮助保护数据库中的敏感数据。以下是一些常见的MySQL加密和压缩方法参考: 建议收藏以备后续用到查阅参考。 目录 一、AES_ENCRYPT AES加密 二、AES_DECRYPT AES解密 三、COMPRESS 压缩字符串 四、UNCOMPRESS 解压…

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.hkea.cn/news/520556/

相关文章:

  • 公司创建一个网站需要多少钱想做百度推广找谁
  • 做文献ppt模板下载网站有哪些常德政府网站
  • 青岛网站建设公司排行外链工具在线
  • 网站怎么做显得简洁美观seo数据是什么意思
  • 阿里巴巴开通诚信通后网站怎么做网络优化网站
  • 东莞手机网站价格便宜个人免费建站软件
  • 电子商务网站建设的步骤一般为百度100%秒收录
  • 做企业网站怎么样免费的推广软件下载
  • 拓普网站建设美国搜索引擎
  • 网站开发者工资冯耀宗seo视频教程
  • 软件开发各阶段工作量比例搜索引擎优化的基础是什么
  • 网站怎么做才能将名声打响云搜索app
  • 南阳做网站优化哪家好一级域名生成二级域名
  • 3322动态域名官网郑州seo联系搜点网络效果好
  • 网络营销渠道的类型河北seo基础教程
  • 做微信网站多少钱seo内部优化包括哪些内容
  • 中国城乡建设网站网络优化公司排名
  • 个人网站做淘宝客教程torrentkitty磁力搜索引擎
  • 广州北京网站建设seo培训讲师招聘
  • 手机上免费自己做网站网络营销案例分享
  • 长沙大型网站建设谷歌账号
  • 大兴德艺网站建设发布悬赏任务的推广平台
  • html5制作网站模板百度产品大全首页
  • 贵阳网站建设贵阳百度推广怎么推广
  • 瓮安建设局网站google play三件套
  • 大型门户网站模板营销神器
  • 学设计的网站都有哪些seo和sem
  • 如何做网站流量买卖营销型网站的特点
  • 装修设计网站哪个平台最好软文推广多少钱一篇
  • 怎么做微信里的网页网站链接网站设计平台