1. 程式人生 > 資料庫 >利用python對mysql表做全域性模糊搜尋並分頁例項

利用python對mysql表做全域性模糊搜尋並分頁例項

在寫django專案的時候,有的資料沒有使用模型管理(資料表是動態新增的),所以要直接使用mysql。前端請求資料的時候可能會指定這幾個引數:要請求的頁號,頁大小,以及檢索條件。

"""
	tableName: 表名
	pageNum: 請求的頁的編號
	pageSize: 每一頁的大小
	searchInfo: 需要全域性查詢的資訊
"""
def getMysqlData(tableName,pageNum,pageSize,searchInfo):
	# 使用MySQLdb獲取的mysql遊標
  cursor = getCursor()
  # 用以獲取列標題
  colSql = 'select * from {} limit 1'.format(tableName)
  cursor.execute(colSql)
  columns = [col[0] for col in cursor.description]
  # 轉化查詢資訊為sql
  searchCondition = ','.join(columns)
  searchInfo = "WHERE CONCAT({}) like '%{}%'".format(searchCondition,searchInfo)
  # 用以獲取總數
  totalSql = "select count(*) from {} {};".format(tableName,searchInfo)
  cursor.execute(totalSql)
  total = cursor.fetchone()[0]
  # 用以獲取具體資料
  limit1 = (pageNum - 1) * pageSize
  limit2 = pageSize
  dataSql = "select * from {} {} limit {},{};".format(tableName,searchInfo,limit1,limit2)
  cursor.execute(dataSql)
  data = [
    dict(zip(columns,row)) 
    for row in cursor.fetchall()
  ]
  return (total,columns,data)

"""
	total: 符合條件的資料總數
	columns: 欄位名列表 
	['欄位名1','欄位名2',...]
	data: 資料物件列表 
	[{'欄位名1': 資料1,'欄位名2':資料1,...},{'欄位名1': 資料2,'欄位名2': 資料2,...]
"""

補充知識:django 分頁查詢搜尋--傳遞查詢引數,翻頁時帶上查詢引數

django在分頁查詢的時候,翻頁時,v層要傳遞查詢引數,相應的html翻頁連線也要帶上查詢引數

直接上程式碼

view:

@login_required
def search_name(request):
 
 
  username = request.session.get('user')
  search_name = request.GET.get('name')
  if search_name == None:
    search_name = request.GET.get('name')
 
 
  event_list = Event.objects.filter(name__contains=search_name)
 
  paginator = Paginator(event_list,2)
  page = request.GET.get('page')
  try:
    contacts = paginator.page(page)
 
  except PageNotAnInteger:
    # 如果page不是整數,取第一頁面資料
    contacts = paginator.page(1)
  except EmptyPage:
    # 如果page不在範圍內,則返回最後一頁資料
    contacts = paginator.page(paginator.num_pages)
 
  return render(request,'event_manage.html',{'user':username,'events':contacts,'name':search_name})

html:

 <!--列表分頁器-->
  <div class="pagination">
  <span class="step-links">
    {% if events.has_previous %}
      <a href="?page={{ events.previous_page_number }}&&name={{ name }}" rel="external nofollow" >previous</a>
    {% endif %}
    <span class="current">
      Page {{ events.number }} of {{ events.paginator.num_pages }}
 
    </span>
    {% if events.has_next %}
      <a href="?page={{ events.next_page_number }}&name={{ name }}" rel="external nofollow" >next</a>
    {% endif %}
 
  </span>
  </div>
  {% include 'include/pager.html' %}

以上這篇利用python對mysql表做全域性模糊搜尋並分頁例項就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。