Python操作Sql Server 2008数据库的方法详解


Posted in Python onMay 17, 2018

本文实例讲述了Python操作Sql Server 2008数据库的方法。分享给大家供大家参考,具体如下:

最近由于公司的一个项目需要,需要使用Sql Server 2008数据库,开发语言使用Python,并基于windows平台上的Wing IDE4.0进行。

之前并未使用过Sql Server数据库,这次也当作一次练手,并把这次数据库前期开发过程中遇到的一些问题进行记录。

一、关于pyodbc库和pymssql库的选择

在使用python语言进行开发之前,需要确定使用哪种第三方的数据库操作接口,目前Python提供了一些库,如pymssql和pyodbc,目前网上资料比较多的也是这两个了。刚开始我尝试安装并使用了pymssql库,但是始终无法通过python应用程序远程访问连接Sql Server数据库,由于对windows平台又不太熟悉,网上查了一些资料未果,说是需要依赖feeds,还需要设置各种变量等,最终我放弃了它改用pyodbc,虽然也遇到一些小问题,但是总体来说非常顺利。

二、关于pyodbc库的一些接口说明

基于第三方python库来访问Sql Server数据库的过程非常简单(其实除了能访问sql server外,它还可以访问其它数据库,因为它们都基于标准的DB-API2.0标准),总共只需要四步:打开并连接数据库connect、 获取游标指针、执行数据库sql操作、关闭数据库连接

1 打开连接数据库

cnxn = pyodbc.connect('DRIVER={SQL Server};SERVER=localhost;DATABASE=testdb;UID=me;PWD=pass')

或者是:

cnxn = pyodbc.connect(DRIVER='{SQL Server}',SERVER='localhost',DATABASE='testdb',UID='me',PWD='pass')

这里简单说明一下参数:

DRIVER='{SQL Server}'这个一般是固定的,除非你在Sql Server作了更改。
SERVER:此参数为数据库服务器名称,不是"192.168.0.X"这种,一般在安装时命名好了,我的是:ZHANGHUAMIN\MSSQLSERVER_ZHM
DATABASE:此参数指的是Sql Server内具体的数据库了,使用这个connect接口连接之前在sqlserver内应该是已经先创建好并存在的,否则连接不上。
UID:用户名
PWD:密码

执行完毕后,如果成功将返回一个数据库连接句柄。

2 获取游标指针

cursor = cnxn.cursor()

后面对数据库执行的sql语句将使用游标指针来操作

3 执行数据库sql操作

cursor.execute("select user_id, user_name from users") #调用游标指针的execute方法执行sql语句
row = cursor.fetchone() #sql语句执行结果的获取,如果需要一次获取多条记录,可以使用cursor.fetchall()方法
if row:
  print row

有时对数据库执行完sql语句后需要对此事务进行提交,使用如下接口:

cnxn.commit()

特别是当创建一个数据库或数据表,若未进行提交事务,在Sql Server2008终端上将找不到创建的数据库及数据表,如果提交后,在sql server2008通过终端的查询sql 语句就可以即时查到。注:提交事务的commit方法属于数据库的连接句柄对象

4 关闭数据库连接

cnxn.close()

与文件操作类似,不再说明。

三、用python操作Sql Server 2008数据库的具体例程

#!/usr/bin/python
#coding=utf-8
#-------------------------------------------------------------------------------
# Name: datamapper.py
# Purpose: using pyodbc library to operate database
#
# Author: huamin.zhang
#
# Created: 20/04/2013
#-------------------------------------------------------------------------------
import pyodbc
import time
class ODBC_MS:
  ''''' 对pyodbc库的操作进行简单封装
  pyodbc库的下载地址:http://code.google.com/p/pyodbc/downloads/list
  使用该库时,需要在Sql Server Configuration Manager里面将TCP/IP协议开启
  此类完成对数据库DB的连接/查询/执行操作
  正确的连接方式如下:
  cnxn = pyodbc.connect('DRIVER={SQL SERVER};SERVER=ZHANGHUAMIN\MSSQLSERVER_ZHM;DATABASE=AdventureWorks2008;UID=sa;PWD=wa1234')
  cnxn = pyodbc.connect(DRIVER='{SQL SERVER}',SERVER=r'ZHANGHUAMIN\MSSQLSERVER_ZHM',DATABASE='AdventureWorks2008',UID='sa',PWD='wa1234',charset="utf-8")
  '''
  def __init__(self, DRIVER,SERVER, DATABASE, UID, PWD):
    ''''' initialization '''
    self.DRIVER = DRIVER
    self.SERVER = SERVER
    self.DATABASE = DATABASE
    self.UID = UID
    self.PWD = PWD
  def __GetConnect(self):
    ''''' Connect to the DB '''
    if not self.DATABASE:
      raise(NameError,"no setting db info")
    self.conn = pyodbc.connect(DRIVER=self.DRIVER, SERVER=self.SERVER, DATABASE=self.DATABASE, UID=self.UID, PWD=self.PWD, charset="UTF-8")
    #self.conn = pyodbc.connect(DRIVER=self.DRIVER, SERVER=self.SERVER, DATABASE=self.DATABASE, UID=self.UID, PWD=self.PWD)
    cur = self.conn.cursor()
    if not cur:
      raise(NameError,"connected failed!")
    else:
      return cur
  def ExecQuery(self, sql):
    ''''' Perform one Sql statement '''
    cur = self.__GetConnect() #建立链接并创建数据库操作指针
    cur.execute(sql)#通过指针来执行sql指令
    ret = cur.fetchall()#通过指针来获取sql指令响应数据
    cur.close()#游标指标关闭
    self.conn.close()#关闭数据库连接
    return ret
  def ExecNoQuery(self,sql):
    ''''' Person one Sql statement like write data, or create table, database and so on'''
    cur = self.__GetConnect()
    cur.execute(sql)
    self.conn.commit()#连接句柄来提交
    cur.close()
    self.conn.close()
def main():
  ms = ODBC_MS('{SQL SERVER}', r'ZHANGHUAMIN\MSSQLSERVER_ZHM', 'zhm_db', 'sa', 'wa1234')#zhm_db数据库是在sql server 终端里先创建好的
  #ms.ExecNoQuery("drop table Customers_test")
  sql = '''''CREATE TABLE Customers_test
  (
    CustomerNo   int       IDENTITY   NOT NULL,
    CustomerName  varchar(30)         NOT NULL,
    Address1    nvarchar(30)         NOT NULL ,
    Address2    nvarchar(30)         NOT NULL,
    City      nvarchar(20)         NOT NULL,
    State     nchar(20)          NOT NULL,
    Zip      varchar(10)         NOT NULL,
    Contact    varchar(25)         NOT NULL,
    Phone     char(15)           NOT NULL,
    FedIDNo    varchar(9)          NOT NULL,
    DateInSystem  smalldatetime        NOT NULL
  );'''
  ms.ExecNoQuery(sql)
  #注意:在进行插入操作时,自增长度不能够写入
  sql = u'''''insert into Customers_test
  (
    CustomerName,
    Address1,
    Address2,
    City,
    State,
    Zip,
    Contact,
    Phone,
    FedIDNo,
    DateInSystem
  )
  VALUES
  (
    'zhm', '北京市朝阳区', '北京市朝阳区', '北京', '哈哈','3625514', '18001226509', '010-88765879', '21', '2012-09-09'
  );
  '''
  ms.ExecNoQuery(sql)
if __name__ == '__main__':
  main()

说明:我之前连接了一个Sql Server自带的AdventureWorks2008数据库例程,并在其中创建了一个如上数据表Customers_test,然后插入一条如上记录,结果在Sql Server2008的终端上用Select * FROM Customers_test查询,结果对包含中文信息字段的数据变成如“??????”的乱码,经过倒腾了一上午,唯一可能解释的原因可能在于AdventureWorks2008数据库做了一些我不知道的约束,中文所对应的编码它不支持。 因为在如上例程中,我自己创建的zhm_db数据库,并在其中创建数据表,然后插入记录,同样的在Sql Server终端里用select查询,中文也是可以正常显示的。

注意,在python程序中需要增加:#coding = utf-8编码,并在连接connect内增加charset = "utf-8"指明字符集为utf-8编码即可。这样可以防止乱码的出现

最后在Sql Server 2008内通过终端使用SELECT * FROM Customers_test显示的结果如下:

Python操作Sql Server 2008数据库的方法详解

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

Python 相关文章推荐
Python 迭代器工具包【推荐】
May 06 Python
python下10个简单实例代码
Nov 15 Python
使用Python通过win32 COM打开Excel并添加Sheet的方法
May 02 Python
python实现单链表中删除倒数第K个节点的方法
Sep 28 Python
Python读取Pickle文件信息并计算与当前时间间隔的方法分析
Jan 30 Python
python开发准备工作之配置虚拟环境(非常重要)
Feb 11 Python
python多线程共享变量的使用和效率方法
Jul 16 Python
自定义django admin model表单提交的例子
Aug 23 Python
Python生成六万个随机,唯一的8位数字和数字组成的随机字符串实例
Mar 03 Python
python判断正负数方式
Jun 03 Python
Numpy中np.max的用法及np.maximum区别
Nov 27 Python
Pycharm 跳转回之前所在页面的操作
Feb 05 Python
Python读写及备份oracle数据库操作示例
May 17 #Python
Python selenium抓取微博内容的示例代码
May 17 #Python
Python实现的查询mysql数据库并通过邮件发送信息功能
May 17 #Python
Python实现读取txt文件并转换为excel的方法示例
May 17 #Python
cmd运行python文件时对结果进行保存的方法
May 16 #Python
Python基于lxml模块解析html获取页面内所有叶子节点xpath路径功能示例
May 16 #Python
Python使用Dijkstra算法实现求解图中最短路径距离问题详解
May 16 #Python
You might like
木翼下载系统中说明的PHP安全配置方法
2007/06/16 PHP
php生成xml简单实例代码
2009/12/16 PHP
用PHP的超级变量$_GET获取HTML表单(Form) 数据
2011/05/07 PHP
ThinkPHP模板自定义标签使用方法
2014/06/26 PHP
PHP中的插件机制原理和实例
2014/07/08 PHP
Laravel 5框架学习之Eloquent 关系
2015/04/09 PHP
Javascript绝句欣赏 一些经典的js代码
2012/02/22 Javascript
javascript 获取模态窗口的滚动位置代码
2013/08/06 Javascript
jQuery实现公告文字左右滚动的实例代码
2013/10/29 Javascript
jquery仿搜索自动联想功能代码
2014/05/23 Javascript
Js可拖拽放大的层拖动特效实现方法
2015/02/25 Javascript
JavaScript模拟可展开、拖动与关闭的聊天窗口实例
2015/05/12 Javascript
JS实现随页面滚动显示/隐藏窗口固定位置元素
2016/02/26 Javascript
浅谈bootstrap使用中的一些问题以及解决过程
2016/10/18 Javascript
jquery.zclip轻量级复制失效问题
2017/01/08 Javascript
一个简易的js图片轮播效果
2017/07/22 Javascript
详解Webpack-dev-server的proxy用法
2018/09/08 Javascript
原生js滑动轮播封装
2020/07/31 Javascript
Python多线程和队列操作实例
2015/06/21 Python
python实现应用程序在右键菜单中添加打开方式功能
2017/01/09 Python
python将文本分每两行一组并保存到文件
2018/03/19 Python
利用python-pypcap抓取带VLAN标签的数据包方法
2019/07/23 Python
python 叠加等边三角形的绘制的实现
2019/08/14 Python
Python字符串hashlib加密模块使用案例
2020/03/10 Python
图解Python中深浅copy(通俗易懂)
2020/09/03 Python
Python 使用Opencv实现目标检测与识别的示例代码
2020/09/08 Python
老板电器官方购物商城:老板油烟机、燃气灶、消毒柜、电烤箱
2018/05/30 全球购物
Spongelle官网:美国的创意护肤洗护品牌
2019/05/15 全球购物
WatchShop法国:英国排名第一的独立手表零售商
2020/02/17 全球购物
静态变量和实例变量的区别
2015/07/07 面试题
厂区绿化方案
2014/05/08 职场文书
部门活动策划方案
2014/08/16 职场文书
汽车机电维修工求职信
2014/09/30 职场文书
模范教师事迹材料
2014/12/16 职场文书
国家助学金感谢信
2015/01/21 职场文书
Nginx配置并兼容HTTP实现代码解析
2021/03/31 Servers