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

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

一、应用场景

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

二、代码部分

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

from django.db.models import Q  
def searchHouse(request):datas = request.POSTtype = 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)

http://www.lryc.cn/news/380677.html

相关文章:

  • transdreamer 论文阅读笔记
  • AIGC技术的发展现状与未来趋势探讨
  • Postman Postman接口测试工具使用简介
  • Java开发笔记Ⅱ(Jsoup爬虫)
  • 一五三、MAC 安装MongoDB可视化工具连接
  • ULTRAINTERACT 数据集与 EURUS 模型:推动开源大型语言模型在推理领域的新进展
  • 【leetcode刷题】面试经典150题 , 27. 移除元素
  • 红队内网攻防渗透:内网渗透之内网对抗:横向移动篇PTH哈希PTT票据PTK密匙Kerberoast攻击点TGTNTLM爆破
  • springBoot不同module之间互相依赖
  • [modern c++] 类型萃取 type_traits
  • 函数模板和类模板的区别
  • ChatGPT 提示词技巧一本速通
  • 【windows解压】解压文件名乱码
  • 使用Flink CDC实时监控MySQL数据库变更
  • 学生课程信息管理系统
  • 如何看待鸿蒙HarmonyOS?
  • 【论文复现|智能算法改进】一种基于多策略改进的鲸鱼算法
  • yarn安装配置及使用教程
  • 有那么点道理。
  • 蔚蓝资源包和数据分析
  • MySQL----利用Mycat配置读写分离
  • 【科学计算与可视化】2. pandas 基础
  • 医学记录 --- 腋下异味
  • 【Linux】进程间通信_1
  • Linux Kernel入门到精通系列讲解(RV-Kernel 篇) 5.6 在kernel 中实现系统复位和系统关机驱动
  • 如何在Java中进行单元测试?
  • 代码随想录训练营Day32
  • 代码随想录训练营Day31
  • Docker 多阶段构建
  • Linux应急响应——知攻善防应急靶场-Linux(1)