Python笔记(十二):操作数据库
(一) 前言
本文说明如何连接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执行失败 | 
(三) 模块安装
Oracle:pip install cx_Oracle
Mysql: pip install pymysql
sql server:https://www.lfd.uci.edu/~gohlke/pythonlibs/ 下载pymssql,然后 pip install xxx.whl。(pip install pymssql 安装不了再用这种方式,上面2个如果安装不了也可以用这种方式去安装)

(四) Oracle示例
从下面3个示例可以看出,代码其实基本相同,只是导入的模块不一样(其他数据库应该也是差不多的)。
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示例
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 示例
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()
 
                     
                    
                 
                    
                
 
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号