利用python對mysql表做全域性模糊搜尋並分頁例項
阿新 • • 發佈:2020-07-16
在寫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表做全域性模糊搜尋並分頁例項就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。