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

作者:不想长大啊 时间:2024-01-15 03:13:17 

本文实例讲述了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,Pymssql模块,SQL,Server数据库
0
投稿

猜你喜欢

  • python 实现非极大值抑制算法(Non-maximum suppression, NMS)

    2021-01-18 21:46:20
  • mybatis分页插件pageHelper详解及简单实例

    2024-01-19 17:35:25
  • Python使用pymysql模块操作mysql增删改查实例分析

    2024-01-24 03:56:48
  • Python实现图片裁剪的两种方式(Pillow和OpenCV)

    2022-07-08 12:42:47
  • 阿里云CentOS7搭建Apache+PHP+MySQL环境

    2023-11-23 02:44:59
  • 让你Python到很爽的加速递归函数的装饰器

    2022-10-23 13:04:47
  • 利用SQL语言有没有办法查到表中哪些记录中的全部

    2009-04-10 18:29:00
  • Python图像处理之直线和曲线的拟合与绘制【curve_fit()应用】

    2021-01-28 10:30:49
  • python 下划线的不同用法

    2021-01-20 16:55:13
  • MHTML在ie7/vista bug 解决方案

    2010-02-01 12:42:00
  • pycharm部署、配置anaconda环境的教程

    2022-08-23 11:50:54
  • Python requests发送post请求的一些疑点

    2022-09-09 17:45:03
  • ROS  TF坐标变换基本概念及使用案例

    2022-02-01 10:25:35
  • Python插入Elasticsearch操作方法解析

    2021-08-30 01:47:09
  • PHP概率计算函数汇总

    2023-11-19 08:06:19
  • 安装2019Pycharm最新版本的教程详解

    2023-06-25 23:27:54
  • MySQL Server 层四个日志详解

    2024-01-18 12:12:59
  • python-图片流传输的思路及示例(url转换二维码)

    2021-06-18 14:48:44
  • Python如何配置环境变量详解

    2021-11-20 08:18:21
  • 详解在SpringBoot如何优雅的使用多线程

    2021-07-27 13:02:39
  • asp之家 网络编程 m.aspxhome.com