SQLAlchemy JSON 作为 blob/文本
我正在使用 MySQL 将 JSON 以 blob/文本的形式存储在列中.有没有一种简单的方法可以使用 python/SQLAlchemy 将其转换为 dict?
I'm storing JSON down as blob/text in a column using MySQL. Is there a simple way to convert this into a dict using python/SQLAlchemy?
推荐答案
您可以非常轻松地创建您自己的类型 使用 SQLAlchemy
You can very easily create your own type with SQLAlchemy
对于 SQLAlchemy 版本 >= 0.7,请查看下面的Yogesh 的回答
For SQLAlchemy versions >= 0.7, check out Yogesh's answer below
import jsonpickle
import sqlalchemy.types as types
class JsonType(types.MutableType, types.TypeDecorator):
impl = types.Unicode
def process_bind_param(self, value, engine):
return unicode(jsonpickle.encode(value))
def process_result_value(self, value, engine):
if value:
return jsonpickle.decode(value)
else:
# default can also be a list
return {}
这可以在您定义表时使用(示例使用 elixir):
This can be used when you are defining your tables (example uses elixir):
from elixir import *
class MyTable(Entity):
using_options(tablename='my_table')
foo = Field(String, primary_key=True)
content = Field(JsonType())
active = Field(Boolean, default=True)
你也可以使用不同的 json 序列化器来 jsonpickle.
You can also use a different json serialiser to jsonpickle.
相关文章