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之编写类之一创建实例
Oct 11 Python
Python函数返回值实例分析
Jun 08 Python
Python进行数据提取的方法总结
Aug 22 Python
Python 稀疏矩阵-sparse 存储和转换
May 27 Python
用Python登录好友QQ空间点赞的示例代码
Nov 04 Python
初探利用Python进行图文识别(OCR)
Feb 26 Python
python队列Queue的详解
May 10 Python
Python使用pyautocad+openpyxl处理cad文件示例
Jul 11 Python
Python MongoDB 插入数据时已存在则不执行,不存在则插入的解决方法
Sep 24 Python
Python改变对象的字符串显示的方法
Aug 01 Python
OpenCV读取与写入图片的实现
Oct 13 Python
Python爬虫之Selenium实现关闭浏览器
Dec 04 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
PHP中调用JAVA
2006/10/09 PHP
谈谈PHP语法(4)
2006/10/09 PHP
浅析Mysql 数据回滚错误的解决方法
2013/08/05 PHP
zf框架的db类select查询器join链表使用示例(zend框架)
2014/03/14 PHP
php使用ZipArchive提示Fatal error: Class ZipArchive not found in的解决方法
2014/11/04 PHP
php分页查询mysql结果的base64处理方法示例
2017/05/18 PHP
在每个匹配元素的外部插入新元素的方法
2013/12/20 Javascript
百度判断手机终端并自动跳转js代码及使用实例
2014/06/11 Javascript
基于jQuery实现复选框是否选中进行答题提示
2015/12/10 Javascript
JavaScript语言精粹经典实例(整理篇)
2016/06/07 Javascript
JS控制层作圆周运动的方法
2016/06/20 Javascript
Laydate时间组件在火狐浏览器下有多时间输入框时只能给第一个输入框赋值的解决方法
2016/08/18 Javascript
微信小程序后台解密用户数据实例详解
2017/06/28 Javascript
基于Vue2.0+ElementUI实现表格翻页功能
2017/10/23 Javascript
Vue插值、表达式、分隔符、指令知识小结
2018/10/12 Javascript
layui表格 返回的数据状态异常的解决方法
2019/09/10 Javascript
Javascript模块化机制实现原理详解
2020/04/02 Javascript
javascript实现移动端触屏拖拽功能
2020/07/29 Javascript
python zip文件 压缩
2008/12/24 Python
在Python的Django框架下使用django-tagging的教程
2015/05/30 Python
详解Django框架中的视图级缓存
2015/07/23 Python
python list排序的两种方法及实例讲解
2017/03/20 Python
使用Django和Python创建Json response的方法
2018/03/26 Python
python中的反斜杠问题深入讲解
2019/08/12 Python
关于numpy中eye和identity的区别详解
2019/11/29 Python
pytorch AvgPool2d函数使用详解
2020/01/03 Python
美国礼品卡交易网站:Cardpool
2018/08/27 全球购物
英国皇家造币厂:The Royal Mint
2018/10/05 全球购物
网络教育自我鉴定
2013/11/01 职场文书
生物制药自我鉴定
2014/01/25 职场文书
年终考核实施方案
2014/05/26 职场文书
高中生期中考试失利检讨书
2014/10/23 职场文书
社区党建工作总结2015
2015/05/13 职场文书
师范生小学见习总结
2015/06/23 职场文书
二年级数学教学反思
2016/02/16 职场文书
NoSQL优缺点与MongoDB数据库简介
2022/06/05 MongoDB