前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python笔记(十二):操作数据库

Python笔记(十二):操作数据库

作者头像
free赖权华
发布2018-05-02 11:16:56
9410
发布2018-05-02 11:16:56
举报
文章被收录于专栏:赖权华的笔记赖权华的笔记

(一)      前言

    本文说明如何连接Oracle、MySQL、sqlserver,以及执行sql、获取查询结果等。

(二)      DB-API

DB-API阐明一系列所需对象和数据库访问机制的标准。

Python操作数据库的模块如果遵循DB-API的标准(应该都会遵循这个标准),函数、方法的名称及功能应该是差不多的(下面几张表格列出了部分内容),就是传的参数可能有点区别。

                                                                  connect函数

connect函数通过connection对象访问数据库。该函数创建并返回一个connection对象。

参数

说明

host

数据库实例的访问地址(例如:IP\实例名)

user

用户名

password

密码

database

数据库名

                                                                 connection对象     

方法

说明

close()

关闭数据库连接

commit()

提交事务

rollback()

取消事务

cursor()

使用该连接创建并返回一个游标对象(或类游标对象)

                                                                 cursor对象

                                                       (感觉比较重要的就下面这3个)

方法

说明

execute()

执行SQL

fetchall()

获取查询结果(执行select 语句后)

callproc()

调用存储过程

                                                                      异常

异常

说明

DataError

处理数据时出现问题

OperationalError

数据库操作执行期间出现问题

IntegrityError

数据库关系完整性错误

ProgrammingError

SQL执行失败

(三)      模块安装

代码语言:javascript
复制
Oracle:pip install cx_Oracle  
代码语言:javascript
复制
Mysql: pip install pymysql
代码语言:javascript
复制
sql server:https://www.lfd.uci.edu/~gohlke/pythonlibs/ 下载pymssql,然后 pip install xxx.whl。(pip install pymssql 安装不了再用这种方式,上面2个如果安装不了也可以用这种方式去安装)

(四)      Oracle示例

从下面3个示例可以看出,代码其实基本相同,只是导入的模块不一样(其他数据库应该也是差不多的)。

代码语言:javascript
复制
import cx_Oracle
# 连接数据库,参数:用户名/密码@服务器ip:端口号/实例名
conn = cx_Oracle.connect('py/password@192.168.4.196:1521/orcl')
# 创建游标对象
cur = conn.cursor()
#执行SQL
cur.execute("insert into test_py t values('1005','ZS','张三','123456')")
cur.execute("update test_py t set t.user_name='李四' where t.id='123' ")
#提交事务
conn.commit()
#执行SQL
cur.execute("select * from test_py")
#获得查询结果
row = cur.fetchall()
print(row)
#关闭数据库连接
conn.close()

(五)      MySql示例

代码语言:javascript
复制
 1 import pymysql
 2 
 3 # 连接数据库,host:服务器ip user:用户名 password:密码  database:数据库名
 4 conn = pymysql.connect(host='192.168.4.196', user='root', password='password', database='test')
 5 # 创建游标对象
 6 cur = conn.cursor()
 7 #执行SQL
 8 cur.execute("insert into test_py(id,user_account) values('100','admin')")
 9 cur.execute("update test_py  set user_account = 'test6' where id='123'")
10 #提交事务
11 conn.commit()
12 #执行SQL
13 cur.execute("select * from test_py")
14 #获得查询结果
15 row = cur.fetchall()
16 print(row)
17 #关闭数据库连接
18 conn.close()

(六)      Sql server 示例

代码语言:javascript
复制
import pymssql

# 连接数据库,host:服务器ip\\实例名 user:用户名 password:密码  database:数据库名
conn = pymssql.connect(host='192.168.4.196\\amsys', user='sa', password='123', database='test')
# 创建游标对象
cur = conn.cursor()
#执行SQL
cur.execute("insert into test_py(id,user_account) values('100861','admin')")
cur.execute("update test_py  set user_account = 'test6' where id='123'")
#提交事务
conn.commit()
#执行SQL
cur.execute("select * from test_py")
#获得查询结果
row = cur.fetchall()
print(row)
#关闭数据库连接
conn.close()
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-04-27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档