Django Blob模型字段

38 投票
4 回答
57290 浏览
提问于 2025-04-16 11:21

如何在使用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)

那里还有其他几个代码片段,可能对你有帮助。

撰写回答