Python使用sql語句對mysql數(shù)據(jù)庫多條件模糊查詢的思路詳解
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;背景:
頁面的搜索框是有兩個(gè)搜索條件,一個(gè)是國家,一個(gè)是大洲。
那么在數(shù)據(jù)庫查詢的時(shí)候就會出現(xiàn)問題,如果國家傳的值是None那么使用AND連接的sql語句這個(gè)條件會被
整體判定為false,也就是另一個(gè)查詢條件 “大洲 ”就會作廢,為了防止參數(shù)出現(xiàn)這樣的錯(cuò)誤。需要在寫sql語
句的時(shí)候?qū)?shù)是否為空加一個(gè)判斷條件,然后逐層添加sql語句。
思路:首先使用開頭的一個(gè)sql語句:
sql = ' SELECT * FROM world WHERE 1=1 '
之后逐層判定參數(shù)是否為空,再拼接sql語句:
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語句傳參數(shù),參數(shù)是一個(gè)變量,有兩種方式:① 直接拼接到sql語句中:
var c_name='test'sql_temp = ' SELECT * FROM world WHERE c_name LIKE ’ %'+c_name+'% ’'
② 使用占位符%代替,在語句末尾再替換占位符:
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語句對mysql數(shù)據(jù)庫多條件模糊查詢的思路詳解的文章就介紹到這了,更多相關(guān)Python mysql多條件模糊查詢內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. asp中response.write("中文")或者js中文亂碼問題2. 詳解CSS偽元素的妙用單標(biāo)簽之美3. ASP刪除img標(biāo)簽的style屬性只保留src的正則函數(shù)4. 詳解JS前端使用迭代器和生成器原理及示例5. XML入門的常見問題(四)6. html小技巧之td,div標(biāo)簽里內(nèi)容不換行7. 使用css實(shí)現(xiàn)全兼容tooltip提示框8. php bugs代碼審計(jì)基礎(chǔ)詳解9. ASP中格式化時(shí)間短日期補(bǔ)0變兩位長日期的方法10. 詳解PHP實(shí)現(xiàn)HTTP服務(wù)器過程
