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ò)誤。需要在寫(xiě)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)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- Python Spyder 調(diào)出縮進(jìn)對(duì)齊線的操作
- python縮進(jìn)長(zhǎng)度是否統(tǒng)一
- Python代碼需要縮進(jìn)嗎
- python程序快速縮進(jìn)多行代碼方法總結(jié)
- 超詳細(xì)講解python正則表達(dá)式
- python通過(guò)re正則表達(dá)式切割中英文的操作
- Python驗(yàn)證的50個(gè)常見(jiàn)正則表達(dá)式
- python re模塊和正則表達(dá)式
- Python 條件,循環(huán)語(yǔ)句詳解
- Python基礎(chǔ)入門之if判斷語(yǔ)句
- Python 語(yǔ)句的表達(dá)式和縮進(jìn)