日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 芯聞號(hào) > 充電吧
[導(dǎo)讀]Python連接SQL Server入門(mén) 模塊import pyodbc模塊說(shuō)明pyodbc模塊是用于odbc數(shù)據(jù)庫(kù)(一種數(shù)據(jù)庫(kù)通用接口標(biāo)準(zhǔn))的連接,不僅限于SQL server,還包括Orac

Python連接SQL Server入門(mén) 模塊

import pyodbc

模塊說(shuō)明

pyodbc模塊是用于odbc數(shù)據(jù)庫(kù)(一種數(shù)據(jù)庫(kù)通用接口標(biāo)準(zhǔn))的連接,不僅限于SQL server,還包括Oracle,MySQL,Access,Excel等。

另外除了pyodbc還有其他幾種連接SQL server的模塊,感興趣的可以在這里找到:https://wiki.python.org/moin/SQL%20Server

連接

傳遞odbc標(biāo)準(zhǔn)的連接字符串給 connect 方法即可:

對(duì)于SQL server寫(xiě)法如下:

conn?=?pyodbc.connect(r'DRIVER={SQL?Server?Native?Client?11.0};SERVER=test;DATABASE=test;UID=user;PWD=password')

注意:官方文檔中使用了port參數(shù),而官方wiki中連接SQL server是沒(méi)有port參數(shù)的。實(shí)際連接中發(fā)現(xiàn)加了port參數(shù)連不上(08001錯(cuò)誤),port要寫(xiě)在server參數(shù)中,逗號(hào)分割,如:

conn?=?pyodbc.connect(r'DRIVER={SQL?Server?Native?Client?11.0};SERVER=192.168.1.1,3433;DATABASE=test;UID=user;PWD=password')

注意:不同的SQL server版本對(duì)應(yīng)的DRIVER字段不同。對(duì)應(yīng)關(guān)系如下:

{SQL Server} - released with SQL Server 2000 {SQL Native Client} - released with SQL Server 2005 (also known as version 9.0) {SQL Server Native Client 10.0} - released with SQL Server 2008 {SQL Server Native Client 11.0} - released with SQL Server 2012

注意:使用pyodbc需要安裝微軟官方的Native Client(沒(méi)有安裝會(huì)報(bào)錯(cuò)IM002),安裝SQL server management studio會(huì)自動(dòng)附帶安裝(控制面板里可以看到安裝的版本)。如果沒(méi)有安裝過(guò)需要在https://msdn.microsoft.com/en-us/data/ff658533.aspx下載安裝(sqlncli.msi)。建議選擇與遠(yuǎn)程數(shù)據(jù)庫(kù)版本相對(duì)應(yīng)的Native Client。如果本地安裝的Native Client是高版本,則DRIVER={SQL Server Native Client 11.0}需要填寫(xiě)的是本地的高版本。

使用pyodbc連接其他支持odbc的數(shù)據(jù)庫(kù)方式可參考pyodbc官方wiki。

獲取內(nèi)容

連接之后需要先建立cursor:

cursor?=?conn.cursor()

使用 execute 方法運(yùn)行SQL語(yǔ)句:

cursor.execute("select?user_id,?user_name?from?users")

execute 返回的仍然是cursor

使用 fetchone() 方法依次獲取結(jié)果中需要的內(nèi)容:

row?=?cursor.fetchone()
if?row:
????print(row)

print('name:',?row[1])?????????#?access?by?column?index
print('name:',?row.user_name)??#?or?access?by?name

使用fetchall()直接獲取所有execute結(jié)果作為一個(gè)list:

cursor.execute("select?user_id,?user_name?from?users")
rows?=?cursor.fetchall()
for?row?in?rows:
????print(row.user_id,?row.user_name)

由于execute返回的是cursor本身,所以如果你需要一次直接獲取所有內(nèi)容可以直接使用cursor本身來(lái)獲?。?/p>

cursor.execute("select?user_id,?user_name?from?users"):
for?row?in?cursor:
????print(row.user_id,?row.user_name)

增刪改

增刪改數(shù)據(jù)庫(kù)的內(nèi)容也是直接傳遞SQL語(yǔ)句給execute方法。但要注意運(yùn)行之后需要用commit提交變更:

cursor.execute("insert?into?products(id,?name)?values?('pyodbc',?'awesome?library')")
conn.commit()
cursor.execute("delete?from?products?where?id?<>??",?'pyodbc')
print('Deleted?{}?inferior?products'.format(cursor.rowcount))
conn.commit()

參考資料:

《pyodbc 官方文檔》http://mkleehammer.github.io/pyodbc/ ?《pyodbc官方wiki》https://github.com/mkleehammer/pyodbc/wiki ?《pyodbc的簡(jiǎn)單使用》http://my.oschina.net/zhengyijie/blog/35587
本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀
關(guān)閉