爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
数据库教程
SQLServer和Oracle防止数据锁定的比较
SQLServer和Oracle防止数据锁定的比较
日期:2014-03-24 浏览次数:20428 次
SQL Server和Oracle防止数据锁定的比较
廖铮
www.chinai tp 采集 ow er.comKegMw
2002-5-30 14:23:50
数据库并行访问,也就是两个或两以上用户同时访问同一数据,这也是数据库引擎如何设计和实现适度反应所面临的最大问题。设计优良、性能卓越的数据库引擎可以轻松地同时为成千上万的用户服务。而“底气不足”的数据库系统随着更多的用户同时访问系统将大大降低其性能。最糟糕的情况下甚至可能导致系统的崩溃。
当然,并行访问是任何数据库解决方案都最为重视的问题了,为了解决并行访问方面的问题各类数据库系统提出了各种各样的方案。 SQL Server和Oracle两大DBMS也分别采用了不同的并行处理方法。它们之间的实质差别在哪里呢?
并行访问的问题
并行访问出现问题存在若干种情况。在最简单的情形下,数量超过一个的用户可能同时查询同一数据。就这种情况而言数据库的操作目标很简单:尽可能地为用户们提供快速的数据访问。 这对我们现在常见的数据库来说不成问题:SQL Server和 Oracle 都采用了多线程机制,它们当然能够一次处理多个请求。
不过,在用户修改数据的情况下并行访问问题就变得复杂起来了。显然,数据库通常只允许唯一用户一次修改特定的数据。当某一用户开始修改某块数据时, SQL Server和 Oracle 都能很快地锁定数据,阻止其他用户对这块数据进行更新,直到修改该数据的第1位用户完成其操作并提交交易(commit transaction)。但是,当某一位用户正在修改某块数据时假设另一位用户又正想查询该数据的信息时会发生什么情况呢?在这种情况下数据库管理系统又该如何动作呢?Oracle 和 SQL Server针对这一问题采取了不同的解决方案。
SQL Server方法
现在不妨假设有人开始修改SQL Server上存储的数据,于是这块数据立即被数据库锁定。数据锁定操作阻塞其他任何访问该数据的连接——连查询操作都不会放过。于是,这块被锁定的数据只有在交易被提交或者回滚之后才能接受其他访问操作。
下面用SQL Server随带的pubs示例数据库做一个简单示范。在Query Analyzer内打开两个窗口。在第1个窗口中执行下列SQL操作语句,更新pubs数据库中某一图书的价格:
use pubs
go
begin tran
update titles
set price = price * 1.05
where
title_id = 'BU2075'
由于代码中并没有执行commit语句,所以数据变动操作实际
上一篇: CCNP_route札记6 关于OSPF中的hello和DBD顺序
下一篇:SQLServer2000中清空LOG文件一法
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
mongodb redis memcached的对照
运用MS SQL7的LINKED SERVER第一篇
"Invalid username/password or database/scan listener not up"
DBA常用命令汇总
施用DBCC CHECKPRIMARYFILE 查询Detach数据库信息
JDBC惯用连接写法(包括MySQL、Oracle、Sybase、SQLServer、DB2)
oracle查看锁表对象跟杀锁
初识oracle-创造数据库
使用goldengate的数据泵开展Oracle-Oracle的单向复制
推荐阅读
更多>
scott/tiger登录时提醒ora-28000 the account is locked
Oracle中的Date、TimeStamp和Interval(下)
php操作access数据库类代码
不懂就贴,学识积累。excel导入服务器以及导入到数据库
1淘数据部-月光宝盒双11 HBase集群应用和优化经验
MS SQL SERVER 的一些有用日期
合龙多列为一行
oracle rank() over 求最后一条记要
单范例支撑每天上亿个请求的SSDB
Hive源码分析(三) hadoop.hive.metastore.model.MDatabase is not persistable错误解决
select count(一) 和 select count(*)
小弟我的android 第14天 - 使用SQLiteDatabase操作SQLite数据库
hive汉语
Matlab 人脸辨别之PCA算法,使用Yale人脸数据库
Oracle 函数大全(字符串函数,数学函数,日期函数,逻辑运算函数,其余函数)[转]
oracle死锁查询及处置
高并发高载荷数据库架构策略
oracle用户查询受权
关于SQL Server中几个未公布的访问注册表的扩展存储过程_Sql2000存储过程_MSSQL教程
ADO物件的方法與屬性_Sql2000函数组件_MSSQL教程