postgresql事务
查看更多教程:http://www.gitbook.net/postgresql/2013080567.html
事务与并发控制
数据库几大特性:
ACID:
Atomicity:原子性:一个事务要么全部执行,要么全部不执行
Consistency :一致性:执行事务的时候,数据库从一个一致的状态变更到另一个状态
Isolation:隔离性: 确保在并发执行的时候,每个事务感觉不到其他事务在并发的执行
Durability:持久性:一个事务完成之后,即使数据库发生故障,他对数据库的改变应该永久的保存在数据库中。
并发引起的现象
- 脏读:一个事务读取了第二个事务的已经修改但是未提交的数据
- 不可重复读:一个事务第一次读取数据之后,被读取的数据被另一个已提交的事务进行了修改,事务再次读取这些数据时候发现数据已经被另外一个事务所修改,两次查询不一致
- 幻读:一个事务的两次结果集记录数不一致(特殊的不可重复读)
- 查看数据库的隔离级别操作
- 查看全局事务级别
select name,setting from pg_settings where name = 'default_transaction_isolation' - 修改全局事务隔离级别
alter system set default_transaction_islation to 'REPEATABLE READ';select pg_reload_conf();select current_setting('transaction_isolation'); - 查看当前会话的事务隔离级别
show transaction_isolcation; - 设置当前事务的事务隔离级别
start transaction isolation level READ UNCOMMITED; - start TRANSACTION select xxxx
- END
事物是如何开始的?
1、每条SQL语句就是一个事物。「自动提交模式」
2、直到用户执行commit或rollback为止作一个事务。
2.1、事务开始 sql server 、Postgresql 是下面方式:
Begin transaction ;
Update student set name=‘teddy’ where id=3 ;
Update student set age=‘13’ where id=3 ;
Commit ;———>提交处理
2.2、事务开始 mysql 是下面方式:start transaction ;
start transaction ;
Update student set name=‘teddy’ where id=3 ;
Update student set age=‘13’ where id=3 ;
Commit ;———>提交处理
事务回滚例子:
begin transaction ;
Update student set name=‘teddy’ where id=3 ;
Update student set age=‘13’ where id=3 ;
rollback ;———>取消处理
创建表:create table student ( student_id integer , name varchar(12),sex varchar(12),age integer);
插入数据:insert into student values(1,'teddy','man',25),(2,’Tony’,’man',27)(3,’lida’,’man',25);
更新数据:Update student set name=‘teddy’ where id=3 ;
查询:select*from student;
删除数据: delete from student where student_id=1; —————> 只删除数据,表还存在。
删除表:drop table student;——————————————>表和数据都删除了。
删除视图:drop view aa_view_test;
创建视图:create or replace view
aa_view_test ——>视图名
(name , age) ——>视图里的字段
as
select name ,age from student;
EXIST OR NOT EXIST:是否存在
select name ,age from student_a as A
where exist (select *from student_b. as B);
case用法:
case type
when ‘a’ then ‘一级’
when ‘b’ then ‘二级’
when ‘c’ then ‘三级’
else ‘其他’ end as 类型
对集合的操作:
Union all 全部数据加起来「包含重复」
select *from student1
union all
select *from student2;
Intersect-----选取公共部分
select *from student1
Intersect
select *from student2;
except 记录减法
select *from student1
except
select *from student2;
postgresql事务的更多相关文章
- PostgreSQL事务实现
事务简介 事务管理器:有限状态机 日志管理器 CLOG:事务的执行结果 XLOG:undo/redo日志 锁管理器:实现并发控制,读阶段采用MVCC,写阶段采用锁控制实现不同的隔离级别 Postgre ...
- Odoo 后端数据库postgreSQL事务级别
Table of Contents 事务的特性 并行事务的问题 事务隔离级别 Odoo事务隔离级别 odoo事务控制 事务的特性 事务4个特性,简写未ACID 原子性(Atomicit ...
- PostgreSQL 事务管理的MVCC
PostgreSQL的并发控制机制同时实现了多版本控制MVCC协议和两阶段封锁协议.实际采用哪种协议取决于所执行的语句类型. DML语句的并发控制将使用MVCC协议: DDL语句的并发控制基于标准的两 ...
- postgresql - 事务
1.事务的使用 begin;//开启关闭自动提交的事务 insert into testtab01 values(0); rollback;//事务回滚 2.SavePoint的使用 begin;// ...
- PostgreSQL事务特性之嵌套事务
嵌套事务的实现是基于SAVEPOINT.ROLLBACK TO SAVEPOINT和RELEASE SAVEPOINT的,也就是设置一个保存点,可以回滚到保存点和释放保存点. 测试表的初始状态如下: ...
- PostgreSQL Replication之第二章 理解PostgreSQL的事务日志(5)
2.5 XLOG的内部结构 我们将使用事务贯穿本书,并让您在技术层面上更深地洞察事情是如果工作的,我们已经增加了这部分专门处理XLOG的内部工作机制.我们会尽量避免前往下降到C级,因为这将超出本书的范 ...
- PostgreSQL Replication之第二章 理解PostgreSQL的事务日志(3)
2.3 理解一致性和数据丢失 挖掘PostgreSQL事务日志而不考虑一致性是不可能的.在本章的第一部分,我们已经大体上解释了事务日志的基本思想.您已经知道,无需事先的日志改变的能力,使数据处于一种好 ...
- PostgreSQL Replication之第二章 理解PostgreSQL的事务日志(2)
2.2 XLOG和复制 在本章中,您已经了解到PostgreSQL的事务日志已经对数据库做了所有的更改.事务日志本身被打包为易用的16MB段. 使用这种更改集来复制数据的想法是不牵强的.事实上,这是在 ...
- PostgreSQL的9.4已经发布(译)
http://www.postgresql.org/about/news/1557/ 2014年12月18日,PostgreSQL全球开发小组发布PostgreSQL9.4,PostgresQL是世界 ...
随机推荐
- MarkDown语法总结
MarkDown常用语法讲解,写博客使用. 一丶标题的设置. 标题设置使用#来区分一级标题,几个#代表几级标题. 图片如下. 二丶添加代码块,以及标记代码. 1.添加代码块使用语法三个 '设置 2.添 ...
- [整理+原创]ubuntu Thunderbird Mail设置自动提醒
开机启动的设置方法 // 在终端输入 gnome-session-properties 然后添加thunderbird为启动项 方法1——自动提醒 下载插件:Thunderbird Mail客户端菜单 ...
- JS引擎线程的执行过程的三个阶段(一)
浏览器首先按顺序加载由<script>标签分割的js代码块,加载js代码块完毕后,立刻进入以下三个阶段,然后再按顺序查找下一个代码块,再继续执行以下三个阶段,无论是外部脚本文件(不异步加载 ...
- 记一次vue长列表的内存性能分析和优化
好久没写东西,博客又长草了,这段时间身心放松了好久,都没什么主题可以写了 上周接到一个需求,优化vue的一个长列表页面,忙活了很久也到尾声了,内存使用和卡顿都做了一点点优化,还算有点收获 写的有点啰嗦 ...
- Oracle 11g设置IP访问限制
出于数据安全考虑,对Oracle数据库的IP做一些限制,只有固定的IP才能访问. 修改$ORACLE_HOME/network/ADMIN/sqlnet.ora文件 增加以下内容(红色表示注释): # ...
- PhpStudy升级MySQL5.7
PhpStudy2017集成环境中的mysql数据库的版本默认是mysql5.5,下面是PhpStudy升级数据库到mysql5.7的方法: 1:备份当前数据库数据,可以导出数据库文件,作为备份,我这 ...
- centos-linux入门笔记
一.linux的用户 linux的用户和windwos差不多,分为管理员用户和普通用户. 普通用户:权限没那么高而已. 管理员用户:在linux中就是root用户,所拥有的权限是最高的. 二.linu ...
- PHP 脚本不报错
场景 当运行PHP脚本,访问数组中不存在的key时,脚本不报错,如下: <?php $arr = [1,2,3]; // 不报错,返回null var_dump($arr['abc']); 解决 ...
- Html和Css学习笔记-css进阶-盒模型
我的邮箱地址:zytrenren@163.com欢迎大家交流学习纠错! 此篇博客是我的复习笔记,html和css学的时间太久了,忘得差不多了,最近要使用一下,所以重新打开html的书略读,后记录了标签 ...
- wepy框架自定义组件编译报错not Found File XXX.wxss
今天在自己写wepy框架组件的时候编译后报错not Found File XXX.wxss 我去,当时我很难受啊,调用组件时结构和逻辑都正常,一写样式就原地爆炸 解决之路:1.先打开编译后的dist文 ...