欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決Django中多條件查詢的問題

 更新時間:2019年07月18日 09:27:13   作者:_古時候  
今天小編就為大家分享一篇解決Django中多條件查詢的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

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')
    # 獲取貸款狀態(tài)
    state = request.POST.get('state')
    # 獲取貸款類型
    dk_type = request.POST.get('dk_type')

    # 定一個字典用于保存前端發(fā)送過來的查詢條件
    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="">處理狀態(tài):</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>處理狀態(tài)</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>處理狀態(tài)</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中多條件查詢的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Python3基礎之函數用法

    Python3基礎之函數用法

    這篇文章主要介紹了Python3的函數用法,非常重要,需要的朋友可以參考下
    2014-08-08
  • Python函數式編程指南(二):從函數開始

    Python函數式編程指南(二):從函數開始

    這篇文章主要介紹了Python函數式編程指南(二):從函數開始,本文講解了定義一個函數、使用函數賦值、閉包、作為參數等內容,需要的朋友可以參考下
    2015-06-06
  • python中input()的用法及擴展

    python中input()的用法及擴展

    這篇文章主要介紹了python中input()的用法及擴展,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 9個提高?Python?編程的小技巧

    9個提高?Python?編程的小技巧

    這篇文章主要介紹了9個提高?Python?編程的小技巧,下文分享python編程技巧,需要的小伙伴可以參考一下,希望對你的學習有所幫助
    2022-05-05
  • Python實現雙軸組合圖表柱狀圖和折線圖的具體流程

    Python實現雙軸組合圖表柱狀圖和折線圖的具體流程

    這篇文章主要介紹了Python雙軸組合圖表柱狀圖+折線圖,Python繪制雙軸組合的關鍵在plt庫的twinx()函數,具體實例代碼跟隨小編一起看看吧
    2021-08-08
  • Matlab中的mat數據轉成python中使用的npy數據遇到的坑及解決

    Matlab中的mat數據轉成python中使用的npy數據遇到的坑及解決

    這篇文章主要介紹了Matlab中的mat數據轉成python中使用的npy數據遇到的坑及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 詳解Python3中setuptools、Pip安裝教程

    詳解Python3中setuptools、Pip安裝教程

    這篇文章主要介紹了詳解Python3中setuptools、Pip安裝教程,文中給大家提到了注意事項,需要的朋友可以參考下
    2019-06-06
  • OpenCV HSV顏色識別及HSV基本顏色分量范圍

    OpenCV HSV顏色識別及HSV基本顏色分量范圍

    這篇文章主要介紹了OpenCV HSV顏色識別及HSV基本顏色分量范圍,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • python基于tkinter點擊按鈕實現圖片的切換

    python基于tkinter點擊按鈕實現圖片的切換

    這篇文章主要介紹了python基于tkinter點擊按鈕實現圖片的切換,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • Python使用Traits庫實現對象屬性

    Python使用Traits庫實現對象屬性

    Python作為一種動態(tài)編程語言,它的變量沒有類型,這種靈活性給快速開發(fā)帶來很多便利,不過它也不是沒有缺點,Traits庫的一個很重要的目的就是為了解決這些缺點所帶來的問題,trait為Python對象的屬性增加了類型定義的功能
    2023-11-11

最新評論