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中的rfind()方法使用详解
May 19 Python
在Django中创建动态视图的教程
Jul 15 Python
Python使用os模块和fileinput模块来操作文件目录
Jan 19 Python
Python中应该使用%还是format来格式化字符串
Sep 25 Python
python中join()方法介绍
Oct 11 Python
python能做什么 python的含义
Oct 12 Python
Python3 A*寻路算法实现方式
Dec 24 Python
Python性能分析工具py-spy原理用法解析
Jul 27 Python
Python 如何查找特定类型文件
Aug 17 Python
Python的3种运行方式:命令行窗口、Python解释器、IDLE的实现
Oct 10 Python
使用tensorflow 实现反向传播求导
May 26 Python
Python简易开发之制作计算器
Apr 28 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
咖啡因含量是由谁决定的?低因咖啡怎么来?低因咖啡适合什么人喝
2021/03/06 新手入门
php cookie 作用范围?不要在当前页面使用你的cookie
2009/03/24 PHP
基于php常用函数总结(数组,字符串,时间,文件操作)
2013/06/27 PHP
PHP在网页中动态生成PDF文件详细教程
2014/07/05 PHP
PHP判断字符串长度的两种方法很实用
2015/09/22 PHP
jQuery+json实现的简易Ajax调用实例
2015/12/14 Javascript
老生常谈js动态添加事件--- 事件委托
2016/07/19 Javascript
玩转NODE.JS(四)-搭建简单的聊天室的代码
2016/11/11 Javascript
基于jquery实现二级联动效果
2017/03/30 jQuery
phantomjs导出html到pdf的方法总结
2017/10/19 Javascript
jQuery 防止相同的事件快速重复触发方法
2018/02/08 jQuery
vue.js层叠轮播效果的实例代码
2018/11/08 Javascript
vue中组件的过渡动画及实现代码
2018/11/21 Javascript
移动端如何用下拉刷新的方式实现上拉加载
2018/12/10 Javascript
详解nodejs 开发企业微信第三方应用入门教程
2019/03/12 NodeJs
npx create-react-app xxx创建项目报错的解决办法
2020/02/17 Javascript
Vue Cli3 打包配置并自动忽略console.log语句的方法
2020/04/23 Javascript
[01:34]DOTA2 7.22版本新增神杖效果一览(敏捷英雄篇)
2019/05/28 DOTA
Python将字符串常量转化为变量方法总结
2019/03/17 Python
Python闭包和装饰器用法实例详解
2019/05/22 Python
初次部署django+gunicorn+nginx的方法步骤
2019/09/11 Python
PageFactory设计模式基于python实现
2020/04/14 Python
乐天旅游台湾网站:Rakuten Travel TW
2017/06/01 全球购物
婴儿地球:Baby Earth
2018/12/25 全球购物
"序列点" 是什么
2016/07/29 面试题
长青弘远的面试题
2012/06/09 面试题
最新个人职业生涯规划书
2014/01/22 职场文书
医学生自我鉴定范文
2014/03/26 职场文书
金融事务专业求职信
2014/04/25 职场文书
师德自我剖析材料范文
2014/10/06 职场文书
妈妈再爱我一次观后感
2015/06/08 职场文书
三十年同学聚会感言
2015/07/30 职场文书
国家助学金受助感言
2015/08/01 职场文书
新员工入职感想
2015/08/07 职场文书
2015年秋学期师德师风建设工作总结
2015/10/23 职场文书
Python常遇到的错误和异常
2021/11/02 Python