第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

內(nèi)聯(lián)列表以在python MySQLDB IN子句中使用

內(nèi)聯(lián)列表以在python MySQLDB IN子句中使用

慕勒3428872 2019-09-21 11:03:20
我知道如何將列表映射到字符串:foostring = ",".join( map(str, list_of_ids) )而且我知道我可以使用以下命令將該字符串放入IN子句中:cursor.execute("DELETE FROM foo.bar WHERE baz IN ('%s')" % (foostring))我需要使用MySQLDB安全地完成同一件事(避免SQL注入)。在上面的示例中,由于foostring沒有作為執(zhí)行參數(shù)傳遞,因此它很容易受到攻擊。我還必須在mysql庫(kù)之外引用和轉(zhuǎn)義。
查看完整描述

3 回答

?
慕的地10843

TA貢獻(xiàn)1785條經(jīng)驗(yàn) 獲得超8個(gè)贊

無痛MySQLdb execute('...WHERE name1 = %s AND name2 IN (%s)', value1, values2)


def execute(sql, *values):


    assert sql.count('%s') == len(values), (sql, values)

    placeholders = []

    new_values = []

    for value in values:

        if isinstance(value, (list, tuple)):

            placeholders.append(', '.join(['%s'] * len(value)))

            new_values.extend(value)

        else:

            placeholders.append('%s')

            new_values.append(value)

    sql = sql % tuple(placeholders)

    values = tuple(new_values)


    # ... cursor.execute(sql, values)


查看完整回答
反對(duì) 回復(fù) 2019-09-21
  • 3 回答
  • 0 關(guān)注
  • 555 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)