Python3操作SQL Server数据库(实例讲解)


Posted in Python onOctober 21, 2017

1.前言

前面学完了SQL Server的基本语法,接下来学习如何在程序中使用sql,毕竟不能在程序中使用的话,实用性就不那么大了。

2.最基本的SQL查询语句

python是使用pymssql这个模块来操作SQL Server数据库的,所有需要先安装pymssql。

这个直接在命令行里输入pip install pymssql安装就行了

然后还要配置好自己本地的SQL Server数据库,进入Microsoft SQL Server Management Studio中可以进行设置。如果你选择的是使用Windows身份验证的方式的话,要改成SQL验证方式才行。这个网上教程很多,搜索一下就出来了。

3.简单测试语句

import pymssql

conn = pymssql.connect(host='127.0.0.1',
            user='sa',
            password='123',
            database='SQLTest',
            charset='utf8')

#查看连接是否成功
cursor = conn.cursor()
sql = 'select * from student'
cursor.execute(sql)
#用一个rs变量获取数据
rs = cursor.fetchall()

print(rs)

打开IDLE,新建python程序:

运行结果:

Python3操作SQL Server数据库(实例讲解)

4.提交与回滚

在python中,在操作完 "增删改" 之后,还需要执行commit()才能真正提交代码执行,如果出意外的话就执行rollback()回滚到之前的状态,相当于之前的操作都白做了,这样也保护了数据库。

所以建议写程序这样写:

try:
  conn = pymssql.connect(host='127.0.0.1',
              user='sa',
              password='123',
              database='SQLTest',
              charset='utf8')
  cursor = conn.cursor()
  sql = 'insert into student values('0001', '张三', 18, '男', '文学院')'
  cursor.execute(sql)
  conn.commit()
except Exception as ex:
  conn.rollback()
  raise ex
finally:
  conn.close()

大家可以试一试将conn.commit()删去,然后看看数据库是否有变化。

5.封装成类的写法

'''
  TestDB类
  功能:测试数据库的类写法
  作者:PyLearn
  博客: http://www.cnblogs.com/PyLearn/
  最后修改日期: 2017/10/17
'''
import pymssql

class TestDB():

  def __init__(self):
    try:
      self.conn = pymssql.connect(host='127.0.0.1',
                    user='sa',
                    password='123',
                    database='SQLTest',
                    charset='utf8')
      self.cursor = self.conn.cursor()
      self.sql = "insert into student values('0001', '张三', 18, '男', '文学院')"
      self.cursor.execute(self.sql)
      self.conn.commit()
    except Exception as ex:
      self.conn.rollback()
      raise ex
    finally:
      self.conn.close()

if __name__ == '__main__':
  test_DB = TestDB()

以上这篇Python3操作SQL Server数据库(实例讲解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
pyqt4教程之widget使用示例分享
Mar 07 Python
以windows service方式运行Python程序的方法
Jun 03 Python
Django中的“惰性翻译”方法的相关使用
Jul 27 Python
Python学习笔记整理3之输入输出、python eval函数
Dec 14 Python
Python实现输出程序执行进度百分比的方法
Sep 16 Python
Python栈算法的实现与简单应用示例
Nov 01 Python
机器学习经典算法-logistic回归代码详解
Dec 22 Python
Python中列表与元组的乘法操作示例
Feb 10 Python
python判断一个集合是否为另一个集合的子集方法
May 04 Python
基于python修改srt字幕的时间轴
Feb 03 Python
简单了解python列表和元组的区别
May 14 Python
Flask使用SQLAlchemy实现持久化数据
Jul 16 Python
Python3实现简单可学习的手写体识别(实例讲解)
Oct 21 #Python
python虚拟环境virtualenv的使用教程
Oct 20 #Python
Python环境搭建之OpenCV的步骤方法
Oct 20 #Python
详解如何用OpenCV + Python 实现人脸识别
Oct 20 #Python
python中的计时器timeit的使用方法
Oct 20 #Python
浅谈Python peewee 使用经验
Oct 20 #Python
Python 获得13位unix时间戳的方法
Oct 20 #Python
You might like
领悟php接口中interface存在的意义
2013/06/27 PHP
PHP获取服务器端信息的方法
2014/11/28 PHP
php强制运行广告的方法
2014/12/01 PHP
PHP基于yii框架实现生成ICO图标
2015/11/13 PHP
php实现在新浪云中使用imagick生成缩略图并上传的方法
2016/09/26 PHP
CI框架AR数据库操作常用函数总结
2016/11/21 PHP
js 判断 enter 事件
2009/02/12 Javascript
javascript 混合的构造函数和原型方式,动态原型方式
2009/12/07 Javascript
jquery获取当前元素索引值用法实例
2015/06/10 Javascript
javascript字符串循环匹配实例分析
2015/07/17 Javascript
javascript作用域链(Scope Chain)用法实例解析
2015/11/30 Javascript
jQuery form插件之formDdata参数校验表单及验证后提交
2016/01/23 Javascript
jQuery获取浏览器类型和版本号的方法
2016/07/05 Javascript
Angularjs中ng-repeat-start与ng-repeat-end的用法实例介绍
2016/12/31 Javascript
微信小程序实现打开内置地图功能【附源码下载】
2017/12/07 Javascript
webpack vue项目开发环境局域网访问方法
2018/03/20 Javascript
详解keep-alive + vuex 让缓存的页面灵活起来
2019/04/19 Javascript
[14:50]2018DOTA2亚洲邀请赛开幕式
2018/04/03 DOTA
[01:03:47]VP vs NewBee Supermajor 胜者组 BO3 第一场 6.5
2018/06/06 DOTA
[45:59]完美世界DOTA2联赛PWL S2 FTD vs GXR 第二场 11.22
2020/11/24 DOTA
[01:04:02]DOTA2-DPC中国联赛 正赛 Elephant vs IG BO3 第二场 1月24日
2021/03/11 DOTA
一个基于flask的web应用诞生 flask和mysql相连(4)
2017/04/11 Python
django 创建过滤器的实例详解
2017/08/14 Python
python实现石头剪刀布程序
2021/01/20 Python
Python的形参和实参使用方式
2019/12/24 Python
利用Python如何画一颗心、小人发射爱心
2021/02/21 Python
微信小程序canvas实现水平、垂直居中效果
2020/02/05 HTML / CSS
中国最大的团购网站:聚划算
2016/09/21 全球购物
在网上学习全世界最好的课程:Coursera
2017/11/07 全球购物
Lacoste澳大利亚官网:服装、鞋类及配饰
2018/11/14 全球购物
银行实习自我鉴定
2013/10/12 职场文书
员工保密承诺书
2014/05/28 职场文书
护士求职简历自我评价
2015/03/10 职场文书
卢旺达饭店观后感
2015/06/05 职场文书
安全温馨提示语大全
2015/07/14 职场文书
idea 在springboot中使用lombok插件的方法
2021/08/02 Java/Android