我正在尝试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
这是图书馆的问题吗?我需要以某种方式更改编码吗?任何帮助表示赞赏。
答案 0 :(得分:17)
如果要将二进制数据插入数据库,则需要使用psycopg2.Binary()包装器。使用像您所做的字符串将导致数据被视为文本,这些文本将因编码问题而被拒绝,或者在您尝试再次阅读时被接受但受损。
尝试用:
替换最后一次执行调用cur.execute("INSERT INTO public.test VALUES (%s)", (psycopg2.Binary(data),))