当前位置: 首页 > news >正文

[Django学习]Q对象实现多字段模糊搜索

一、应用场景

        假设我们现在有一个客房系统,前端界面上展示出来了所有客房的所有信息。用户通过客房的价格、面积、人数等对客房进行模糊搜索,如检索出价格在50到100元之间的客房,同时检索面积在20平方米到30平方米之间的客房,此时后端可以借助Q对象对客房进行筛选处理,并返回给前端。

二、代码部分

        学习笔记以注释的形式出现

from django.db.models import Q  
def searchHouse(request):

    datas = request.POST
    type = datas.get("type")
    area = datas.get("area")
    price = datas.get("money")
    people = datas.get("people")

    query = Q()
    # 使用Q对象组合多个查询条件

    type_value = int(type)
    if type_value != 0:
        query.add(Q(type=type_value-1), Q.AND)

    if area == "1":
        # 若area检索类型为"1",则为检索面积在0到15之间的客房
        query &= Q(area__range=(0, 15))
        # 给query添加上该查询语句
    elif area == "2":
        query &= Q(area__range=(15, 20))
    elif area == "3":
        query &= Q(area__range=(20, 30))
    elif area == "4":
        query &= Q(area__gte=30)

    if price == "1":
        query &= Q(price__range=(0, 50))
    elif price == "2":
        query &= Q(price__range=(50, 100))
    elif price == "3":
        query &= Q(price__range=(100, 200))
    elif price == "4":
        query &= Q(price__gte=200)

    if people == "1":
        query.add(Q(people=1), Q.AND)
    elif people == "2":
        query.add(Q(people=2), Q.AND)
    elif people == "3":
        query &= Q(people__gte=3)

    # 依照query对house表进行检索
    reses = house.objects.filter(query)

    houses = []

    for res in reses:
        a_house = {
            "id": res.id,
            "type": res.type,
            "area": res.area,
            "price": res.price,
            "people": res.people,
            "counts": res.counts,
            "status": res.status,
            "manager_phone": res.managerID.phone,
            "manager_name": res.managerID.name
        }
        houses.append(a_house)

    return JsonResponse({'data': houses}, safe=False)

相关文章:

  • ping命令返回结果实例分析
  • 【LinuxC语言】阻塞、回调与轮询快速理解
  • 压力测试Monkey命令参数和报告分析
  • 大模型参数高效微调学习笔记
  • 前端练习小项目——视觉冲击卡片
  • 单片机练习题4
  • 7 bool query组合查询
  • 基于SpringBoot+大数据城市景观画像可视化设计和实现
  • 程序员如何高效读代码?
  • A类IP介绍
  • 张宇1000题太难?这么刷只要30天就能吃透!
  • Lambda函数(箭头表达式)
  • 小鹏汽车2025冲刺类L4智驾,挑战与机遇并存
  • 百老开通知识星球啦,数据要素、数据治理等资料迅速扩散!
  • HTML(18)——浮动
  • Pycharm怎么默认终端连接远程服务器
  • 代码-功能-python-爬取博客网标题作者发布时间
  • 只有一个鸿蒙好?还是鸿蒙、安卓、IOS并存好?
  • 如何在Springboot中配置Druid连接池连接MySQL?
  • Spring-bean
  • 上海天文馆走进徐家汇书院,XR沉浸式天文科普体验再推力作
  • 杨建全已任天津市委副秘书长、市委市政府信访办主任
  • 学者三年实地调查被判AI代笔,论文AI率检测如何避免“误伤”
  • 坚决打好产业生态培育攻坚战!陈吉宁调研奉贤区
  • “走进书适圈”:一周城市生活
  • 国家统计局公布2024年城镇单位就业人员年平均工资情况