av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

Python MySQLdb 執行sql語句時的參數傳遞方式

瀏覽:43日期:2022-08-04 13:16:46

使用MySQLdb連接數據庫執行sql語句時,有以下幾種傳遞參數的方法。

1.不傳遞參數

conn = MySQLdb.connect(user='root',passwd='123456',host='192.168.101.23',db='cmdb')orange_id = 98sql = 'select * from orange where id=%s' % orange_idcursor = conn.cursor(sql)cursor.execute()

2.傳遞參數

color = 'yellow'sql = 'select * from orange where color = %s'

cursor.execute(sql, color)

注意此處的占位符是%s,無論是字符串、數字或者其他類型,都是這個占位符。

另外, %s不能加引號,如’%s’, 這是錯誤的寫法。

與第一種寫法,有什么區別呢?

兩者區別是對變量的解析:

第一種寫法,使用百分號%, 是用Python解釋器對%s執行相應的替換。這種方法存在漏洞,有些時候不能正常解析,比如包含某些特殊字符,甚至會造成注入攻擊的風險。

第二種,變量是作為execute的參數傳入的,由MySQLdb的內置方法把變量解釋成合適的內容。

一般情況下,建議使用第二種方法,把變量作為參數傳遞給execute。

3.使用字典dict類型傳遞參數

sql = 'select * from orange where %(color)s, %(weight)s'values = {'color': 'yellow', 'weight': 30}cursor.execute(sql, values)

這種方式,傳遞的參數對應關系比較清晰。尤其是參數比較多時,使用字典,可以保證傳遞參數的順序正確。

補充知識:python自動化之pymysql庫使用變量向SQL語句中動態傳遞參數(sql注入 || 傳參策略)

使用python 3連接Mysql實現自動化增刪查改庫內數據,由于項目原因很多的sql語句過于復雜,導致sql語句內傳遞的參數過多而且容易變動,導致很多同學不知從何下手動態的傳遞參數,有的采用比較笨的方法拼接sql,但是工作量太大,而且復雜的語句拼接時很容易出錯且不好維護,所以為大家整理了%s占位符的字典傳參的用法

import pymysql db = pymysql.connect(host='119.XX.XX.XX', port=3306, user='XXXXXXXX', passwd='XXXXXXXXXXXXX', db='XXXXXX', charset=’utf8’) # %s 占位符為需要傳遞的參數,切記不要加’’雙引號,要不然會報錯sql = 'SELECT totalusercount * 1.4 FROM mm_project_uv_outdoor WHERE poiid = %s AND currenttime = %s' cursor = db.cursor()# 以下為傳遞多個參數的用法cursor.execute(sql,[’B00140N5CS’,’2019-04-23’])# 傳遞單個參數時 cursor.execute(sql,’B00140N5CS’)print(cursor.fetchall())db.close()

運行后就能得到所查詢的數據了

Python MySQLdb 執行sql語句時的參數傳遞方式

最后建議大家多看官方的文檔或標準教程,這樣更有益學習

以上這篇Python MySQLdb 執行sql語句時的參數傳遞方式就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 久久国产综合 | 男人的天堂在线视频 | 麻豆久久久9性大片 | 久久成人精品视频 | 亚洲444eee在线观看 | 亚州精品天堂中文字幕 | 在线观看日韩 | 国产成人精品免费视频大全最热 | 成人超碰 | 天天玩天天干天天操 | 国产一级特黄真人毛片 | 国产精品18hdxxxⅹ在线 | 天天射天天操天天干 | 国产乱码一区 | 国产成人精品久久二区二区91 | 国精产品一品二品国精在线观看 | jlzzjlzz欧美大全 | 国产精品精品视频一区二区三区 | 午夜网| 北条麻妃av一区二区三区 | 久久网一区二区 | 精品国产乱码久久久久久丨区2区 | 美国av毛片| 九色视频网站 | 99热欧美| 欧美视频在线观看 | 日韩欧美一区二区三区 | 欧美精品网站 | 中文字幕国产 | 欧美高清dvd| 一级片av| www.99re | 一区二区三区四区免费在线观看 | 精品国产一区二区在线 | 国产精品免费一区二区 | 亚洲精品中文字幕 | 四虎永久免费在线 | 精品在线看 | 欧美精品区 | 久草视频2| 免费成人高清 |