postgresql:md5消息摘要的数据类型?

象嘉道*_*象嘉道 9 database postgresql database-design

我想使用某些字符串的MD5消息摘要作为表的主键.我应该为这样的字段使用什么数据类型?我应该为该领域写什么selectinsert陈述?

Clo*_*eto 12

bytea对于hexa表示,md5哈希将仅使用16个字节而不是32个字节:

create table t (d bytea);
insert into t (d) values
    (digest('my_string', 'md5')),
    (decode(md5('my_string'), 'hex'));
Run Code Online (Sandbox Code Playgroud)

上面的两种形式都可以使用,但是要使用更简单的digest功能,必须以pgcrypto超级用户身份安装扩展:

create extension pgcrypto;
Run Code Online (Sandbox Code Playgroud)

使用digest函数或decode以及md5如上所述的组合来搜索某个字符串:

select
    octet_length(d) ba_length,
    pg_column_size(d) ba_column,
    encode(d, 'hex') hex_representation,
    octet_length(encode(d, 'hex')) h_length,
    pg_column_size(encode(d, 'hex')) h_column
from t
where d = digest('my_string', 'md5')
;
 ba_length | ba_column |        hex_representation        | h_length | h_column 
-----------+-----------+----------------------------------+----------+----------
        16 |        17 | 3d212b21fad7bed63c1fb560c6a5c5d0 |       32 |       36
        16 |        17 | 3d212b21fad7bed63c1fb560c6a5c5d0 |       32 |       36
Run Code Online (Sandbox Code Playgroud)

pg_column_size值是存储大小.bytea与hexa表示相比,它不到一半.