python sqlite3 pickle 类型列有默认值

python sqlite3 pickle type column has default value

我们知道在数据库系统中(在我的例子中我们使用 sqlite3 作为示例),我们可以使用 BLOB 类型(二进制)或 TEXT 类型来存储任何 pickleable 对象。

data = [1,2,3] # b'\x80\x03]q\x00(K\x01K\x02K\x03e.'
create table test (value BLOB)
cursor.execute("insert into test values (?)", (pickle.dumps(data),)
## this works

但是如果我们想为列设置默认值怎么办? 例如

create table test (value BLOB default b'\x80\x03]q\x00(K\x01K\x02K\x03e.')
## obviously this is not working.

我知道一个解决方案是使用 base64

## because we know base64.b64encode(pickle.dumps([1,2,3])) =
## 'gANjYnVpbHRpbnMKc2V0CnEAXXEBKEsBSwJLA2WFcQJScQMu'
## so we can use:
create table test (value BLOB default 'gANjYnVpbHRpbnMKc2V0CnEAXXEBKEsBSwJLA2WFcQJScQMu')

但据我所知,在 SqlAlchemy PickleType 中,他们没有使用 base64 编码。因为这需要额外的时间。

任何人都知道如果我们想为 pickletype 列设置默认值,我应该怎么做?

sqlite 使用 'x' 或 'X' 作为 BLOB 字符串文字 (https://www.sqlite.org/lang_expr.html#hexint) 的前缀,所以虽然这 b'\x80\x03]q\x00(K\x01K\x02K\x03e.' 不起作用。这应该:

create table test (value BLOB default X'80035d7100284b014b024b03652e')