微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

django-elasticsearch-dsl NestedFiled无法用于ManyToManyField

如何解决django-elasticsearch-dsl NestedFiled无法用于ManyToManyField

除了使用Price属性的BookPrice模型上的 Price 字段之外,我已经能够成功声明,映射和填充所有模型字段到Elasticsearch Index。如果我从文档中删除“价格”字段,那么它将正常工作。

但是,我过去曾经能够成功构建索引,但是我认为我做了一些更改并且失去了代码完整性,并且现在无法正常工作。

我尝试了在帮助论坛和官方文档中找到的所有可能组合,但是没有运气。

我当前正在使用

SchemaDirectiveVisitor

models.py

Elasticsearch == 7.8.0
elasticsearch-dsl == 7.2.1
django-elasticsearch-dsl == 7.1.1

documents.py

class Publisher(models.Model):
    publisher_name = models.CharField(max_length=50)

class BookType(models.Model):
    book_type = models.CharField(max_length=20) # Hard Cover,Soft Cover,Kindle Edition,Digital PDF etc.

class Book(models.Model):
    book_title = models.TextField()
    book_types = models.ManyToManyField(BookType,through='BookPrice',through_fields=('book','book_type'))

class BookPrice(models.Model):
    book_type = models.ForeignKey(Booktype,on_delete=models.CASCADE)
    book = models.ForeignKey(Book,on_delete=models.CASCADE)
    price = models.DecimalField(max_digits=7,decimal_places=2)

错误

@registry.register_document
class BookDocument(Document):
    book_title = fields.TextField(
        attr='book_title',fields={
            'suggest': fields.CompletionField(),})

    publisher = fields.ObjectField(properties={
        'publisher_name': fields.TextField(),})

    book_types = fields.nestedField(properties={
        'id': fields.IntegerField(),'book_type': fields.TextField(),'price': fields.FloatField()
    })

    class Index:
        name = 'books'
        settings = {'number_of_shards': 1,'number_of_replicas': 0}

    class Django:
        model = Book
        fields = [
            'id','slug','published_date','pages',]

        related_models = [BookPrice,BookType]

        def get_queryset(self):
            return super(BookDocument,self).get_queryset().select_related('publisher','book_types')

        def get_instances_from_related(self,related_instance):
            if isinstance(related_instance,BookPrice):
                return related_instance.book
            return related_instance.book_set.all()

解决方法

我使用prepare_foo(self,instance)方法解决了这个问题,并开始工作。 Using prepare_field

documents.py

def prepare_book_types(self,instance):
    return instance.get_price_for_es()

models.py

class Book(models.Model):
   ......

    def get_price_for_es(self):
       book_types= self.bookprice_set.all()
       book_types_price_list = []
       for x in book_types:
           book_types_price_list.append({'id': x.booktype_id,'book_type': x.booktype.book_type,'price': x.price})
       return book_types_price_list

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?