关闭

python连接SQL Server:Pymssql模块

6868人阅读 评论(1) 收藏 举报
分类:

数据库版本: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关闭连接。

运行效果:



0
0
查看评论

Python——pymssql安装

下载: https://pypi.python.org/pypi/pymssql/2.0.1#downloads pymssql的安装包:pymssql-2.0.1.win32-py2.7.exe 放到目录:D:\Python27\Scripts下 打开cmd.exe 目录转到 D:\...
  • Shiyaru1314
  • Shiyaru1314
  • 2016-08-24 10:48
  • 6040

python 利用pymssql连接sqlserver、查询、传参、插入新表案例

场景:连接数据库后,将某个表的查询结果赋值给另一条查询语句,并将查询后的结果插入到新表。 知识点: *1.pymssql如何连接数据库 2.数据库查询传参 3.字符串之间的相互转换 *import pymssqlimport numpy as npconn=pymssql.connect(h...
  • mengliuqing123
  • mengliuqing123
  • 2017-10-21 11:26
  • 761

python pymssql连接MSSQL以及无法连接解决方法

python 连接pymssql语法就比较通俗直白,有两个模块可以链接数据库。import pymssql import _mssql具体差异可以看官网文档 http://www.pymssql.org/en/stable/intro.html然后就是链接语句conn=pymssql.connec...
  • HuangZhang_123
  • HuangZhang_123
  • 2017-03-22 09:36
  • 2035

python 安装pymssql

refs: http://blog.csdn.net/litingcheng1126/article/details/70333478 pip安装pymssql提示缺少 cl 如下: C:\Program Files(x86)\Microsoft V...
  • Henry_Wu001
  • Henry_Wu001
  • 2018-01-15 16:29
  • 107

Python安装pymssql

Python安装pymssql (v2.1.3)pymssql下载地址: https://pypi.python.org/pypi/pymssql/python2.7 x32版本下pymssql的安装:如果使用2.1.1版本:https://pypi.python.org/pypi/pymssql...
  • yanzhibo
  • yanzhibo
  • 2016-09-03 12:19
  • 15388

pymssql 3.4

  • 2015-01-16 16:25
  • 711KB
  • 下载

python 连接mssqlserver方法之pymssql

安装pymssql模块,参照我之前写的博文python中使用第三方模块 import sys import pymssql class Mssql: def __init__(self, config): self.cf = config def __Connect(...
  • a87b01c14
  • a87b01c14
  • 2015-05-19 20:24
  • 5890

python连接sql server并执行查询操作

python操作sql server...
  • shaxiaozilove
  • shaxiaozilove
  • 2017-02-07 09:02
  • 2630

Python连接SQL Server入门

Python连接SQL Server入门模块import pyodbc模块说明pyodbc模块是用于odbc数据库(一种数据库通用接口标准)的连接,不仅限于SQL server,还包括Oracle,MySQL,Access,Excel等。另外除了pyodbc还有其他几种连接SQL server的模块...
  • chroming
  • chroming
  • 2016-05-30 23:02
  • 21483

python操作sqlserver

python连接sqlserver
  • yangzhawen
  • yangzhawen
  • 2014-08-18 12:10
  • 5485
    个人资料
    • 访问:531071次
    • 积分:9079
    • 等级:
    • 排名:第2469名
    • 原创:362篇
    • 转载:14篇
    • 译文:1篇
    • 评论:137条
    博客专栏
    最新评论