解决Django中多条件查询的问题


Posted in Python onJuly 18, 2019

tags: django中对条件查询

一些cms项目都会使用到多条件查询,我们后端如何处理请求的条件呢?

满足一个条件

满足两个条件

满足多个条件

………………….

这样处理起来会非常的恼火. 其实有多方法比如(传参数,传字典,传Q对象,传F对象…)陷入深深的思考中…怎么用做简单的方法把这个需求解决了.

个人觉得.把我们的查询的所有条件来构建一个字典来查询起来比较高效.具体如何操作见下面的代码:

视图函数.

def order_list(request):
  
  if request.method == 'GET':
    return render(request, 'admin/order_list.html')

  if request.method == 'POST':
    # 获取案件号
    case_order = request.POST.get('case_order')
    # 获取客户姓名
    case_name = request.POST.get('case_name')
    # 获取身份证号码
    idno = request.POST.get('idno')
    # 获取贷款日期
    loan_date = request.POST.get('loan_date')
    # 获取贷款状态
    state = request.POST.get('state')
    # 获取贷款类型
    dk_type = request.POST.get('dk_type')

    # 定一个字典用于保存前端发送过来的查询条件
    search_dict = dict()
    # 如果有这个值 就写入到字典中去
    if case_order:
      search_dict['loan_id'] = case_order
    if case_name:
      search_dict['name'] = case_name
    if idno:
      search_dict['user_card'] = idno
    if loan_date:
      search_dict['pri_date'] = loan_date
    if state:
      # 通过关联关系查询出来需要的数据
      state_info = StatuTable.objects.filter(statu_name=state).first()

      search_dict['statu_id'] = state_info.statu_id
    if dk_type:
      loa = LoantypeTable.objects.filter(loan_name=dk_type).first()
      search_dict['loa_loan_id'] = loa.loan_id

    # 多条件查询 关键点在这个位置传如的字典前面一定要加上两个星号.
    user_order_info = UserTable.objects.filter(**search_dict)
    # 序列化
    data_info = [user_order.to_dict() for user_order in user_order_info]

    data = {
      'code': 200,
      'data_info': data_info
    }
    return JsonResponse(data)

Models见上一篇文章

传送门 Model

前端html页面

<head>
  // 使用jquery就必须引入
	<script src="/static/admin/js/jquery.js" type="text/javascript"></script>
  // 需要使用ajaxSubmit去提交表单就必须引入
  <script src="/static/admin/js/jquery.form.min.js" type="text/javascript"></script>
  // 使用template.js渲染页面就必须引入
  <script src="/static/admin/js/template.js" type="text/javascript"></script>
  <script src="/static/admin/js/order_list.js" type="text/javascript"></script>
</head>

<div class="wrap">
  <div class="page-title">
    <span class="modular fl"><i class="order"></i><em>查询还款案件</em></span>
  </div>
  <div class="operate">
    <form id="search-order">
      {% csrf_token %}
      <div>
        <div style="margin: 10px">
          <label for="">客户单号:</label>
          <input type="text" class="textBox length-long " name="case_order" value=""/>

          <label for="">客户名称:</label>
          <input type="text" class="textBox length-long " name="case_name" value=""/>
        </div>

        <div style="margin: 10px">
          <label for="">身份证号:</label>
          <input type="text" class="textBox length-long " name="idno" value=""/>

          <label for="">贷款日期:</label>
          <input type="text" class="textBox length-long" id="datepicker" name="loan_date" value=""/>
        </div>

        <div style="margin: 10px">
          <label for="">处理状态:</label>
          <select class="inline-select textBox length-long" name="state">
            <option value="未处理">未处理</option>
            <option value="已处理">已处理</option>
          </select>
          <label for="">贷款项目:</label>
          <select class="inline-select textBox length-long" name="dk_type">
            <option value="POS贷">POS贷</option>
            <option value="现金贷">现金贷</option>
          </select>
          <div style="margin-right: 20px;margin-top: 10px;">
            <input type="submit" value="查询" class="tdBtn"/>
          </div>
        </div>
      </div>
    </form>
  </div>

  <table class="list-style Interlaced" id="test">
    <tr>
      <th>申请编号</th>
      <th>客户名称</th>
      <th>联系方式</th>
      <th>身份证号码</th>
      <th>办理日期</th>
      <th>处理人</th>
      <th>处理状态</th>
      <th>处理时间</th>
      <th>操作</th>
    </tr>
    {% verbatim %}
    <script type="text/html" id="tr_list">
      {{ each users as user }}
      <tr>
        <td>
          <input type="checkbox"/>
          <a href="/admin/order_detail/?id={{ user.user_id }}" rel="external nofollow" rel="external nofollow" style="text-decoration:underline; color: blue">
            <span>{{ user.loan_id }}</span>
          </a>
        </td>
        <td class="center">
          <span class="block">{{ user.name }}</span>
        </td>
        <td width="200" style="text-align:center">
          <span class="block">{{ user.phone }}</span>
        </td>
        <td class="center">
          <span>{{ user.card }}</span>
        </td>
        <td class="center">
          <span>{{ user.date }}</span>
        </td>
        <td class="center">
          <span>{{ user.deal_peo }}</span>
        </td>
        <td class="center">
          <span>{{ user.status }}</span>
        </td>
        <td class="center">
          <span>{{ user.deal_time }}</span>
        </td>
        <td class="center">
          <a href="/admin/order_detail/?id={{ user.user_id }}" rel="external nofollow" rel="external nofollow" class="inline-block" title="查看案件"><img
              src="/static/admin/images/icon_view.gif"/></a>
          <a class="inline-block" title="删除案件">
            <img src="/static/admin/images/icon_trash.gif"/>
          </a>
        </td>
      </tr>
      {{ /each }}
    </script>
    {% endverbatim %}
  </table>
  <!-- BatchOperation -->
  <div style="overflow:hidden;">
    <!-- Operation -->
    <div class="BatchOperation fl">
      <input type="checkbox" id="del"/>
      <label for="del" class="btnStyle middle">全选</label>
      <a href="/admin/export_excel/" rel="external nofollow" ><button id="export_excel" type="button" class="btnStyle" >导出excel</button></a>
      <input type="button" value="删除案件" class="btnStyle"/>
    </div>

后端搞定了就可以在前端写ajax去渲染页面了.

$(function () {
  var token = $(':input[name="csrfmiddlewaretoken"]').val()
  $('#search-order').submit(function () {
    $(this).ajaxSubmit({
      url: '/admin/order_list/',
      dataType: 'json',
      type: 'POST',
      headers: {'X-CSRFToken': token},
      success: function (data) {
        if (data.code == 200) {
          var html ='<tr>\n' +
            '      <th>申请编号</th>\n' +
            '      <th>客户名称</th>\n' +
            '      <th>联系方式</th>\n' +
            '      <th>身份证号码</th>\n' +
            '      <th>办理日期</th>\n' +
            '      <th>处理人</th>\n' +
            '      <th>处理状态</th>\n' +
            '      <th>处理时间</th>\n' +
            '      <th>操作</th>\n' +
            '    </tr>'

          var tr_html = template('tr_list', {users: data.data_info})
          html += tr_html
          $('#test').html(html)
        }
      }
    })
    // 阻止默认提交
    return false;
  })
})

总结:

重点就在怎么构建字典后最后构建好的字段如何传参的问题.

以上这篇解决Django中多条件查询的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python3通过Luhn算法快速验证信用卡卡号的方法
May 14 Python
详解Python中的各种函数的使用
May 24 Python
Python找出9个连续的空闲端口
Feb 01 Python
常见python正则用法的简单实例
Jun 21 Python
Python的Flask框架中的Jinja2模板引擎学习教程
Jun 30 Python
Python模拟自动存取款机的查询、存取款、修改密码等操作
Sep 02 Python
python自动化UI工具发送QQ消息的实例
Aug 27 Python
Python3 Click模块的使用方法详解
Feb 12 Python
Python GUI库PyQt5图形和特效样式QSS介绍
Feb 25 Python
python GUI库图形界面开发之PyQt5信号与槽机制、自定义信号基础介绍
Feb 25 Python
使用python从三个角度解决josephus问题的方法
Mar 27 Python
python小程序之飘落的银杏
Apr 17 Python
python openpyxl使用方法详解
Jul 18 #Python
Python Django基础二之URL路由系统
Jul 18 #Python
使用django的objects.filter()方法匹配多个关键字的方法
Jul 18 #Python
Django基础三之视图函数的使用方法
Jul 18 #Python
详解python实现小波变换的一个简单例子
Jul 18 #Python
Django基础知识 URL路由系统详解
Jul 18 #Python
对Django项目中的ORM映射与模糊查询的使用详解
Jul 18 #Python
You might like
PHP扩展编写点滴 技巧收集
2010/03/09 PHP
thinkphp浏览历史功能实现方法
2014/10/29 PHP
php查看网页源代码的方法
2015/03/13 PHP
PHP防盗链的基本思想 防盗链的设置方法
2015/09/25 PHP
PHP获取文件扩展名的方法实例总结
2017/06/10 PHP
JavaScript 提升运行速度之循环篇 译文
2009/08/15 Javascript
JQuery模板插件 jquery.tmpl 动态ajax扩展
2011/11/10 Javascript
jquery选择器的选择使用及性能介绍
2013/01/16 Javascript
jQuery 获取、设置HTML或TEXT内容的两种方法
2014/05/23 Javascript
JS实现一个列表中包含上移下移删除等功能
2014/09/24 Javascript
JS实现CheckBox复选框全选全不选功能
2015/05/06 Javascript
javascript基于prototype实现类似OOP继承的方法
2015/12/16 Javascript
js实现简易垂直滚动条
2017/02/22 Javascript
基于JQuery和原生JavaScript实现网页定位导航特效
2017/04/03 jQuery
微信小程序实现收藏与取消收藏切换图片功能
2018/08/03 Javascript
React Hooks的深入理解与使用
2018/11/12 Javascript
ES6 class类链式继承,实例化及react super(props)原理详解
2020/02/15 Javascript
Vue scoped及deep使用方法解析
2020/08/01 Javascript
深入理解Python中命名空间的查找规则LEGB
2015/08/06 Python
Python的Django中将文件上传至七牛云存储的代码分享
2016/06/03 Python
Python3简单实例计算同花的概率代码
2017/12/06 Python
python复制文件到指定目录的实例
2018/04/27 Python
python查看列的唯一值方法
2018/07/17 Python
python3 中文乱码与默认编码格式设定方法
2018/10/31 Python
Python高级编程之继承问题详解(super与mro)
2019/11/19 Python
python之列表推导式的用法
2019/11/29 Python
python通过cython加密代码
2020/12/11 Python
小天鹅官方商城:LittleSwan
2017/06/16 全球购物
阿联酋手表和配饰购物网站:Rivolishop
2019/11/25 全球购物
运行时异常与一般异常有何异同?
2014/01/05 面试题
求职简历中自我评价
2014/01/28 职场文书
运动会入场解说词
2014/02/07 职场文书
小学教师培训感言
2014/02/11 职场文书
学雷锋先进个人事迹
2014/05/26 职场文书
银行金融服务方案
2014/06/11 职场文书
python爬虫框架feapde的使用简介
2021/04/20 Python