Django Blob模型领域

时间:2011-02-06 18:59:47

标签: python django django-models django-orm django-blob

如何使用Django的ORM和PostgreSQL后端存储二进制数据的“blob”?是的,我知道Django对这种事情感到皱眉,是的,我知道他们更喜欢你使用ImageField或FileField,但这足以说明,这对我的应用来说是不切实际的。

我尝试使用TextField进行黑客攻击,但是当我的二进制数据没有严格确认模型编码类型(默认为unicode)时,我会遇到偶然的错误。例如

psycopg2.DataError: invalid byte sequence for encoding "UTF8": 0xe22665

4 个答案:

答案 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:

我还没有使用它,但它看起来很棒,我会在发布我的答案后立即开始使用它。