7

我正在尝试 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

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

4

1 回答 1

19

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

尝试将最后一个执行调用替换为:

cur.execute("INSERT INTO public.test VALUES (%s)", (psycopg2.Binary(data),))
于 2012-10-25T04:05:15.317 回答