《Oracle数据库管理与维护实战》——2.8 数据库访问-阿里云开发者社区

开发者社区> 异步社区> 正文

《Oracle数据库管理与维护实战》——2.8 数据库访问

简介:
+关注继续查看

本节书摘来自异步社区出版社《Oracle数据库管理与维护实战》一书中的第2章,第2.8节,作者: 何伟娜 , 常建功,更多章节内容可以访问云栖社区“异步社区”公众号查看。

2.8 数据库访问

Oracle数据库管理与维护实战
Oracle是大型的多用户并发数据库系统,本节介绍使用Oracle实现多用户并发的基本概念和相关机制。

2.8.1 竞争性、并发性与一致性概念

竞争性、并发性与一致性是所有多计算机系统都会遇到的问题。如计算机网络中文件服务器阻止多个文件同时修改同一个文件,在Windows平台下经常提示另一个用户正在使用此文件、不能修改等。当两个用户要同时获取同一资源时,例如要同时获取打印机,就会产生竞争性。当多个用户获取同一资源,好像每个用户在独自使用该资源时,产生并发性。

Oracle是一个多用户数据库系统,在它内部必须解决资源进程并发性与一致性,使用户对数据库并发、安全的访问。Oracle的并发性与一致性机制并不会使数据库的访问复杂化或降低系统性能。例如,如果几个用户同时想更新表中的同一记录行,Oracle会使用自动锁机制,使事务串行发生,好像是独立发生一样。如事务要查询另一个事务正在更新的表时,Oracle的多版本机制自动允许查询立即执行,并让查询读取更新前的数据。

一致性内最重要的是读一致性,Oracle采取以下措施保证读一致性。

Oracle保证SQL语句在操作某些数据时,其他事务不能更改这些数据。

当一个事务读数据库数据时,这些数据也可以让其他事务读。

当一个事务在写数据时,其他事务仍可正常读这些数据。

但一个事务A在修改一行记录时,其他要更改同一行记录的事务必须要等到事务A完成更新后才能开始对这一行的更改。

2.8.2 事务之间的冲突

多用户数据库系统中,事务具有几种不同形式相互的影响,包括更新丢失、脏读、非重复读等。

1.更新丢失
系统允许多个事务同时更新同一数据时,会发生更新冲突。例如,两个用户都要更新同一表的同一行数据,一个更新就会覆盖掉另一个更新。为防止这种冲突发生,Oracle采取锁机制,防止同时发生更新操作。

2.脏读
当一个事务读取另一个打开事务还未提交的数据时,就会产生脏读。例如,用户A想修改某表中的一行记录,如果该用户还没提交修改,而另一个用户B想查询这行记录,如果返回的是A用户修改后的数据,就是脏读。

Oracle数据库会尽量避免脏读的产生,脏读容易产生问题。如果读取没有提交的数据,而该数据提交失败,那么读出的数据就是无效的,甚至是错误的。Oracle中有一些机制能保证不出现脏读。

3.可重复读与非重复读
在同一事务中,查询返回的是同一数据集,忽略其他已提交或未提交的事务所做的修改,这时发生可重复读。只有当前事务结束、又开始一个新的事务时,查询才能看到最新的结果,这就是可重复读。而如果查询在相同的事务中多次进行,每次都返回最新的数据集,这时发生非重复读。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
编程实战——电影管理器之界面UI及动画切换
在前文“编程实战——电影管理器之利用MediaInfo获取高清视频文件的相关信息”中提到电影管理器的目的是方便播放影片,在想看影片时不需要在茫茫的文件夹下找寻。   我对电影管理器的想法如下: 1、可以全键盘操作(不依赖鼠标),最好是利用键盘上的小数字键区就能完成全部操作。
824 0
【方法】如何限定IP访问Oracle数据库
【方法】如何限定IP访问Oracle数据库   1.1  BLOG文档结构图   1.2  前言部分 1.
1060 0
在 Linux x86 上安装 Oracle 数据库 10g_5
结论 现在,您的数据库已经启动并运行,您可以开始使用 Oracle 10g 中提供的许多新特性。最好从 Oracle Enterprise Manager 开始使用,这是因为它是彻底地重新编写的,采用了基于 Web 的界面。
972 0
Oracle数据库的可恢复性设置
整理自《Oracle 11g OCP/OCA 认证指南》 001     为了保证数据库的最大可恢复性,必须多路复用控制文件;必须多路复用联机重做日志;必须以归档日志模式运行数据库,并多路复用归档日志文件;最后必须作常规备份。
849 0
在 Linux x86 上安装 Oracle 数据库 10g_3
启动 Oracle 通用安装程序。 $ ./runInstaller 1.      欢迎 o        单击 Next。 2.      指定清单目录和证书 o        如果您一直在依循本指南中的步骤,则使用默认值即可。
791 0
+关注
异步社区
异步社区(www.epubit.com)是人民邮电出版社旗下IT专业图书旗舰社区,也是国内领先的IT专业图书社区,致力于优质学习内容的出版和分享,实现了纸书电子书的同步上架,于2015年8月上线运营。公众号【异步图书】,每日赠送异步新书。
11938
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载