我想在Django中执行全名(first_name concat last_name)搜索/查询。
以下是我的模特:
class Employee(models.Model):
user = models.OneToOneField(User, on_delete=models.CASCADE, related_name='employee')
company = models.ForeignKey(Company)
username = models.CharField(max_length=30, blank=False)
first_name = models.CharField(max_length=30, blank=False)
last_name = models.CharField(max_length=30, blank=False)
created_at = models.DateTimeField(auto_now_add=True)
例如,我们有一个这样的条目。 first_name:" Michael",last_name:" Jackson"
我希望能够查询全名" michael jackson"。如果可以在没有区分大小写的情况下表现出来也很棒。
此其他stackoverflow问题类似,但答案并未在正确的Querying full name in Django中满足此特定要求。我们希望能够进行连续搜索。
我尝试使用注释,但它不起作用
queryset = Employee.objects.annotate(fullname=Concat('first_name', 'last_name'))
search_result = queryset.filter(fullname__icontains='michael jackson')
答案 0 :(得分:3)
这很有效。
from django.db.models.functions import Concat
from django.db.models import Value
queryset = Employee.objects.annotate(fullname=Concat('first_name', Value(' '), 'last_name'))
c = queryset.filter(fullname__icontains='michael jackson')