这里有新鲜出炉的 Python 多线程编程,程序狗速度看过来!
Python 是一种面向对象、解释型计算机程序设计语言,由 Guido van Rossum 于 1989 年底发明,第一个公开发行版发行于 1991 年。Python 语法简洁而清晰,具有丰富和强大的类库。它常被昵称为胶水语言,它能够把用其他语言制作的各种模块(尤其是 C/C++)很轻松地联结在一起。
这篇文章主要介绍了 Python sqlite3 事务处理方法, 结合具体实例形式分析了 Python 针对 sqlite3 事务处理的操作技巧, 代码中包含详尽的注释, 需要的朋友可以参考下
本文实例讲述了 Python sqlite3 事务处理方法。分享给大家供大家参考,具体如下:
sqlite3 事务总结:
在 connect() 中不传入 isolation_level
事务处理:
使用
- connection.commit()
- # ! /usr/bin / env python# - *-coding: utf - 8 - *-'''sqlite3事务总结:
- 在connect()中不传入 isolation_level
- 事务处理:
- 使用connection.commit()
- 分析:
- 智能commit状态:
- 生成方式: 在connect()中不传入 isolation_level, 此时isolation_level==''
- 在进行 执行Data Modification Language (DML) 操作(INSERT/UPDATE/DELETE/REPLACE)时, 会自动打开一个事务,
- 在执行 非DML, 非query (非 SELECT 和上面提到的)语句时, 会隐式执行commit
- 可以使用 connection.commit()方法来进行提交
- 注意:
- 不能和cur.execute("COMMIT")共用
- 自动commit状态:
- 生成方式: 在connect()中传入 isolation_level=None
- 这样,在任何DML操作时,都会自动提交
- 事务处理
- connection.execute("BEGIN TRANSACTION")
- connection.execute("COMMIT")
- 如果不使用事务, 批量添加数据非常缓慢
- 数据对比:
- 两种方式, 事务耗时差别不大
- count = 100000
- 智能commit即时提交耗时: 0.621
- 自动commit耗时: 0.601
- 智能commit即时提交耗时: 0.588
- 自动commit耗时: 0.581
- 智能commit即时提交耗时: 0.598
- 自动commit耗时: 0.588
- 智能commit即时提交耗时: 0.589
- 自动commit耗时: 0.602
- 智能commit即时提交耗时: 0.588
- 自动commit耗时: 0.622
- '''import sys import time class Elapse_time(object) : '''耗时统计工具'''def __init__(self, prompt = '') : self.prompt = prompt self.start = time.time() def __del__(self) : print('%s耗时: %.3f' % (self.prompt, time.time() - self.start)) CElapseTime = Elapse_time import sqlite3#-------------------------------------------------------------------------------#测试#filename = 'e:/temp/a.db'def prepare(isolation_level = '') : connection = sqlite3.connect(filename, isolation_level = isolation_level) connection.execute("create table IF NOT EXISTS people (num, age)") connection.execute('delete from people') connection.commit() return connection,
- connection.cursor() def db_insert_values(cursor, count) : num = 1 age = 2 * num
- while num <= count: cursor.execute("insert into people values (?, ?)", (num, age)) num += 1 age = 2 * num def study_case1_intelligent_commit(count) : '''
- 在智能commit状态下, 不能和cur.execute("COMMIT")共用
- '''connection,
- cursor = prepare() elapse_time = Elapse_time(' 智能commit') db_insert_values(cursor, count)#cursor.execute("COMMIT")#产生异常cursor.execute("select count(*) from people") print(cursor.fetchone()) def study_case2_autocommit(count) : connection,
- cursor = prepare(isolation_level = None) elapse_time = Elapse_time(' 自动commit') db_insert_values(cursor, count) cursor.execute("select count(*) from people") print(cursor.fetchone()) def study_case3_intelligent_commit_manual(count) : connection,
- cursor = prepare() elapse_time = Elapse_time(' 智能commit即时提交') db_insert_values(cursor, count) connection.commit() cursor.execute("select count(*) from people") print(cursor.fetchone()) def study_case4_autocommit_transaction(count) : connection,
- cursor = prepare(isolation_level = None) elapse_time = Elapse_time(' 自动commit') connection.execute("BEGIN TRANSACTION;")#关键点db_insert_values(cursor, count) connection.execute("COMMIT;")#关键点cursor.execute("select count(*) from people;") print(cursor.fetchone()) if __name__ == '__main__': count = 10000 prepare() for i in range(5) : #study_case1_intelligent_commit(count)#不提交数据#study_case2_autocommit(count)#非常缓慢study_case3_intelligent_commit_manual(count) study_case4_autocommit_transaction(count)
来源: http://www.phperz.com/article/17/0711/336786.html