解决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 相关文章推荐
python和C语言混合编程实例
Jun 04 Python
从零开始学Python第八周:详解网络编程基础(socket)
Dec 14 Python
python中的set实现不重复的排序原理
Jan 24 Python
python如何让类支持比较运算
Mar 20 Python
Python Pandas 如何shuffle(打乱)数据
Jul 30 Python
Django接收post前端返回的json格式数据代码实现
Jul 31 Python
Centos7 下安装最新的python3.8
Oct 28 Python
Python实现非正太分布的异常值检测方式
Dec 09 Python
python wxpython 实现界面跳转功能
Dec 17 Python
python深copy和浅copy区别对比解析
Dec 26 Python
python3.7+selenium模拟淘宝登录功能的实现
May 26 Python
PyTorch之nn.ReLU与F.ReLU的区别介绍
Jun 27 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/12/04 PHP
PHP采集利器 Snoopy 试用心得
2011/07/03 PHP
php使用fputcsv()函数csv文件读写数据的方法
2015/01/06 PHP
浅谈PHP链表数据结构(单链表)
2016/06/08 PHP
javascript中的107个基础知识收集整理 推荐
2010/03/29 Javascript
封装了jQuery的Ajax请求全局配置
2015/02/05 Javascript
详解JavaScript中|单竖杠运算符的使用方法
2016/05/23 Javascript
微信开发 JS-SDK 6.0.2 经常遇到问题总结
2016/12/08 Javascript
js实现贪吃蛇小游戏(容易理解)
2017/01/22 Javascript
js 获取今天以及过去日期
2017/04/11 Javascript
使用jquery Ajax实现上传附件功能
2018/10/23 jQuery
详解datagrid使用方法(重要)
2020/11/06 Javascript
[02:51]2014DOTA2国际邀请赛 IG战队官方纪录片
2014/07/21 DOTA
Python3实现生成随机密码的方法
2014/08/23 Python
Python 出现错误TypeError: ‘NoneType’ object is not iterable解决办法
2017/01/12 Python
Python SVM(支持向量机)实现方法完整示例
2018/06/19 Python
python频繁写入文件时提速的方法
2019/06/26 Python
Python 实现数据结构-堆栈和队列的操作方法
2019/07/17 Python
python基于pdfminer库提取pdf文字代码实例
2019/08/15 Python
python使用Thread的setDaemon启动后台线程教程
2020/04/25 Python
Django 解决model 反向引用中的related_name问题
2020/05/19 Python
python中return不返回值的问题解析
2020/07/22 Python
Python操作dict时避免出现KeyError的几种解决方法
2020/09/20 Python
python 基于wx实现音乐播放
2020/11/24 Python
Waterford英国官方网站:世界上最受欢迎的优质水晶品牌
2019/08/17 全球购物
Shell如何接收变量输入
2012/09/24 面试题
js实现弹框效果
2021/03/24 Javascript
造价工程师个人求职信
2013/09/21 职场文书
酒店大堂副理的职责范文
2014/02/13 职场文书
大学生简短的自我评价分享
2014/02/20 职场文书
城市规划应届毕业生自荐信
2014/07/04 职场文书
2015秋季新学期开学寄语
2015/05/28 职场文书
2015上半年个人工作总结
2015/07/27 职场文书
个人工作失误的保证书怎么写?
2019/06/21 职场文书
创业计划书之密室逃脱
2019/11/08 职场文书
三种方式清除vue路由跳转router-link的历史记录
2022/04/10 Vue.js