亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

利用python對(duì)mysql表做全局模糊搜索并分頁實(shí)例

瀏覽:12日期:2022-07-17 18:15:24

在寫django項(xiàng)目的時(shí)候,有的數(shù)據(jù)沒有使用模型管理(數(shù)據(jù)表是動(dòng)態(tài)添加的),所以要直接使用mysql。前端請(qǐng)求數(shù)據(jù)的時(shí)候可能會(huì)指定這幾個(gè)參數(shù):要請(qǐng)求的頁號(hào),頁大小,以及檢索條件。

'''tableName: 表名pageNum: 請(qǐng)求的頁的編號(hào)pageSize: 每一頁的大小searchInfo: 需要全局查詢的信息'''def getMysqlData(tableName, pageNum, pageSize, searchInfo):# 使用MySQLdb獲取的mysql游標(biāo) cursor = getCursor() # 用以獲取列標(biāo)題 colSql = ’select * from {} limit 1’.format(tableName) cursor.execute(colSql) columns = [col[0] for col in cursor.description] # 轉(zhuǎn)化查詢信息為sql searchCondition = ’,’.join(columns) searchInfo = 'WHERE CONCAT({}) like ’%{}%’'.format(searchCondition, searchInfo) # 用以獲取總數(shù) totalSql = 'select count(*) from {} {};'.format(tableName, searchInfo) cursor.execute(totalSql) total = cursor.fetchone()[0] # 用以獲取具體數(shù)據(jù) 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: 符合條件的數(shù)據(jù)總數(shù)columns: 字段名列表 [’字段名1’, ’字段名2’, ...]data: 數(shù)據(jù)對(duì)象列表 [{’字段名1’: 數(shù)據(jù)1,’字段名2’:數(shù)據(jù)1, ...},{’字段名1’: 數(shù)據(jù)2, ’字段名2’: 數(shù)據(jù)2, ...}, ...]'''

補(bǔ)充知識(shí):django 分頁查詢搜索--傳遞查詢參數(shù),翻頁時(shí)帶上查詢參數(shù)

django在分頁查詢的時(shí)候,翻頁時(shí),v層要傳遞查詢參數(shù),相應(yīng)的html翻頁連接也要帶上查詢參數(shù)

直接上代碼

view:

@login_requireddef 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不是整數(shù),取第一頁面數(shù)據(jù) contacts = paginator.page(1) except EmptyPage: # 如果page不在范圍內(nèi),則返回最后一頁數(shù)據(jù) 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='http://www.aoyou183.cn/bcjs/?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='http://www.aoyou183.cn/bcjs/?page={{ events.next_page_number }}&name={{ name }}' rel='external nofollow' >next</a> {% endif %} </span> </div> {% include ’include/pager.html’ %}

以上這篇利用python對(duì)mysql表做全局模糊搜索并分頁實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 欧美日韩 国产区 在线观看 | 亚洲视频在线观看视频 | 亚洲成人精品 | 91老师国产黑色丝袜在线 | 美国大片成人性网 | 欧美成人影院 在线播放 | 中文字幕yellow在线资源 | 国产香蕉精品视频在 | 黄色一级毛片免费 | 国产精品久久久久久福利69堂 | 国产在线短视频 | 香蕉视频在线免费播放 | 91福利视频合集 | 欧美高清激情毛片 | 成熟自由日本语热亚洲人 | 拍拍拍精品视频在线观看 | 色天天天天综合男人的天堂 | 亚洲一区二区三区久久 | 麻豆国产果冻传媒网站入口 | 国产精品国色综合久久 | 免费簧网站永久在线播放国产 | 国产麻豆91网在线看 | 精品哟哟哟国产在线不卡 | 国产精品一区高清在线观看 | 青青草免费在线视频 | 国内精品久久久久久西瓜色吧 | 一区二区成人国产精品 | 3344成年站福利在线视频免费 | 黄毛片| 欧美综合另类 | 老年人一级特黄aa大片 | 爱爱爱免费视频观看在线网站 | 欧美高清性刺激毛片 | 亚洲精品中文字幕乱码一区二区 | 男女国产一级毛片 | 黄色一级片在线播放 | 99九九成人免费视频精品 | 国产一区二区精品久久凹凸 | 91香蕉嫩草 | 日本96在线精品视频免费观看 | 午夜在线亚洲 |