佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > Python使用sql語(yǔ)句對(duì)mysql數(shù)據(jù)庫(kù)多條件模糊查詢(xún)的思路詳解

Python使用sql語(yǔ)句對(duì)mysql數(shù)據(jù)庫(kù)多條件模糊查詢(xún)的思路詳解

熱門(mén)標(biāo)簽:Win7旗艦版 電話(huà)運(yùn)營(yíng)中心 企業(yè)做大做強(qiáng) 客戶(hù)服務(wù) 呼叫中心市場(chǎng)需求 百度AI接口 硅谷的囚徒呼叫中心 語(yǔ)音系統(tǒng)
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ù)查詢(xún)的時(shí)候就會(huì)出現(xiàn)問(wèn)題,如果國(guó)家傳的值是None那么使用AND連接的sql語(yǔ)句這個(gè)條件會(huì)被

整體判定為false,也就是另一個(gè)查詢(xún)條件 “大洲 ”就會(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ù)多條件模糊查詢(xún)的思路詳解的文章就介紹到這了,更多相關(guān)Python mysql多條件模糊查詢(xún)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python Spyder 調(diào)出縮進(jìn)對(duì)齊線(xiàn)的操作
  • 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ǔ)入門(mén)之if判斷語(yǔ)句
  • Python 語(yǔ)句的表達(dá)式和縮進(jìn)

標(biāo)簽:山西 崇左 長(zhǎng)沙 山西 安康 喀什 海南 濟(jì)南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python使用sql語(yǔ)句對(duì)mysql數(shù)據(jù)庫(kù)多條件模糊查詢(xún)的思路詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話(huà)咨詢(xún)

    • 400-1100-266
    玛多县| 进贤县| 闸北区| 湟中县| 喀喇沁旗| 修水县| 五大连池市| 东源县| 汉阴县| 灵武市| 府谷县| 鄢陵县| 甘德县| 靖江市| 龙川县| 页游| 宿州市| 景泰县| 明溪县| 岳阳县| 奎屯市| 南汇区| 通许县| 军事| 台中县| 侯马市| 平湖市| 山阴县| 怀远县| 驻马店市| 滕州市| 石台县| 滨海县| 肃南| 大兴区| 泽库县| 巴彦县| 扶绥县| 辽宁省| 儋州市| 南华县|