Python基于Pymssql模块实现连接SQL Server数据库的方法详解


Posted in Python onJuly 20, 2017

本文实例讲述了Python基于Pymssql模块实现连接SQL Server数据库的方法。分享给大家供大家参考,具体如下:

数据库版本: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.whl
Processing e:\pymssql-2.1.3-cp35-cp35m-win_amd64.whl
Installing collected packages: pymssql
Successfully installed pymssql-2.1.3

一、创建数据库Test、表tb、插入数据

特别需要注意的是:为了避免乱码问题,这里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)

二、连接数据库、查询、增加、更新数据

connect的参数:

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

# -*- 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()

基本的步骤就是:

(1)连接数据库,指定连接参数
(2)打开cursor,执行sql
(3)通过cursor获取数据,具体可以是一次获取所有数据,也可以是一次获取一行。
 整个结果集是元组列表,就是list类型的,而每一条记录是一个tuple,也就是元祖。
(4)如果是增、改数据,必须就要调用commit()函数来提交事务,否则程序已退出,数据库里的数据不会有变化。
(5)最后要用close关闭连接。

运行效果:

Python基于Pymssql模块实现连接SQL Server数据库的方法详解

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python 中文乱码问题深入分析
Mar 13 Python
Python的ORM框架SQLObject入门实例
Apr 28 Python
Python 提取dict转换为xml/json/table并输出的实现代码
Aug 28 Python
itchat和matplotlib的结合使用爬取微信信息的实例
Aug 25 Python
python3使用pyqt5制作一个超简单浏览器的实例
Oct 19 Python
python+django+sql学生信息管理后台开发
Jan 11 Python
nohup后台启动Python脚本,log不刷新的解决方法
Jan 14 Python
Django对接支付宝实现支付宝充值金币功能示例
Dec 17 Python
Pandas时间序列:重采样及频率转换方式
Dec 26 Python
Pytorch 实现focal_loss 多类别和二分类示例
Jan 14 Python
TensorFlow实现指数衰减学习率的方法
Feb 05 Python
tensorflow指定CPU与GPU运算的方法实现
Apr 21 Python
Python使用内置json模块解析json格式数据的方法
Jul 20 #Python
Python轻量级ORM框架Peewee访问sqlite数据库的方法详解
Jul 20 #Python
Python函数式编程
Jul 20 #Python
python 换位密码算法的实例详解
Jul 19 #Python
python实现rsa加密实例详解
Jul 19 #Python
Python中标准库OS的常用方法总结大全
Jul 19 #Python
spyder常用快捷键(分享)
Jul 19 #Python
You might like
《雄兵连》系列首部大电影《烈阳天道》:可能是因为期望值太高了
2020/08/18 国漫
解决GD中文乱码问题
2007/02/14 PHP
zend framework多模块多布局配置
2011/02/26 PHP
理解PHP中的stdClass类
2014/04/18 PHP
PHP实现递归目录的5种方法
2016/10/27 PHP
IE和Firefox下event事件杂谈
2009/12/18 Javascript
在多个页面使用同一个HTML片段的代码
2011/03/04 Javascript
取得元素的左和上偏移量的方法
2014/09/17 Javascript
jQuery插件Skippr实现焦点图幻灯片特效
2015/04/12 Javascript
JavaScript模拟push
2016/03/06 Javascript
一波JavaScript日期判断脚本分享
2016/03/06 Javascript
jQuery+ajax+asp.net获取Json值的方法
2016/06/08 Javascript
深入理解requestAnimationFrame的动画循环
2016/09/20 Javascript
微信小程序 wx.request(object) API详解及实例代码
2016/09/30 Javascript
js 实现获取name 相同的页面元素并循环遍历的方法
2017/02/14 Javascript
使用JavaScriptCore实现OC和JS交互详解
2017/03/28 Javascript
实例解析ES6 Proxy使用场景介绍
2018/01/08 Javascript
浅谈react受控组件与非受控组件(小结)
2018/02/09 Javascript
详解redis在nodejs中的应用
2018/05/02 NodeJs
vue-cli项目修改文件热重载失效的解决方法
2018/09/19 Javascript
微信小程序之下拉列表实现方法解析(附完整源码)
2019/08/23 Javascript
layui之table checkbox初始化时选中对应选项的方法
2019/09/02 Javascript
JSX在render函数中的应用详解
2019/09/04 Javascript
[00:14]PWL:老朋友Mushi拍VLOG与中国玩家问好
2020/11/04 DOTA
Python使用自带的ConfigParser模块读写ini配置文件
2016/06/26 Python
Java如何基于wsimport调用wcf接口
2020/06/17 Python
python通过cython加密代码
2020/12/11 Python
AE美国鹰日本官方网站: American Eagle Outfitters
2016/12/10 全球购物
毕业生毕业总结的自我评价范文
2013/11/02 职场文书
学生检讨书怎么写?
2014/10/10 职场文书
国庆庆典邀请函
2015/02/02 职场文书
投诉书格式范本
2015/07/02 职场文书
庆元旦主持词
2015/07/06 职场文书
您对思维方式了解多少?
2019/12/09 职场文书
Python基于Opencv识别两张相似图片
2021/04/25 Python
入门学习Go的基本语法
2021/07/07 Golang