我知道如何用原始的PostgreSQL命令来做到这一点,但想知道是否有办法用Django PostgreSQL进行搜索。是否可以将您自己的字符串添加到Django SearchVectorField中?
class Person(models.Model):
name = models.CharField(max_length=64)
description = models.CharField(max_length=256)
active = models.BooleanField(default=False)
search_vector = SearchVectorField(blank=True)
def update_search(person):
vector = SearchVector('name') + SearchVector('description')
if person.active:
vector = vector + SearchVector('alive')
person.search_vector = vector
django.core.exceptions.FieldError: Cannot resolve keyword 'alive' into field.
我试图使“活”一个@property的方法,但它看起来像它只是想搜索一个数据库字段。
是否有一种方法可以在纯Django ORM中执行此操作,还是应该转到原始SQL路由?
Ooooh。很好的发现。会试试这个。 – Dax