Django Blob模型字段
如何在使用Django的ORM和PostgreSQL数据库的情况下存储一段“二进制数据”?我知道Django不太喜欢这样做,而且我也知道他们更推荐使用ImageField或FileField来处理这些,但对我来说,这样做不太实际。
我尝试用TextField来解决这个问题,但有时候会出现错误,因为我的二进制数据并不完全符合模型的编码类型,默认是unicode。例如:
psycopg2.DataError: invalid byte sequence for encoding "UTF8": 0xe22665
4 个回答
10
我一直在使用这个简单的字段来连接'mysql'数据库,你可以根据需要修改它来适配其他类型的数据库。
class BlobField(models.Field):
description = "Blob"
def db_type(self, connection):
return 'blob'
38
如果你使用的是Django版本1.6或更高的版本,那么你可以使用一个叫做BinaryField的字段。
36
这个代码片段怎么样:
http://djangosnippets.org/snippets/1597/
这是存储二进制数据在文本字段中可能最简单的解决方案。
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)
那里还有其他几个代码片段,可能对你有帮助。