Django ORM非空判断、以及通用写法

django文档

Django ORM中,判断非空(not null)有多种方式,

使用isnull查询方法

py 复制代码
# 查找所有name字段不为空的对象
objects = MyModel.objects.filter(name__isnull=False)

使用exclude方法排除空值:

py 复制代码
# 查找所有name字段不为空的对象
objects = MyModel.objects.exclude(name__isnull=True)

使用blank=False和null=False设置字段属性

py 复制代码
from django.db import models

class MyModel(models.Model):
    name = models.CharField(max_length=100, blank=False, null=False)
    # 这样定义的name字段在数据库中不允许为空

在Model方法中进行判断

py 复制代码
class MyModel(models.Model):
    name = models.CharField(max_length=100)

    def is_name_not_null(self):
        return self.name is not None

使用clean方法进行验证

py 复制代码
from django.core.exceptions import ValidationError

class MyModel(models.Model):
    name = models.CharField(max_length=100)

    def clean(self):
        if self.name is None:
            raise ValidationError({'name': 'Name cannot be null.'})

这些方法各有优缺点,具体使用时需要根据具体的业务需求和使用场景进行选择。比如在查询时使用isnull或exclude方法更加简单高效,而在Model中设置字段属性或重写clean方法可以在保存时进行更复杂的验证。

通用写法

在Django ORM中,通过表达式来判断字段是否为空是非常常见的需求。您提到的ar_address__isnull=True是一个具体的例子,那么如何编写更通用的表达式来实现这种判断呢?

使用 Q 对象:

python 复制代码
from django.db.models import Q

# 判断 ar_address 字段是否为空
qs = MyModel.objects.filter(Q(ar_address__isnull=True))

Q 对象可以用于构建复杂的查询条件,这种方式更加灵活。

使用 IsNull 表达式:

py 复制代码
from django.db.models import IsNull

# 判断 ar_address 字段是否为空
qs = MyModel.objects.filter(IsNull('ar_address'))

IsNull 表达式也可以用于判断字段是否为空。

使用 Case 和 When 表达式

python 复制代码
from django.db.models import Case, When, BooleanField

# 判断 ar_address 字段是否为空
qs = MyModel.objects.annotate(
    is_ar_address_null=Case(
        When(ar_address__isnull=True, then=True),
        default=False,
        output_field=BooleanField()
    )
)

这种方式可以将判断结果作为一个新的字段添加到查询集中,方便后续的处理。

使用自定义的函数

python 复制代码
def is_field_null(field_name):
    return Q(**{f"{field_name}__isnull": True})

# 判断 ar_address 字段是否为空
qs = MyModel.objects.filter(is_field_null('ar_address'))

自定义一个通用的函数,可以更方便地复用这种判断逻辑。

相关推荐
小嵌同学15 小时前
Linux:malloc背后的实现细节
大数据·linux·数据库
R瑾安15 小时前
mysql安装(压缩包方式8.0及以上)
数据库·mysql
代码的余温16 小时前
MySQL Cluster核心优缺点
数据库·mysql
Mr.Entropy17 小时前
请求超过Spring线程池的最大线程(处理逻辑)
数据库·sql·spring
GBASE17 小时前
“G”术时刻:南大通用GBase 8c数据库权限管理场景实践(二)
数据库
wearegogog12318 小时前
MySQL中实施排序(sorting)及分组(grouping)操作
数据库·mysql
2301_8035545218 小时前
MySQL 主从读写分离架构
数据库·mysql·架构
正在走向自律18 小时前
Ubuntu系统下Python连接国产KingbaseES数据库实现增删改查
开发语言·数据库·python·ubuntu·kingbasees·ksycopg2
没有bug.的程序员19 小时前
Redis 内存管理机制:深度解析与性能优化实践
java·数据库·redis·性能优化·内存管理机制
小蒜学长19 小时前
基于SpringBoot+Vue的健身房管理系统的设计与实现(代码+数据库+LW)
java·数据库·vue.js·spring boot·后端