Python使用sql語(yǔ)句對(duì)mysql數(shù)據(jù)庫(kù)多條件模糊查詢的思路詳解
def find_worldByName(c_name,continent): print(c_name) print(continent) sql = ' SELECT * FROM world WHERE 1=1 ' if(c_name!=None):sql=sql+'AND ( c_name LIKE ’%'+c_name+'%’ )' if(continent!=None):sql=sql+' AND ( continent LIKE ’%'+continent+'%’) ' sql=sql+' AND dt=(SELECT dt FROM world order by dt desc limit 1) order by confirm desc ' # 'AND continent LIKE ’%%%%%s%%%%’' # ' order by dt desc ' %(c_name,continent) # sql_temp = ' SELECT * FROM world WHERE c_name LIKE ’%'+c_name+'%’ ' res = query(sql) list= [] for i in res:# print(i)list.append(i) return list;背景:
頁(yè)面的搜索框是有兩個(gè)搜索條件,一個(gè)是國(guó)家,一個(gè)是大洲。
那么在數(shù)據(jù)庫(kù)查詢的時(shí)候就會(huì)出現(xiàn)問(wèn)題,如果國(guó)家傳的值是None那么使用AND連接的sql語(yǔ)句這個(gè)條件會(huì)被
整體判定為false,也就是另一個(gè)查詢條件 “大洲 ”就會(huì)作廢,為了防止參數(shù)出現(xiàn)這樣的錯(cuò)誤。需要在寫sql語(yǔ)
句的時(shí)候?qū)?shù)是否為空加一個(gè)判斷條件,然后逐層添加sql語(yǔ)句。
思路:首先使用開(kāi)頭的一個(gè)sql語(yǔ)句:
sql = ' SELECT * FROM world WHERE 1=1 '
之后逐層判定參數(shù)是否為空,再拼接sql語(yǔ)句:
if(c_name!=None): sql=sql+'AND ( c_name LIKE ’%'+c_name+'%’ )' if(continent!=None): sql=sql+' AND ( continent LIKE ’%'+continent+'%’) ' sql=sql+' AND dt=(SELECT dt FROM world order by dt desc limit 1) order by confirm desc '
還有一個(gè)地方需要注意:sql語(yǔ)句傳參數(shù),參數(shù)是一個(gè)變量,有兩種方式:① 直接拼接到sql語(yǔ)句中:
var c_name='test'sql_temp = ' SELECT * FROM world WHERE c_name LIKE ’ %'+c_name+'% ’'
② 使用占位符%代替,在語(yǔ)句末尾再替換占位符:
sql = ' SELECT * FROM world WHERE c_name LIKE ’%%%%%s%%%%’ AND continent LIKE ’%%%%%s%%%%’' %(c_name,continent)

Tomorrow the birds will sing.
到此這篇關(guān)于Python使用sql語(yǔ)句對(duì)mysql數(shù)據(jù)庫(kù)多條件模糊查詢的思路詳解的文章就介紹到這了,更多相關(guān)Python mysql多條件模糊查詢內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. php使用正則驗(yàn)證密碼字段的復(fù)雜強(qiáng)度原理詳細(xì)講解 原創(chuàng)2. vue前端RSA加密java后端解密的方法實(shí)現(xiàn)3. JSP+Servlet實(shí)現(xiàn)文件上傳到服務(wù)器功能4. 基于jsp+mysql實(shí)現(xiàn)在線水果銷售商城系統(tǒng)5. 基于javaweb+jsp實(shí)現(xiàn)企業(yè)財(cái)務(wù)記賬管理系統(tǒng)6. CSS可以做的幾個(gè)令你嘆為觀止的實(shí)例分享7. ASP動(dòng)態(tài)網(wǎng)頁(yè)制作技術(shù)經(jīng)驗(yàn)分享8. 淺談?dòng)蓀osition屬性引申的css進(jìn)階討論9. ASP中實(shí)現(xiàn)字符部位類似.NET里String對(duì)象的PadLeft和PadRight函數(shù)10. 利用CSS3新特性創(chuàng)建透明邊框三角

網(wǎng)公網(wǎng)安備