国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python基于Pymssql模塊實現(xiàn)連接SQL Server數(shù)據(jù)庫的方法詳解

2019-11-25 16:00:20
字體:
來源:轉載
供稿:網(wǎng)友

本文實例講述了Python基于Pymssql模塊實現(xiàn)連接SQL Server數(shù)據(jù)庫的方法。分享給大家供大家參考,具體如下:

數(shù)據(jù)庫版本:SQL Server 2012

按照Python版本來選擇下載pymssql模塊,這樣才能連接上sql server。

我安裝的python版本是3.5 ,64位的,所以下載的pymssql模塊是:pymssql-2.1.3-cp35-cp35m-win_amd64.whl

我把文件下載后放到E盤,安裝pymssql模塊:

C:/Users/Administrator>pip install e:/pymssql-2.1.3-cp35-cp35m-win_amd64.whlProcessing e:/pymssql-2.1.3-cp35-cp35m-win_amd64.whlInstalling collected packages: pymssqlSuccessfully installed pymssql-2.1.3

一、創(chuàng)建數(shù)據(jù)庫Test、表tb、插入數(shù)據(jù)

特別需要注意的是:為了避免亂碼問題,這里Name列是nvarchar類型的(適合中文),不會出現(xiàn)亂碼現(xiàn)象,一開始用的varchar類型出現(xiàn)了亂碼。

create database Test;gouse test;goif object_id('tb') is not null  drop table tb;goCREATE TABLE TB(ID INT,NAME NVARCHAR(20),SCORE NUMERIC(10,2));INSERT INTO TB(ID,NAME,SCORE)VALUES(1,'語文',100),   (2,'數(shù)學',80),   (3,'英語',900),   (4,'政治',65),   (5,'物理',65),   (6,'化學',85),   (7,'生物',55),   (8,'地理',100)

二、連接數(shù)據(jù)庫、查詢、增加、更新數(shù)據(jù)

connect的參數(shù):

user:用戶名
password:密碼
trusted:布爾值,指定是否使用windows身份認證登陸
host :主機名
database:數(shù)據(jù)庫
timeout:查詢超時
login_timeout:登陸超時
charset:數(shù)據(jù)庫的字符集
as_dict:布爾值,指定返回值是字典還是元組
max_conn:最大連接數(shù)

# -*- coding:gbk -*-import pymssql#數(shù)據(jù)庫連接conn=pymssql.connect(host='wc-pc',user='sa',password='ggg',database='Test')#打開游標cur=conn.cursor();if not cur:  raise Exception('數(shù)據(jù)庫連接失敗!')sSQL = 'SELECT * FROM TB'#執(zhí)行sql,獲取所有數(shù)據(jù)cur.execute(sSQL)result=cur.fetchall()#1.result是list,而其中的每個元素是 tupleprint(type(result),type(result[0]))#2.print('/n/n總行數(shù):'+ str(cur.rowcount))#3.通過enumerate返回行號for i,(id,name,v) in enumerate(result):  print('第 '+str(i+1)+' 行記錄->>> '+ str(id) +':'+ name+ ':' + str(v) )#4.修改數(shù)據(jù)cur.execute("insert into tb(id,name,score) values(9,'歷史',75)")cur.execute("update tb set score=95 where id=7")conn.commit() #修改數(shù)據(jù)后提交事務#再查一次cur.execute(sSQL)#5.一次取一條數(shù)據(jù),cur.rowcount為-1r=cur.fetchone()i=1print('/n')while r:  id,name,v =r #r是一個元祖  print('第 '+str(i)+' 行記錄->>> '+ str(id) +':'+ name+ ':' + str(v) )  r=cur.fetchone()  i+= 1conn.close()

基本的步驟就是:

(1)連接數(shù)據(jù)庫,指定連接參數(shù)
(2)打開cursor,執(zhí)行sql
(3)通過cursor獲取數(shù)據(jù),具體可以是一次獲取所有數(shù)據(jù),也可以是一次獲取一行。
 整個結果集是元組列表,就是list類型的,而每一條記錄是一個tuple,也就是元祖。
(4)如果是增、改數(shù)據(jù),必須就要調用commit()函數(shù)來提交事務,否則程序已退出,數(shù)據(jù)庫里的數(shù)據(jù)不會有變化。
(5)最后要用close關閉連接。

運行效果:

更多關于Python相關內容感興趣的讀者可查看本站專題:《Python常見數(shù)據(jù)庫操作技巧匯總》、《Python編碼操作技巧總結》、《Python數(shù)據(jù)結構與算法教程》、《Python函數(shù)使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經(jīng)典教程》及《Python文件與目錄操作技巧匯總

希望本文所述對大家Python程序設計有所幫助。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 武夷山市| 济源市| 鹿邑县| 萨嘎县| 桐柏县| 义马市| 三台县| 灌南县| 从江县| 宝清县| 甘孜| 松桃| 晋州市| 开鲁县| 顺昌县| 大关县| 普格县| 织金县| 繁峙县| 南木林县| 上饶县| 东辽县| 吉木萨尔县| 双辽市| 广宗县| 达州市| 明水县| 雅江县| 刚察县| 辽源市| 延庆县| 桃源县| 眉山市| 铜川市| 临高县| 永丰县| 曲沃县| 永修县| 子洲县| 广饶县| 罗田县|