Django Model.objects.get...不区分大小写

问题描述

我正在开发字典应用程序,并且有一个Expression模型定义如下:

class Expression(models.Model):
    expression = models.CharField()

在我的一种观点中,我正在使用Expression.objects.get_or_create(expression=expression)

重要的是,我希望“ expression”与数据库中所有现有Expression对象之间的比较不区分大小写。

换句话说,即使这不是有效的语法,我也希望搜索逻辑为:Expression.objects.get_or_create(expression.lower()=expression.lower())

我该如何实现?

解决方法

您可以执行不区分大小写的过滤器,如下所示:

Expression.objects.get_or_create(expression__iexact=expression.lower())

查看documentation进行其他字段查找。

注意:由于竞争条件,get_or_create方法def btn_click(btn): global expression expression = expression + str(btn) btn_input.set(expression) btn_7= Button(root,text = '7',width =5,height =2,command=lambda:btn_click(7)) # btn_7= Button(root,command=btn_click(7)) 可以在数据库中创建重复项。请确保将唯一字段或一个唯一的字段传递给此方法,以避免重复。