首頁 >資料庫 >mysql教程 >在 MySQL 中儲存 SHA1 雜湊值:BINARY(20) 還是 VARCHAR(40)?

在 MySQL 中儲存 SHA1 雜湊值:BINARY(20) 還是 VARCHAR(40)?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-11-20 20:11:18789瀏覽

 Storing SHA1 Hashes in MySQL: BINARY(20) or VARCHAR(40)?

在 MySQL 中儲存 SHA1 雜湊值:VARCHAR 欄位應該要多長?

在 MySQL 中儲存 SHA1 雜湊結果時對於資料庫,確定 VARCHAR 欄位的適當長度非常重要。 SHA1 值的長度為 160 位,因此應將其儲存在可容納此長度的欄位中。

這篇文章反對使用 VARCHAR 欄位來儲存 SHA1 雜湊值,因為它浪費了長度的額外位元組的固定長度欄位。相反,它建議使用 BINARY(20) 字段,該字段長度為 20 個字符,可以存儲 160 位 SHA1 值,而不浪費空間。

此外,文章建議使用 UNHEX 函數來轉換 SHA1將值儲存到 BINARY 欄位之前將其轉換為二進位。與儲存原始 SHA1 值相比,這減少了儲存要求。

本文透過比較 BINARY(20) 和 CHAR(40) 欄位的儲存要求得出結論。對於一百萬筆記錄,使用 InnoDB 引擎時,BINARY(20) 所需的空間比 CHAR(40) 少。

以上是在 MySQL 中儲存 SHA1 雜湊值:BINARY(20) 還是 VARCHAR(40)?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn