python 连接 SQL Server 数据库
#!/usr/bin/python
# -*- coding:utf-8 -*-
import pymssql
import pyodbc
host = '127.0.0.1:1433'
user = 'sa'
password = '*****'
database = 'student'
# SERVER是服务器名称,DATABASE是数据库名称,UID是用户名,PWD是密码
odbc = 'DRIVER={SQL Server};SERVER=DESKTOP-MC70Q1A;DATABASE=student;UID=sa;PWD=******'
# 数据库pymssql连接
def db_connect():
# 打开数据库连接
db = pymssql.connect(host, user, password, database)
# 使用cursor()方法创建一个游标对象cursor
cursor = db.cursor()
# 使用execute()方法执行SQL查询
cursor.execute('SELECT @@VERSION')
# 使用fetchone()方法获取单条数据
data = cursor.fetchone()
print('数据库版本为:%s' % data)
# 关闭数据库连接
db.close()
# 数据库pyodbc连接
def db_connect1():
# 打开数据库连接
db = pyodbc.connect(odbc)
# 使用cursor()方法创建一个游标对象cursor
cursor = db.cursor()
# 使用execute()方法执行SQL查询
cursor.execute('SELECT @@VERSION')
# 使用fetchone()方法获取单条数据
data = cursor.fetchone()
print('数据库版本为:%s' % ''.join(data))
# 关闭数据库连接
db.close()
# 数据库pymssql插入
def insert_record():
db = pymssql.connect(host, user, password, database)
cursor = db.cursor()
# 插入语句
sql = """
INSERT Course VALUES('10021','插入课程1',NULL)
INSERT Course VALUES('10022','插入课程2',NULL)
INSERT Course VALUES('10023','插入课程3',NULL)
"""
try:
# 执行sql语句
cursor.execute(sql)
# 提交到数据库执行
db.commit()
print('插入成功')
except Exception as e:
print('插入失败:%s' % e)
# 如果发生错误就回滚
db.rollback()
finally:
# 关闭数据库连接
db.close()
# 数据库pyodbc插入
def insert_record1():
db = pyodbc.connect(odbc)
cursor = db.cursor()
# 插入语句
sql = """
INSERT Course VALUES('10024','插入课程4',NULL)
INSERT Course VALUES('10025','插入课程5',NULL)
INSERT Course VALUES('10026','插入课程6',NULL)
"""
try:
# 执行sql语句
cursor.execute(sql)
# 提交到数据库执行
db.commit()
print('插入成功')
except Exception as e:
print('插入失败:%s' % e)
# 如果发生错误就回滚
db.rollback()
finally:
# 关闭数据库连接
db.close()
# 数据库pymssql删除
def delete_record():
db = pymssql.connect(host, user, password, database)
cursor = db.cursor()
# 删除语句
sql = " DELETE FROM Course WHERE cno IN('10021','10022','10023')"
try:
# 执行sql语句
cursor.execute(sql)
# 提交到数据库执行
db.commit()
print('删除成功')
except Exception as e:
print('删除失败:%s' % e)
# 如果发生错误就回滚
db.rollback()
finally:
# 关闭数据库连接
db.close()
# 数据库pyodbc删除
def delete_record1():
db = pyodbc.connect(odbc)
cursor = db.cursor()
# 删除语句
sql = "DELETE FROM Course WHERE cno IN('10024','10025','10026')"
try:
# 执行sql语句
cursor.execute(sql)
# 提交到数据库执行
db.commit()
print('删除成功')
except Exception as e:
print('删除失败:%s' % e)
# 如果发生错误就回滚
db.rollback()
finally:
# 关闭数据库连接
db.close()
# pymssql创建数据库表
def create_table():
db = pymssql.connect(host, user, password, database)
cursor = db.cursor()
# 创建表语句
sql = """
DROP TABLE
IF EXISTS New_table
CREATE TABLE New_table(
name CHAR(20) NULL,
age INT,
sex CHAR(2))
"""
try:
# 执行sql语句
cursor.execute(sql)
# 提交到数据库执行
db.commit()
print('创建表成功')
except Exception as e:
print('创建表失败:%s' % e)
# 如果发生错误就回滚
db.rollback()
finally:
# 关闭数据库连接
db.close()
# pyodbc创建数据库表
def create_table1():
db = pyodbc.connect(odbc)
cursor = db.cursor()
# 创建表语句
sql = """
DROP TABLE
IF EXISTS New_table1
CREATE TABLE New_table1(
name CHAR(20) NULL,
age INT,
sex CHAR(2))
"""
try:
# 执行sql语句
cursor.execute(sql)
# 提交到数据库执行
db.commit()
print('创建表成功')
except Exception as e:
print('创建表失败:%s' % e)
# 如果发生错误就回滚
db.rollback()
finally:
# 关闭数据库连接
db.close()
# 数据库pymssql查询
def query_data():
db = pymssql.connect(host, user, password, database)
cursor = db.cursor()
# 查询语句
sql = "SELECT * FROM Course WHERE cbefore='高等数学'"
try:
# 执行sql语句
cursor.execute(sql)
# 获取所有记录列表
results = cursor.fetchall()
for row in results:
cno = row[0]
cname = row[1]
cbefore = row[2]
# 输出结果
print('课程号:{0}\t课程名:{1}\t\t先行课:{2}'.format(cno, cname, cbefore))
except Exception as e:
print('查询失败:%s' % e)
finally:
# 关闭数据库连接
db.close()
# 数据库pyodbc查询
def query_data1():
db = pyodbc.connect(odbc)
cursor = db.cursor()
# 查询语句
sql = "SELECT * FROM Course WHERE cbefore='高等数学'"
try:
# 执行sql语句
cursor.execute(sql)
# 获取所有记录列表
results = cursor.fetchall()
for row in results:
cno = row[0]
cname = row[1]
cbefore = row[2]
# 输出结果
print('课程号:{0}\t课程名:{1}\t\t先行课:{2}'.format(cno, cname, cbefore))
except Exception as e:
print('查询失败:%s' % e)
finally:
# 关闭数据库连接
db.close()
# 数据库pymssql修改
def alter_table():
db = pymssql.connect(host, user, password, database)
cursor = db.cursor()
# 创建表语句
sql = """
ALTER TABLE New_table
ALTER COLUMN sex CHAR(3)
ALTER TABLE New_table
DROP COLUMN age
"""
try:
# 执行sql语句
cursor.execute(sql)
# 提交到数据库执行
db.commit()
print('修改表成功')
except Exception as e:
print('修改表失败:%s' % e)
# 如果发生错误就回滚
db.rollback()
finally:
# 关闭数据库连接
db.close()
# 数据库pyodbc修改
def alter_table1():
db = pymssql.connect(host, user, password, database)
cursor = db.cursor()
# 创建表语句
sql = """
ALTER TABLE New_table1
ALTER COLUMN sex CHAR(3)
ALTER TABLE New_table1
DROP COLUMN age
"""
try:
# 执行sql语句
cursor.execute(sql)
# 提交到数据库执行
db.commit()
print('修改表成功')
except Exception as e:
print('修改表失败:%s' % e)
# 如果发生错误就回滚
db.rollback()
finally:
# 关闭数据库连接
db.close()
注意:
1.在使用pymssql模块连接SQL Server执行查询操作时会出现中文乱码问题,尝试了编码改成GBK以及UTF-8最终都以失败告终。执行插入操作以及其它为出现问题,可正常显示。
2.使用pyodbc模块连接SQL Server效果则相对较好,没有出现中文乱码问题,建议首选。
3.执行操作时一定要使用commit语句提交到数据库执行。
4.如果发生错误记得要使用rollback语句回滚。
python 连接 SQL Server 数据库的更多相关文章
- python连接sql server数据库实现增删改查
简述 python连接微软的sql server数据库用的第三方模块叫做pymssql(document:http://www.pymssql.org/en/stable/index.html).在官 ...
- python 连接sql server数据库的示例代码
首先,到http://pymssql.sourceforge.net/下载pymssql模块,必须安装这个模块才可以用python连接mysql 以下是sql server的操作代码,需要注意字符集 ...
- Python连接SQL Server数据库 - pymssql使用基础
连接数据库 pymssql连接数据库的方式和使用sqlite的方式基本相同: 使用connect创建连接对象 connect.cursor创建游标对象,SQL语句的执行基本都在游标上进行 cursor ...
- python连接sql server数据库
记录一下pyodbc连接数据库的使用方法和注意事项,基于python2.7: 前提: pip install pyodbc .下载pyodbc包. pyodbc.connect('DRIVER ...
- Python 连接Sql Server数据库 MSSql
Python 想要和MSSql数据库进行交互,首先要下载名为"pymssql"的包,然后import该包即可. 地址:https://pypi.python.org/pypi/py ...
- Python 连接SQL Server数据库 - pymssql使用基础
1. 官方api http://www.pymssql.org/en/stable/ref/pymssql.html 我学习自这里
- Python3.7.1学习(八) Python访问SQL Server数据库
一.pip install pymssql即可安装pymssql库 二.Python连接SQL Server数据库 实例代码如下: # -*- coding:utf-8 -*-"&q ...
- python 使用pymssql连接sql server数据库
python 使用pymssql连接sql server数据库 #coding=utf-8 #!/usr/bin/env python#------------------------------ ...
- python 连接sql server
linux 下pymssql模块的安装 所需压缩包:pymssql-2.1.0.tar.bz2freetds-patched.tar.gz 安装: tar -xvf pymssql-2.1.0.tar ...
随机推荐
- hdu 2196【树形dp】
http://acm.hdu.edu.cn/showproblem.php?pid=2196 题意:找出树中每个节点到其它点的最远距离. 题解: 首先这是一棵树,对于节点v来说,它到达其它点的最远距离 ...
- 给图片加ALT属性是个什么意思?有什么优点呢
使用百度统计的seo建议当中一条图片ALT信息"存在没有alt信息的img标签"扣分较多.站点图片中加入ALT对seo有什么优点呢?这是非常多初学seo的朋友们都须要询问的问题.a ...
- 解决uploadify插件不同浏览器下的兼容性问题
http://www.thinkphp.cn/code/2138.html uploadify在部分浏览器上没法使用,或者各种报错的解决方法.uploadify插件上传图片是很爽的体验. 如果用chr ...
- 当better-scroll遇见了react擦出的火花
关于better-scroll这个插件前面已经介绍过两次了 从原生js使用到结合服务端发送数据使用都有过介绍 今天给大家分享一下这款插件在react中遇见的坑 总之我真是对这款插件又爱又恨 每次各种 ...
- Python 基础06 循环
循环用于重复执行一些程序块.从上一讲的选择结构,我们已经看到了如何用缩进来表示程序块的隶属关系. 循环也会用到类似的写法. for 循环 for 循环需要预先设定好循环的次数(n) 然后执行隶属于fo ...
- react+antd 点击分页为上次操作结果
最近项目中在使用antd的分页组件时发生了第一次点击分页无变化,再次点击时数据为上一次的分页结果,代码如下: setPageIndex = (pagination)=> { const page ...
- oracle 通过内部函数提高SQL效率.
SELECT H.EMPNO,E.ENAME,H.HIST_TYPE,T.TYPE_DESC,COUNT(*) FROM HISTORY_TYPE T,EMP E,EMP_HISTORY H WHER ...
- Ext--Layout(布局)
EXT中的布局,常用的有border.column.fit.form.tabel这几种. Fit布局,子元素将自动填满整个父容器(对元素设置宽度无效),如果容器组件中有多个子元素,则只会显示第一个子元 ...
- Python--day71--分页功能
分页功能代码: from django.shortcuts import render # Create your views here. from app01 import models def b ...
- SpringBoot 集成 Activiti 一路踩得坑
由于项目需要,本人开始在项目Spring boot 中集成工作流引擎Activiti.由于第一次集成,一路上步步都是坑,怪我没有先去看官方文档.现将一路上遇到的问题一一记录. 一. 环境配置 1.项目 ...