1.事务的特性

原子性,要么完成,要么都不完成

2.psycopg的事务特点

在psycopg中,事务是由connection处理的,当第一次一个命令发送给数据库时(开启数据库操作游标),

一个事务就建立了。接下来的sql命令都会在这个事务中执行,不仅仅是这个游标的sql操作命令,其他的只要是同一个连接connection

开启的游标,sql命令都会在这一个事务中进行。

如果有任何sql命令执行失败,事务将终止,不会再有sql命令执行,直到执行了rollback()方法。

代码示例如下:

  1. import psycopg2
  2. conn = psycopg2.connect(host='127.0.0.1', port=5432, user='postgres', password='1', database='postgres')
  3. cursor = conn.cursor()
  4. cursor.execute('insert into test(a,b) values(%s,%s)',(3,'huiyunyun'))
  5. cursor.execute('SELECT a,b FROM test')
  6. data_list = cursor.fetchall()
  7. for item in data_list:
  8. print(item[0])
  9. print('---------')
  10. cursor.close()
  11. cursor = conn.cursor()
  12. cursor.execute('SELECT a,b FROM test')
  13. data_list = cursor.fetchall()
  14. for item in data_list:
  15. print(item[0])
  16. print('---------')
  17. cursor.close()
  18. conn.close()
  19. conn = psycopg2.connect(host='127.0.0.1', port=5432, user='postgres', password='1', database='postgres')
  20. cursor = conn.cursor()
  21. cursor.execute('SELECT a,b FROM test')
  22. data_list = cursor.fetchall()
  23. for item in data_list:
  24. print(item[0])
  25. print('---------')
  26. cursor.close()
  27. conn.close()

运行结果:

【1.png】

connection负责终止事务,执行commit()或者rollback()方法。

关闭连接close()或销毁连接del事务默认rollback

3.自动提交

设置连接为autocommit模式,命令会自动提交,持久化到数据库。

4.with语句使用

示例如下:

  1. with psycopg2.connect(DSN) as conn:
  2. with conn.cursor() as curs:
  3. curs.execute(SQL)

connection结束时,没有异常发生,事务commit,否则rollback,结束事务,但是不会调用close()关闭连接;

cursor结束时,会释放与其相关的资源,但事务不会有影响

  1. conn = psycopg2.connect(DSN)
  2. with conn:
  3. with conn.cursor() as curs:
  4. curs.execute(SQL1)
  5. with conn:
  6. with conn.cursor() as curs:
  7. curs.execute(SQL2)
  8. conn.close()

5.线程安全

多线程使用数据库有两种方式

1)每个线程创建一个connection,使用单独的会话

2)使用相同的connection,使用共同的会话,即同一个事务

psycopg事务的更多相关文章

  1. Odoo 后端数据库postgreSQL事务级别

    Table of Contents 事务的特性 并行事务的问题 事务隔离级别 Odoo事务隔离级别 odoo事务控制         事务的特性 事务4个特性,简写未ACID 原子性(Atomicit ...

  2. Spring基于AOP的事务管理

                                  Spring基于AOP的事务管理 事务 事务是一系列动作,这一系列动作综合在一起组成一个完整的工作单元,如果有任何一个动作执行失败,那么事务 ...

  3. SQLServer事务同步下如何收缩日志

    事务同步是SQLServer做读写分离的一种常用的方式. 随着业务数据的不断增长,数据库积攒了大量的日志,为了腾出硬盘空间,需要对数据库日志进行清理 订阅数据库的日志清理 因为订阅数据库所有的数据都来 ...

  4. 事务日志已满,原因为“ACTIVE_TRANSACTION”

    汇总篇:http://www.cnblogs.com/dunitian/p/4822808.html#tsql 异常处理汇总-数据库系列  http://www.cnblogs.com/dunitia ...

  5. Mysql事务探索及其在Django中的实践(二)

    继上一篇<Mysql事务探索及其在Django中的实践(一)>交代完问题的背景和Mysql事务基础后,这一篇主要想介绍一下事务在Django中的使用以及实际应用给我们带来的效率提升. 首先 ...

  6. Mysql事务探索及其在Django中的实践(一)

    前言 很早就有想开始写博客的想法,一方面是对自己近期所学知识的一些总结.沉淀,方便以后对过去的知识进行梳理.追溯,一方面也希望能通过博客来认识更多相同技术圈的朋友.所幸近期通过了博客园的申请,那么今天 ...

  7. CRL快速开发框架系列教程七(使用事务)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  8. 玩转spring boot——结合JPA事务

    接着上篇 一.准备工作 修改pom.xml文件 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi=&q ...

  9. MySQL 系列(三)你不知道的 视图、触发器、存储过程、函数、事务、索引、语句

    第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...

随机推荐

  1. 转:Ogre的八叉树场景管理器OctreeSceneManager

    上面是我绘制的一张图. 关于八叉树场景管理器主要需要关注两个类,其一是松散八叉树的数据结构Ogre::Octree,其二是八叉树场景管理器Ogre::OctreeSceneManager. 下面摘录图 ...

  2. C#中巧用#if DEBUG 进行调试

    #if DEBUG是个好东西. #if DEBUG UserID = "abc@test.com"; Password = "; #endif 当调试代码的时候加上适当的 ...

  3. samba服务的高级进阶配置

    本文将学习一下几个方面的内容,将会结合具体的实验来一步步实现. 1. 用户账号的映射 2. 使用IP对客户端进行访问控制 3. 使用域名对客户端进行访问控制 4. 使用通配符对客户端进行访问控制 5. ...

  4. 怎样看待IT界业务,技术,管理的各自比重

    怎样看待IT界业务,技术,管理的各自比重   技术是根本,业务是个人能力的体现,管理一般随意,追求简单,眼光向IBM等有优秀管理经验的大公司看齐   重点从个人的喜好.性格方面来考虑分配比重,可以加上 ...

  5. 【Oracle】Oracle的内外连接

    目录结构: contents structure [+] Oracle的内外连接 内连接 等值连接 非等值连接 自连接 外连接 外连接的特点 如何实现外连接 SQL99的内外连接 SQL99的内连接 ...

  6. 【struts2】拦截器基础

    1)拦截器是什么? 拦截器(Interceptor)是Struts2最强大的特性之一,它是一种可以让你在Action执行之前和Result执行之后进行一些功能处理的机制.来回顾一下官方给出的Strut ...

  7. mysql FullText全文索引的问题

    今天有同学问题,搜索ip的时候怎样能把 select ip from tabelx where ip like '%192.168.0.1%' 这种句子的性能优化. 的确,使用 like %x 的方式 ...

  8. python 生成图表

    python写入excel(xlswriter)--生成图表 折线图 # -*- coding:utf-8 -*- import xlsxwriter # 创建一个excel workbook = x ...

  9. RecyclerView的滚动事件OnScrollListener研究

      (1)滚动事件分类 列表的滚动一般分为两种: 1.手指按下 -> 手指拖拽列表移动 -> 手指停止拖拽 -> 抬起手指 2.手指按下 -> 手指快速拖拽后抬起手指 -> ...

  10. Linux/Unix 新手和专家教程

    你正在找一些高质量的Linux 和 UNIX 的教程吗?如果是,这篇文章会告诉你到哪去找到这些教程.这里我们将给出超过30个相当的不错的 Linux 和 UNIX 在线的教程. 需要大家注意的是,他们 ...