当前位置:   article > 正文

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

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

一、应用场景

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

二、代码部分

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

  1. from django.db.models import Q
  2. def searchHouse(request):
  3. datas = request.POST
  4. type = datas.get("type")
  5. area = datas.get("area")
  6. price = datas.get("money")
  7. people = datas.get("people")
  8. query = Q()
  9. # 使用Q对象组合多个查询条件
  10. type_value = int(type)
  11. if type_value != 0:
  12. query.add(Q(type=type_value-1), Q.AND)
  13. if area == "1":
  14. # 若area检索类型为"1",则为检索面积在0到15之间的客房
  15. query &= Q(area__range=(0, 15))
  16. # 给query添加上该查询语句
  17. elif area == "2":
  18. query &= Q(area__range=(15, 20))
  19. elif area == "3":
  20. query &= Q(area__range=(20, 30))
  21. elif area == "4":
  22. query &= Q(area__gte=30)
  23. if price == "1":
  24. query &= Q(price__range=(0, 50))
  25. elif price == "2":
  26. query &= Q(price__range=(50, 100))
  27. elif price == "3":
  28. query &= Q(price__range=(100, 200))
  29. elif price == "4":
  30. query &= Q(price__gte=200)
  31. if people == "1":
  32. query.add(Q(people=1), Q.AND)
  33. elif people == "2":
  34. query.add(Q(people=2), Q.AND)
  35. elif people == "3":
  36. query &= Q(people__gte=3)
  37. # 依照query对house表进行检索
  38. reses = house.objects.filter(query)
  39. houses = []
  40. for res in reses:
  41. a_house = {
  42. "id": res.id,
  43. "type": res.type,
  44. "area": res.area,
  45. "price": res.price,
  46. "people": res.people,
  47. "counts": res.counts,
  48. "status": res.status,
  49. "manager_phone": res.managerID.phone,
  50. "manager_name": res.managerID.name
  51. }
  52. houses.append(a_house)
  53. return JsonResponse({'data': houses}, safe=False)

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号