Django Blob 模型字段

问题描述 投票:0回答:5

如何使用 Django 的 ORM 和 PostgreSQL 后端存储二进制数据的“blob”?是的,我知道 Django 不赞成这种事情,是的,我知道他们更喜欢你使用 ImageField 或 FileField 来实现这一点,但我只想说,这对我的应用程序来说是不切实际的。

我尝试过使用 TextField 来破解它,但是当我的二进制数据没有严格确认模型编码类型(默认情况下为 unicode)时,我会偶尔遇到错误。例如

psycopg2.DataError: invalid byte sequence for encoding "UTF8": 0xe22665
python django django-models django-orm django-blob
5个回答
37
投票

如果您使用的是 Django >= 1.6,则有一个 BinaryField


36
投票

这个片段有什么好处:

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)

还有一些其他片段可能会有所帮助。


10
投票

我一直在'mysql'后端使用这个简单的字段,您可以为其他后端修改它

class BlobField(models.Field):
    description = "Blob"
    def db_type(self, connection):
        return 'blob'

0
投票

另外,请查看 Django Storages 的数据库存储:

我还没有使用过它,但它看起来很棒,我一发布我的答案就开始使用它。


0
投票

以访客身份回答,是一些网站添加的新功能

© www.soinside.com 2019 - 2024. All rights reserved.