第06章 事务及视图

本章内容

 事务

 视图

1 事务

1.1 什么是事务

事务也称工作单元,是一个或多个SQL语句组成的序列,这些个SQL操作作为一个完整的工作单元要么全部执行,要么全不执行。

例如:
Bank 转账
A------B 2000
1) A -2000
-------------
2) B +2000

1.2 事务的特性

1、原子性:不可再分的。

2、一致性:不管是谁操作了数据库,那么在数据库中的数据状态是一致的。大家看到的结果是一致的。

3、隔离性:A操作的时候,不影响B,A在提交(commit)之前,可以查看到修改后的结果,但是B看不到。(commit之后,A的操作才真正执行到数据库,在commit之前可以通过rollback撤消操作)

4、持久性:一旦提交,对数据的修改是永久的。

1.3 事务常用的关键字

1.3.1 提交事务(commit)

作用:对表执行DML语句后,实际上数据并没有在磁盘数据文件发生变化,而是改变内存中的显示,这时的数据,我们称之为赃数据,当我们执行了commit之后,此时数据才真正的写入了数据文件,其它会话才能看到变化的数据。

1.3.2 自动提交事务

  1. 当执行DDL语句,如create,alter,drop table..
  2. 当执行DCL语句, grant , revoke,commit、rollback...
  3. 当退出(执行exit) sqlplus

    1.3.3 回滚事务(rollback)

    作用:可以对之前的dml语句误操作进行反悔。

    1.3.4 只读事务的操作(read only)

    set transaction read only;

注:只读事务它只能是在事务操作前的第一句话,它跟其它会话提交事务无关.但是事务的提交则可以同步到其它会话改变的数据,什么时候使用只读事务?一般在某个时间点统计数据的时候进行使用.

实验1:冻结视图

1.3.5 保存点的操作(savepoint)

-设置保存点:savepoint 保存点名称

-回退到保存点:rollback to 保存点名称

-回退所有的事务操作:rollback;

通过保存点的操作,可以有效的保证损失降到最低.我们可以通过保存点的设置来进行数据的回退.

  实验2:保存点操作示例

提交后的数据状态
  1. 数据的改变已经保存到了数据库中。
  2. 所有的用户可以看到结果。
  3. 所有的保存点被释放。
  4. 锁被释放,其他用户可以操作涉及到的数据。

2 视图

2.1 概述

视图是一个虚拟表,其内容由查询定义,同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。(视图不是真实存在磁盘上的)

2.2 视图与表的区别

 表需要占用磁盘空间,视图不需要

 视图不能添加索引(所以查询速度略微慢点)

 使用视图可以简化复杂查询

 视图的使用利于提高安全性

 视图能对查询出来的记录进行修改,并将修改后的数据回送到源表中

2.3 创建视图

--语法结构:

CREATE[OR REPLACE][FORCE][NOFORCE]VIEW view_name

[(column_name)[,….n]]

AS Select_statement

[WITH CHECK OPTION[CONSTRAINT constraint_name]]

[WITH READ ONLY]

--参数说明

CREATE OR REPALCE:--用于创建和修改视图

WITH CHECK OPTION :--用于创建限制数据访问的视图

WITH READ ONLY :--用于创建只读视图

--简化:

create view 视图名 as select 语句;

2.4 创建或修改视图

create or replace view 视图名 as select 语句 [with read only]

2.5 删除视图

drop view 视图名

备注:当表查询非常复杂时,请使用视图吧!

--示例:显示与SMITH 同部门的所有员工?映射到该视图(view)
SELECT * FROM emp WHERE
deptno = (select deptno from emp WHERE ename ='SMITH');

2.6 with_check_option演示

2.7 相关数据字典

--查看当前用户下的视图

SELECT * FROM USER_VIEWS;

--查看数据库下所有视图

SELECT * FROM DBA_VIEWS;

2018.6.24 oracle数据库的 事务及视图的更多相关文章

  1. Oracle数据库之事务

    Oracle数据库之事务 1. 什么是事务 在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么都成功执行,完成整个 ...

  2. 小菜鸟之Oracle数据库之事务

    Oracle数据库之事务 1. 什么是事务 在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么都成功执行,完成整个 ...

  3. 2018.6.4 Oracle数据库预定义的异常列表

    declare v_ename emp.ename%type; begin select ename into v_ename from emp where empno=&gno; dbms_ ...

  4. 优化MySchool数据库(事务、视图、索引)

    事务.视图.索引: 事务:当生活逻辑中的“一个步骤”,需要使用多条SQL去完成时,必须使用事务来确保其“完整性“. 视图:简化数据库结构,方便你编写SQL语句(简化SQL语句的编写) 索引:提高“数据 ...

  5. Oracle数据库只读事务和无事务的区别

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt382 Oracle默认情况下(没有事务) 保证了SQL语句级别的读一致性,即 ...

  6. 2018.6.10 Oracle数据库常见的错误汇总

    1.ClassNoFoundException 找不到注册驱动 可能原因:1>驱动名称不对 2>没有导入数据库驱动包 2.SQl 语句中可以使用任何有效的函数,函数操作的列,必须指定别名, ...

  7. 2018.5.9 Oracle数据库查询命令

    0.查询所有数据(最简单,但是时间很久) select * from emp; Result: EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ----- - ...

  8. 2018.6.1 oracle数据库乱码问题

    执行select * from v$controlfile;为什么结果是未选定行? 显示连接了但是select * from dba_data_files; 显示中文乱码: shutdown star ...

  9. 2018.5.30 Oracle数据库PLSQL编程---游标的使用

    显示游标的步骤 /* 显示游标处理步骤 1.声明游标 语法结构:cursor 游标名称 is SQL 语句; 2.打开游标 语法结构:open游标名称; 3.提取数据 语法结构:fetch 4.关闭游 ...

随机推荐

  1. AT2348 HonestOrUnkind

    传送门 显然\(a>b\)的情况下才有解 考虑先找出一个诚实的人,然后剩下的都可以在\(n\)次以内问出来了 发现如果一个人说另一个人是说谎的那么这两个人必有一个是说谎的,由于诚实的人严格多于不 ...

  2. UDP可靠传输简易设计

    UDP,鉴于其丢包和乱序(后发先至)问题,为保证其可靠性设计如下报头协议,供大家参考 数据包设计 数据包总大小按照MTU设计设置,小于1500字节 数据包示意图 包头类型说明 1.类型(1字节) 数值 ...

  3. Vue里的nextTick方法

    官方解释: 在下次 DOM 更新循环结束之后执行延迟回调.在修改数据之后立即使用这个方法,获取更新后的 DOM. 自己总结: `Vue.nextTick(callback)`,当数据发生变化,更新后执 ...

  4. Polycarp's Pockets(思维)

    Polycarp has nn coins, the value of the ii-th coin is aiai. Polycarp wants to distribute all the coi ...

  5. Jmeter4.0---- HTTP请求默认值(15)

    1.说明 在线程组中,添加”HTTP请求默认值”,并填写 协议,服务器名称/IP ,端口号,编码等 ,之后该线程组中的所有请求,可以不用填写这几项,启动后会直接调用”HTTP请求默认值”中的数据,方便 ...

  6. Eventlet Greenlet

    Eventlet是一个用来处理和网络相关的python网络库,而且可以通过协程来实现并发,在eventlet里,把“协程”叫做greenthread. 所谓并发,就是开启了多个greenthread, ...

  7. ElasticSearch 全文检索— ElasticSearch概述

    ElasticSearch 产生背景 1.海量数据组合条件查询 2.毫秒级或者秒级返回数据 Lucene 定义 lucene是一个开放源代码的全文检索引擎工具包,但它不是一个完整的全文检索引擎,而是一 ...

  8. ThreadPoolExecutor线程池的keepAliveTime

    keepAliveTime含义 看了很多文章觉得都不能把keepAliveTime的意思说的很明白,希望通过自己的理解把keepAliveTime说的明确一些 先引用一句我觉得相对说的比较明白的含义: ...

  9. 如何去除Discuz标题栏中的Powered by Discuz!

    今天修改discuz代码遇到一个问题,就是标题栏中的Powered by Discuz!,很不美观.查资料后得到了解决方法!介绍给大家. 那么如何去掉标题里面的Powered by Discuz!呢? ...

  10. Java中的==和equals区别

    概述: A.==可用于基本类型和引用类型:当用于基本类型时候,是比较值是否相同:当用于引用类型的时候,是比较对象是否相同. B.对于String a = “a”; Integer b = 1;这种类型 ...