首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在MySQL中存储SHA1哈希值

在MySQL中存储SHA1哈希值
EN

Stack Overflow用户
提问于 2009-03-05 19:57:17
回答 6查看 114.7K关注 0票数 161

存储散列结果的VARCHAR字段应该有多长时间?

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2009-03-05 20:00:40

我会对可变长度的数据使用VARCHAR,但不会对固定长度的数据使用。

我也不会存储SHA1返回的值。因为它只使用每个字符4位,因此将需要160/4 = 40个字符。

因此,我建议您使用BINARY(20)UNHEX functionSHA1值转换为二进制。

代码语言:javascript
复制
CREATE TABLE `binary` (
    `id` int unsigned auto_increment primary key,
    `password` binary(20) not null
);
CREATE TABLE `char` (
    `id` int unsigned auto_increment primary key,
    `password` char(40) not null
);

在百万条记录中,binary(20)占4456M,而char(40)占6457M。

票数 316
EN

Stack Overflow用户

发布于 2009-03-05 11:58:51

一个SHA1散列有40个字符!

票数 45
EN

Stack Overflow用户

发布于 2009-03-05 12:03:06

sha1的输出大小为160位。它是160/8 == 20个字符(如果使用8位字符)或160/16 = 10 (如果使用16位字符)。

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/614476

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档