欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MYSQL加密和壓縮函數(shù)詳解以及實戰(zhàn)(附示例)

 更新時間:2023年12月22日 08:30:39   作者:小賢java  
這篇文章主要給大家介紹了關(guān)于MYSQL加密和壓縮函數(shù)詳解以及實戰(zhàn)的相關(guān)資料,加密函數(shù)主要用來對數(shù)據(jù)進行加密和界面處理,以保證某些重要數(shù)據(jù)不被別人獲取,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

MySQL提供了多種加密和壓縮方式,可以幫助保護數(shù)據(jù)庫中的敏感數(shù)據(jù)。以下是一些常見的MySQL加密和壓縮方法參考:

一、AES_ENCRYPT AES加密

MySQL AES_ENCRYPT() 函數(shù)使用 AES 加密算法加密一個字符串。

語法:

SELECT AES_ENCRYPT(str, key_str)

參數(shù)說:

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

  • key_str:必需的。密鑰。

返回值:

  • 加密后的二進制字符串。
  • 返回 NULL情況:任意參數(shù)為 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() 函數(shù)使用 AES 加密算法解密一個由 AES_ENCRYPT() 加密后的字符串。

語法:

SELECT AES_DECRYPT(crypt_str, key_str)

參數(shù)說明:

  • crypt_str:必需的。一個要加密的字符串。
  • key_str:必需的。密鑰。

返回值:

  • 解密后的原始明文字符串。
  • 返回 NULL情況:任意參數(shù)為 NULL。

示例:

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

三、COMPRESS 壓縮字符串

MySQL COMPRESS() 函數(shù)壓縮一個字符串并返回壓縮后的二進制字符串。

要解壓縮 COMPRESS() 函數(shù)壓縮后的內(nèi)容,請使用 UNCOMPRESS() 函數(shù)。

語法:

COMPRESS(str)

參數(shù)說明:

  • str:必需的。一個要壓縮的字符串。

返回值:

  • 壓縮后的二進制字符串。
  • 返回 NULL情況:參數(shù)為 NULL。

示例:

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

        看似壓縮后的字符串比原字符串還要長。

        下面用函數(shù)REPEAT 函數(shù)來生成指定長度的字符串再壓縮看。

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() 函數(shù)解壓縮 COMPRESS() 函數(shù)壓縮后的字符串。

語法:

UNCOMPRESS(str_to_uncompress)

參數(shù)說明:

  • str_to_uncompress:必需的。一個要解壓縮的字符串。

返回值:

  • 解壓縮指定的字符串 str_to_uncompress,并將結(jié)果作為二進制字符串返回。
  • 返回 NULL情況:參數(shù)為 NULL。

示例:

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

五、UNCOMPRESSED_LENGTH 取壓縮字符串的原始字符串的長度

MySQL UNCOMPRESSED_LENGTH() 函數(shù)返回一個壓縮的字符串的原始字符串的長度。

語法:

UNCOMPRESSED_LENGTH(compressed_str)

參數(shù)說明:

  • compressed_str:必需的。一個使用 COMPRESS() 函數(shù)壓縮后的字符串。

返回值:

  • 一個壓縮的字符串的原始字符串的長度。
  • 返回 NULL情況:參數(shù)為NULL。

示例:

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

六、MD5 md5加密

MySQL MD5() 函數(shù)計算一個給定字符串的 MD5 摘要,并將結(jié)果作為一個 32 位的由十六進制字符組成的字符串返回。

語法:

MD5(str)

參數(shù)說明:

  • str:必需的。一個要計算 MD5 值的字符串。

返回值:

  • 32 位的由十六進制字符組成的字符串。
  • 返回 NULL情況:參數(shù)為 NULL。

示例:

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

七、RANDOM_BYTES 隨機生成指定長度字符串

MySQL RANDOM_BYTES() 函數(shù)隨機生成一個指定長度的的二進制串。

語法:

RANDOM_BYTES(len)

參數(shù)說明:

  • len:必需的。一個要計算 RANDOM_BYTES 值的字符串。

返回值:

  • 一個長度為 len 的由隨機字節(jié)產(chǎn)生的字符串。
  • 返回 NULL情況:參數(shù) 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() 函數(shù)計算并返回給定字符串的 SHA-1 160 位校驗和。 SHA() 函數(shù)與 MD5() 函數(shù)類似,也是一種計算摘要的函數(shù)。

MySQL SHA() 函數(shù)等效于 SHA1() 函數(shù)。

語法:

SHA(str)

參數(shù)說明:

  • str:必需的。一個要計算 SHA-1 160 位校驗和的字符串。

返回值:

  • 指定字符串的 SHA-1 160 位校驗和。(40 位的由十六進制字符組成的字符串)
  • 返回 NULL情況:參數(shù)為NULL。

示例:

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

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

MySQL SHA1() 函數(shù)計算并返回給定字符串的 SHA-1 160 位校驗和。 SHA1() 函數(shù)與 MD5() 函數(shù)類似,也是一種計算摘要的函數(shù)。
MySQL SHA1() 函數(shù)等效于 SHA() 函數(shù)。

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

MySQL SHA2() 函數(shù)計算并返回給定字符串的 SHA-2 摘要,包括: SHA-224, SHA-256, SHA-384, 和 SHA-512 算法。

SHA2() 函數(shù)與 MD5() 函數(shù)類似,也是一種計算摘要的函數(shù)。

語法:

SHA2(str, hash_length)

參數(shù)說明:

  • str:必需的。一個要計算 SHA-2 校驗和的字符串。
  • hash_length:必需的。哈希長度,可用值包括 224256384512 和 0 (相當(dāng)于 256), 分別對應(yīng)了 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() 函數(shù)計算以字符串形式給定的 SQL 語句的語句摘要哈希值并返回。

語法:

STATEMENT_DIGEST(sql_stmt)

參數(shù)說明:

  • 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的規(guī)范語句摘要

MySQL STATEMENT_DIGEST_TEXT() 函數(shù)返回以字符串形式給定的 SQL 語句的規(guī)范語句摘要。

語法:

STATEMENT_DIGEST_TEXT(sql_stmt)

參數(shù)說明:

  • sql_stmt:必需的。一個要計算規(guī)范語句摘要的字符串。

返回值:

  • SQL 語句的規(guī)范語句摘要。
  • 返回 NULL情況:任意參數(shù)為 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                        |
+------------------------------------------------------+-----------------------------+

總結(jié) 

到此這篇關(guān)于MYSQL加密和壓縮函數(shù)詳解及實戰(zhàn)的文章就介紹到這了,更多相關(guān)MYSQL加密和壓縮函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

相關(guān)文章

  • MySQL之高可用集群部署及故障切換實現(xiàn)

    MySQL之高可用集群部署及故障切換實現(xiàn)

    這篇文章主要介紹了MySQL之高可用集群部署及故障切換實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • MySQL復(fù)制問題的三個參數(shù)分析

    MySQL復(fù)制問題的三個參數(shù)分析

    這篇文章主要介紹了MySQL復(fù)制問題的三個參數(shù)分析,幫助大家更好的理解和學(xué)習(xí)使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下
    2021-04-04
  • 輕松上手MYSQL之SQL優(yōu)化之Explain詳解

    輕松上手MYSQL之SQL優(yōu)化之Explain詳解

    Explain是SQL分析工具中非常重要的一個功能,它可以模擬優(yōu)化器執(zhí)行查詢語句,幫助我們理解查詢是如何執(zhí)行的,這篇文章主要給大家介紹了關(guān)于輕松上手MYSQL之SQL優(yōu)化之Explain詳解的相關(guān)資料,需要的朋友可以參考下
    2024-06-06
  • SQL HAVING子句在GROUP BY中的條件篩選靈活運用

    SQL HAVING子句在GROUP BY中的條件篩選靈活運用

    這篇文章主要為大家介紹了SQL HAVING子句在GROUP BY中的條件篩選靈活運用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • SQL計算timestamp的差值的方法

    SQL計算timestamp的差值的方法

    這篇文章主要介紹了SQL計算timestamp的差值的方法的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • innodb_flush_method取值方法(實例講解)

    innodb_flush_method取值方法(實例講解)

    下面小編就為大家?guī)硪黄猧nnodb_flush_method取值方法(實例講解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • MySQL單表千萬級數(shù)據(jù)處理的思路分享

    MySQL單表千萬級數(shù)據(jù)處理的思路分享

    日前筆者需要處理MySQL單表千萬級的電子元器件數(shù)據(jù),進行數(shù)據(jù)歸類, 數(shù)據(jù)清洗以及器件參數(shù)處理,進而得出國產(chǎn)器件與國外器件的替換兼容性數(shù)據(jù),為電子工程師尋找國產(chǎn)替換件提供參考。
    2021-06-06
  • 解決Navicat Premium 連接 MySQL 8.0 報錯

    解決Navicat Premium 連接 MySQL 8.0 報錯"1251"的問題分析

    這篇文章主要介紹了解決Navicat Premium 連接 MySQL 8.0 報錯"1251"的問題分析,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • mysql免安裝制作使用說明

    mysql免安裝制作使用說明

    mysql免安裝版本的制作方法,需要的朋友可以參考下。
    2010-08-08
  • mysql data文件夾位置查找

    mysql data文件夾位置查找

    在mysql安裝之后,如何找到自己的mysql數(shù)據(jù)庫的安裝位置,本文將介紹詳細的解決方法,需要的朋友可以參考下
    2012-12-12

最新評論