6

我有一个小脚本,我在其中生成 SHA1 哈希,通过 hashlib 的 hexdigest 获取二进制表示,并将它们存储在带有 bytea 列的 Postgres DB 中。我在 Postgres(缩写)中有一个如下所示的查询:

SELECT * FROM some_table WHERE some_hash in decode(another_hash, 'hex')

执行查询时,我有一些如下所示的代码:

cur.execute(query)
for hash_rep in cur:
    print bhash

现在,在该打印语句中,它要么打印出难以理解的字符,要么将其更改为:

print str(psycopg2.Binary(bhash))

我得到类似的东西:

'\214p\203\030\017K\247\373o\253'::bytea

将其转换回原始字符串的正确方法是什么?原始表示类似于“30d22d5d64efe4c5333e”,我想将其恢复为原始字符串以进行比较。我不确定我是否遗漏了一些明显的东西,

4

1 回答 1

7

由于您要求 Postgres 解码您的十六进制字符串并将其存储为二进制,因此您应该要求 postgres 在输出时将其编码回十六进制。

SELECT encode(some_hash, 'hex'), * FROM some_table WHERE some_hash in decode(another_hash, 'hex')

或者,您可以在 python 中进行编码。试试binascii.hexlify(data)

于 2015-03-26T00:31:41.320 回答