如何使用 Django 的 ORM 和 PostgreSQL 后端存储二进制数据的“blob”?是的,我知道 Django 不赞成这种事情,是的,我知道他们更喜欢你使用 ImageField 或 FileField 来实现这一点,但我只想说,这对我的应用程序来说是不切实际的。
我尝试过使用 TextField 来破解它,但是当我的二进制数据没有严格确认模型编码类型(默认情况下为 unicode)时,我会偶尔遇到错误。例如
psycopg2.DataError: invalid byte sequence for encoding "UTF8": 0xe22665
如果您使用的是 Django >= 1.6,则有一个 BinaryField
这个片段有什么好处:
http://djangosnippets.org/snippets/1597/
这可能是在 a 中存储二进制数据的最简单的解决方案 文本字段。
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)
还有一些其他片段可能会有所帮助。
我一直在'mysql'后端使用这个简单的字段,您可以为其他后端修改它
class BlobField(models.Field):
description = "Blob"
def db_type(self, connection):
return 'blob'
另外,请查看 Django Storages 的数据库存储:。
我还没有使用过它,但它看起来很棒,我一发布我的答案就开始使用它。
以访客身份回答,是一些网站添加的新功能