python链接SQL Server:Pymssql模块

数据库版本:SQL Server 2012。html

按照python版原本选择下载pymssql模块,这样才能链接上sql server。python

我安装的python版本是3.5 ,64位的,因此下载的pymssql模块是:pymssql-2.1.3-cp35-cp35m-win_amd64.whlsql

我把文件下载后放到E盘,安装pymssql模块:数据库

 

C:\Users\Administrator>pip install e:\pymssql-2.1.3-cp35-cp35m-win_amd64.whl
Processing e:\pymssql-2.1.3-cp35-cp35m-win_amd64.whl
Installing collected packages: pymssql
Successfully installed pymssql-2.1.3

 

 

1、建立数据库Test、表tb、插入数据windows

特别须要注意的是:为了不乱码问题,这里Name列是nvarchar类型的(适合中文),不会出现乱码现象,一开始用的varchar类型出现了乱码。函数

 

create database Test;
go

use test;
go

if object_id('tb') is not null
   drop table tb;
go

CREATE TABLE TB(ID INT,NAME NVARCHAR(20),SCORE NUMERIC(10,2));

INSERT INTO TB(ID,NAME,SCORE)
VALUES(1,'语文',100),
      (2,'数学',80),
	  (3,'英语',900),
	  (4,'政治',65),

	  (5,'物理',65),
	  (6,'化学',85),
	  (7,'生物',55),
	  (8,'地理',100)

 

2、链接数据库、查询、增长、更新数据post

connect的参数:
user:用户名
password:密码
trusted:布尔值,指定是否使用windows身份认证登录
host :主机名
database:数据库
timeout:查询超时
login_timeout:登录超时
charset:数据库的字符集
as_dict:布尔值,指定返回值是字典仍是元组
max_conn:最大链接数
fetch

 

 

# -*- coding:gbk -*-


import pymssql

#数据库链接
conn=pymssql.connect(host='wc-pc',user='sa',password='ggg',database='Test')

#打开游标
cur=conn.cursor();

if not cur:
    raise Exception('数据库链接失败!')

sSQL = 'SELECT * FROM TB'

#执行sql,获取全部数据
cur.execute(sSQL)
result=cur.fetchall()


#1.result是list,而其中的每一个元素是 tuple
print(type(result),type(result[0]))


#2.
print('\n\n总行数:'+ str(cur.rowcount))


#3.经过enumerate返回行号
for i,(id,name,v) in enumerate(result):
    print('第 '+str(i+1)+' 行记录->>> '+ str(id) +':'+ name+ ':' + str(v) )



#4.修改数据
cur.execute("insert into tb(id,name,score) values(9,'历史',75)")
cur.execute("update tb set score=95 where id=7")
conn.commit() #修改数据后提交事务



#再查一次
cur.execute(sSQL)


#5.一次取一条数据,cur.rowcount为-1
r=cur.fetchone()
i=1

print('\n')

while r:
    id,name,v =r #r是一个元祖
    print('第 '+str(i)+' 行记录->>> '+ str(id) +':'+ name+ ':' + str(v) )
    r=cur.fetchone()
    i+= 1

conn.close()

基本的步骤就是:spa

 

(1)链接数据库,指定链接参数code

(2)打开cursor,执行sql

(3)经过cursor获取数据,具体能够是一次获取全部数据,也能够是一次获取一行。

 整个结果集是元组列表,就是list类型的,而每一条记录是一个tuple,也就是元祖。

(4)若是是增、改数据,必须就要调用commit()函数来提交事务,不然程序已退出,数据库里的数据不会有变化。

(5)最后要用close关闭链接。

运行效果:



 

转载于:https://www.cnblogs.com/momogua/p/8304402.html