psycopg - 将gzip压缩数据插入bytea列

时间:2012-10-25 03:59:18

标签: python postgresql psycopg2

我正在尝试gzip一个字符串,然后使用psycopg2将其写入bytea列。

表格

CREATE TABLE test
(
  data bytea
)

插入

import psycopg2

data = "some string".encode("zlib") # 'x\x9c+\xce\xcfMU(.)\xca\xccK\x07\x00\x1ak\x04l'

conn = psycopg2.connect("my parameters")
cur = conn.cursor()
cur.execute("INSERT INTO public.test VALUES (%s)", (data,))

    Traceback (most recent call last):
      File "<stdin>", line 1, in <module>
    psycopg2.DataError: invalid byte sequence for encoding "UTF8": 0x9c

这是图书馆的问题吗?我需要以某种方式更改编码吗?任何帮助表示赞赏。

1 个答案:

答案 0 :(得分:17)

如果要将二进制数据插入数据库,则需要使用psycopg2.Binary()包装器。使用像您所做的字符串将导致数据被视为文本,这些文本将因编码问题而被拒绝,或者在您尝试再次阅读时被接受但受损。

尝试用:

替换最后一次执行调用
cur.execute("INSERT INTO public.test VALUES (%s)", (psycopg2.Binary(data),))