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 相关文章推荐
使用python BeautifulSoup库抓取58手机维修信息
Nov 21 Python
php使用递归与迭代实现快速排序示例
Jan 23 Python
Python中正则表达式的用法实例汇总
Aug 18 Python
python3实现抓取网页资源的 N 种方法
May 02 Python
Python AES加密模块用法分析
May 22 Python
Python3.6 Schedule模块定时任务(实例讲解)
Nov 09 Python
python ddt实现数据驱动
Mar 14 Python
python3.6.3+opencv3.3.0实现动态人脸捕获
May 25 Python
python opencv实现图片旋转矩形分割
Jul 26 Python
Django代码性能优化与Pycharm Profile使用详解
Aug 26 Python
Python中修改字符串的四种方法
Nov 02 Python
python爬虫 爬取58同城上所有城市的租房信息详解
Jul 30 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
Mysql的GROUP_CONCAT()函数使用方法
2008/03/28 PHP
MySQL时间字段究竟使用INT还是DateTime的说明
2012/02/27 PHP
PHP判断指定时间段的2个方法
2014/03/14 PHP
php导入大量数据到mysql性能优化技巧
2014/12/29 PHP
Win7下手动安装apache2.2、php5.4笔记
2015/04/03 PHP
PHP正则验证字符串是否为数字的两种方法并附常用正则
2019/02/27 PHP
Jquery validation remote 验证的缓存问题解决方法
2014/03/25 Javascript
js实现类似新浪微博首页内容渐显效果的方法
2015/04/10 Javascript
探讨:JavaScript ECAMScript5 新特性之get/set访问器
2016/05/05 Javascript
JavaScript的React Web库的理念剖析及基础上手指南
2016/05/10 Javascript
JavaScript实现简单的拖动效果
2016/07/02 Javascript
javascript 玩转Date对象(实例讲解)
2017/07/11 Javascript
微信小程序修改swiper默认指示器样式的实例代码
2018/07/18 Javascript
jQuery ajax仿Google自动提示SearchSuggess功能示例
2019/03/28 jQuery
「中高级前端面试」JavaScript手写代码无敌秘籍(推荐)
2019/04/08 Javascript
Weex开发之地图篇的具体使用
2019/10/16 Javascript
详解Python中time()方法的使用的教程
2015/05/22 Python
Python中内建函数的简单用法说明
2016/05/05 Python
python Flask实现restful api service
2017/12/04 Python
Python中实现switch功能实例解析
2018/01/11 Python
Python实现识别手写数字大纲
2018/01/29 Python
Python实现抓取HTML网页并以PDF文件形式保存的方法
2018/05/08 Python
python整合ffmpeg实现视频文件的批量转换
2019/05/31 Python
python验证码图片处理(二值化)
2019/11/01 Python
Jupyter打开图形界面并画出正弦函数图像实例
2020/04/24 Python
Python调用OpenCV实现图像平滑代码实例
2020/06/19 Python
Canvas图片分割效果的实现
2019/07/29 HTML / CSS
草莓网化妆品加拿大网站:Strawberrynet Canada
2016/09/20 全球购物
毕业生个人求职的自我评价
2013/10/28 职场文书
普通简短的个人自我评价
2014/02/15 职场文书
餐厅楼面主管岗位职责范本
2014/02/16 职场文书
春节联欢晚会主持词范文
2014/03/24 职场文书
保护环境倡议书
2014/04/14 职场文书
班主任工作经验交流材料
2014/05/13 职场文书
2015年煤矿安全工作总结
2015/05/23 职场文书
公司联欢会主持词
2015/07/04 职场文书