zoukankan      html  css  js  c++  java
  • django orm 筛选

    import os
    
    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "test.setting")
    import django
    
    django.setup()
    
    # from django.core.management import call_command
    #
    #
    # call_command("test", "")
    from django.db import models
    from chat.models import Dog
    
    from django.db.models.functions import Cast
    
    Dog.objects.create(name="Meg", age=1, data={"breed": "collie", "owner": {"name": "Tom", "age": 10}}, food=["noodles", "fuck"])
    Dog.objects.create(name="WangWang", age=1, data={"breed": "collie", "owner": {"name": "LiMing", "age": 10}}, food=["bone", ])
    Dog.objects.annotate(
        title=Cast("data__breed", models.TextField()),
    ).filter(title__regex="c.*")
    
    Dog.objects.annotate(
        title=Cast("food__*", models.TextField()),
    ).filter(title__contains="nood")
    
    from chat.models import Cat
    
    Dog.objects.annotate(
        title=Cast("data__owner__name", models.TextField()),
    ).filter(title__regex="t.*")
    
    Dog.objects.annotate(
        title=Cast("food", models.TextField()),
    ).filter(title__regex="t.*")
    
    Cat.objects.annotate(
        title=Cast("food__0", models.TextField())
    ).values("title")
    
    # Cat.objects.annotate(
    #     food="food"
    # ).filter(food="11")
    
    Dog.objects.filter(data__owner__age__gt=1)
    from django.db.models import Q
    from django.utils import timezone
    
    Dog.objects.filter(create_time__lt=timezone.now())
    Dog.objects.filter(name__icontains="e")
    Dog.objects.filter(name__startswith="M")  # 区分大小
    Dog.objects.filter(name__istartswith="M")  # 不区分大小写
    Dog.objects.filter(name__endswith="g")  # 区分大小
    Dog.objects.filter(name__iendswith="g")  # 不区分大小写
    Dog.objects.filter(name__regex=".*?g")  # 区分大小写
    Dog.objects.filter(name__iregex=".*?G")  # 不区分大小写
    Dog.objects.filter(age__exact=1)
    Dog.objects.filter(age__in=[1, 2, 3])
    Dog.objects.exclude(age=1)
    Dog.objects.filter(~Q(age=1))
    Dog.objects.filter(age__gt=1)  # 大于
    Dog.objects.filter(age__gte=1)  # 大于等于
    Dog.objects.filter(age__lt=2)  # 小于
    Dog.objects.filter(age__lte=2)  # 小于等于
    
    Dog.objects.filter(create_time__gt=timezone.now())  # 大于
    Dog.objects.filter(create_time__gte=timezone.now())  # 大于等于
    Dog.objects.filter(create_time__lt=timezone.now())  # 小于
    Dog.objects.filter(create_time__lte=timezone.now())  # 小于等于
    Dog.objects.filter(food__contains="noodles")
    Dog.objects.filter(~Q(food__contains="noodles"))
    Dog.objects.filter(age__in=[1, 2, 4])
    Dog.objects.filter(age__range=(1, 10))
    
    Dog.objects.annotate(
        title=Cast("food", models.TextField()),
    ).filter(title__regex="t.*")
    from chat.models import Cat
    
    Cat.objects.annotate(title=Cast("food", models.TextField())).filter(title__regex="1.*")
    Cat.objects.filter(food__0__contains="1")
    Cat.objects.annotate(
        title=Cast("food", models.TextField()),
    ).filter(title__contains="11,")
    
    #  精确查找
    Cat.objects.annotate(
        title=Cast("food", models.TextField()),
    ).filter(title__regex="")
    
    
    value = "11"
    # rf"[{{|,]{value}[,|}}]"
    
    Cat.objects.annotate(
        title=Cast("food", models.TextField()),
    ).filter(title__regex=rf"[{{|,]{value}[,|}}]")
    
    
    q =   Q()
    for item in ["{{item},", ",{item}},", ",{item},", "{{item}}"]:
        q |= Q(title__contains=item.replace("{item}","11"))
    
    Cat.objects.annotate(
        title=Cast("food", models.TextField()),
    ).filter(q)
    
    from django.contrib.postgres.fields import ArrayField
    Cat.objects.annotate(
        title=Cast("food", ArrayField(models.TextField())),
    )
    # .filter(q)
    
    # FloatField
    
    
    Dog.objects.annotate(
        food=Cast("data__owner__age", models.IntegerField()),
    ).filter(food=10)
    
    from django.db.models import F, Value, TextField
    from django.db.models.expressions import Func
    
    from django.contrib.postgres.fields import ArrayField
    
    Cat.objects.annotate(
        some_field_splitted=Func(
            F('food'),
            Value(","),
            function='regexp_split_to_array',
            output_field=ArrayField(TextField())
        )
    ).filter()
    
    
    
    
    # Dog.objects.annotate(
    # #     some_field_splitted=Cast("food",Func(
    # #         # F('food'),
    # #         # Value(","),
    # #         function='regexp_split_to_array',
    # #         output_field=ArrayField(TextField())
    # #     )
    # # ))
    
    from django.contrib.postgres.fields import JSONField, ArrayField
    Dog.objects.annotate(
        title=Cast("food__any", ArrayField(JSONField(models.TextField()))),
    ).filter(title__0="1")
    
    
    
  • 相关阅读:
    Docker 给 故障停掉的 container 增加 restart 参数
    使用docker化的nginx 反向代理 docker化的GSCloud 的方法
    apache benchmark 的简单安装与测试
    mysql5.7 的 user表的密码字段从 password 变成了 authentication_string
    Windows 机器上面同时安装mysql5.6 和 mysql5.7 的方法
    python4delphi 安装
    见证下神奇的时刻
    windows下面安装Python和pip终极教程
    python如何安装pip和easy_installer工具
    Tushare的安装
  • 原文地址:https://www.cnblogs.com/twotigers/p/11720696.html
Copyright © 2011-2022 走看看