如何使用Django的ORM和PostgreSQL后端存储二进制数据的“blob”?是的,我知道Django对这种事情感到皱眉,是的,我知道他们更喜欢你使用ImageField或FileField,但这足以说明,这对我的应用来说是不切实际的。
我尝试使用TextField进行黑客攻击,但是当我的二进制数据没有严格确认模型编码类型(默认为unicode)时,我会遇到偶然的错误。例如
psycopg2.DataError: invalid byte sequence for encoding "UTF8": 0xe22665
答案 0 :(得分:26)
这个片段有什么好处:
http://djangosnippets.org/snippets/1597/
这可能是将二进制数据存储在a中的最简单的解决方案 TextField更新。
import base64
from django.db import models
class Foo(models.Model):
_data = models.TextField(
db_column='data',
blank=True)
def set_data(self, data):
self._data = base64.encodestring(data)
def get_data(self):
return base64.decodestring(self._data)
data = property(get_data, set_data)
那里还有其他几个片段可能会有所帮助。
答案 1 :(得分:21)
如果你使用的是Django> = 1.6,那就是BinaryField
答案 2 :(得分:10)
我一直在将这个简单的字段用于'mysql'后端,你可以为其他后端修改它
class BlobField(models.Field):
description = "Blob"
def db_type(self, connection):
return 'blob'
答案 3 :(得分:0)
另外,请查看Django Storages' Database Storage:。
我还没有使用它,但它看起来很棒,我会在发布我的答案后立即开始使用它。