args sqlalchemy查詢參數(shù)傳遞

先放一小段代碼

class reload_system_log(Base):    #重裝系統(tǒng)日志表
    __tablename__ = "reload_system_log"
    id                  = Column(Integer,primary_key=True)
    odd_numbers         = Column(String(50),nullable=False)
    key                 = Column(String(32))
    ip                  = Column(String(15))
    sn                  = Column(String(32))
    reloadid            = Column(String(32))
    producerName        = Column(String(32))
    current_state       = Column(String(20))
    execution           = Column(String(20))
    execution_return    = Column(String(20))
    execution_time      = Column(DateTime,default=datetime.now)

    def __repr__(self):
        return "{odd_numbers:%s,ip:%s,}" %(self.odd_numbers,self.ip)

def log_db(**kwargs):

    print kwargs
    selecturi = []
    if 'ip' in kwargs:
        selecturi.append(reload_system_log.ip == kwargs['ip'])

    if 'odd_numbers' in kwargs:
        selecturi.append(reload_system_log.odd_numbers == kwargs['odd_numbers'])

    if 'current_state' in kwargs:
        selecturi.append(reload_system_log.current_state == kwargs['current_state'])

    if 'execution' in kwargs:
        selecturi.append(reload_system_log.execution == kwargs['execution'])

    def select(args):
        select_ip = session.query(reload_system_log).filter(
            *args
        ).all()
        return select_ip


    if selecturi:
        select(selecturi)

被這問題困擾了半個多小時(shí),問了下大神一個*args就搞定了

問題如下:
一個數(shù)據(jù)庫查詢的需求饱苟,需要匹配多個字段葬荷,且這幾個字段根據(jù)業(yè)務(wù)邏輯進(jìn)行輸入喂窟,即有可能是傳入一個也可能是傳入4個,我們對傳入正確的值進(jìn)行判定椒舵,并調(diào)用數(shù)據(jù)庫orm創(chuàng)建該字段的對象蚂踊,然后拋到列表中,醬汁我們就獲取到了所有正確的參數(shù)的orm對象笔宿。

那么問題來了犁钟,我們?nèi)绾伟堰@個列表中的所有參數(shù)按照orm要求的where條件傳入呢?

也就是這段

正常的查詢請求應(yīng)該是醬汁的
select_ip = session.query(reload_system_log).filter(
    reload_system_log.ip == kwargs['ip'],
    reload_system_log.odd_numbers == kwargs['odd_numbers'],
).all()

但是由于我們要對傳入值做判定泼橘,所以要把列表中的對象轉(zhuǎn)換成 對象1,對象2,這樣的字段傳入到orm查詢請求中涝动。

想過將列表中的對象通過for出來,然后格式化到一個變量上炬灭,毫無疑問失敗了
一個變量僅可以綁定一個對象醋粟,或字符串,數(shù)字啥的,但是我們這個是多個對象昔穴,行不通的镰官,大伙可以試試

最終問大神后說你單獨(dú)寫個函數(shù),然后用*args直接解析傳入的列表就可以把列表中的內(nèi)容拆分成 對象1,對象2,這樣的了吗货,試了一把 果然ok

對于args的使用泳唠,可以看下這篇文章,例子很簡單宙搬,理解很容易
http://python.jobbole.com/83476/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末笨腥,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子勇垛,更是在濱河造成了極大的恐慌脖母,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,000評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件闲孤,死亡現(xiàn)場離奇詭異谆级,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)讼积,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評論 3 399
  • 文/潘曉璐 我一進(jìn)店門肥照,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人勤众,你說我怎么就攤上這事舆绎。” “怎么了们颜?”我有些...
    開封第一講書人閱讀 168,561評論 0 360
  • 文/不壞的土叔 我叫張陵吕朵,是天一觀的道長。 經(jīng)常有香客問我窥突,道長努溃,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,782評論 1 298
  • 正文 為了忘掉前任波岛,我火速辦了婚禮茅坛,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘则拷。我一直安慰自己贡蓖,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,798評論 6 397
  • 文/花漫 我一把揭開白布煌茬。 她就那樣靜靜地躺著斥铺,像睡著了一般。 火紅的嫁衣襯著肌膚如雪坛善。 梳的紋絲不亂的頭發(fā)上晾蜘,一...
    開封第一講書人閱讀 52,394評論 1 310
  • 那天邻眷,我揣著相機(jī)與錄音,去河邊找鬼剔交。 笑死肆饶,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的岖常。 我是一名探鬼主播驯镊,決...
    沈念sama閱讀 40,952評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼竭鞍!你這毒婦竟也來了板惑?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,852評論 0 276
  • 序言:老撾萬榮一對情侶失蹤偎快,失蹤者是張志新(化名)和其女友劉穎冯乘,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體晒夹,經(jīng)...
    沈念sama閱讀 46,409評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡裆馒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,483評論 3 341
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了惋戏。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片领追。...
    茶點(diǎn)故事閱讀 40,615評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖响逢,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情棕孙,我是刑警寧澤舔亭,帶...
    沈念sama閱讀 36,303評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站蟀俊,受9級特大地震影響钦铺,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜肢预,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,979評論 3 334
  • 文/蒙蒙 一矛洞、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧烫映,春花似錦沼本、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至族淮,卻和暖如春辫红,著一層夾襖步出監(jiān)牢的瞬間凭涂,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評論 1 272
  • 我被黑心中介騙來泰國打工贴妻, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留切油,地道東北人。 一個月前我還...
    沈念sama閱讀 49,041評論 3 377
  • 正文 我出身青樓名惩,卻偏偏與公主長得像澎胡,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子绢片,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,630評論 2 359