易截截图软件、单文件、免安装、纯绿色、仅160KB

MS SQL Server 、Sybase、 Oracle支持锁定方案的不同

还是几位读我的书 (《Oracle大型数据库系统在AIX UNIX上的实战详解》) 的读者来邮件咨询问题,很抱歉我不能逐位回复邮件,第一我真的挺忙,第二这些问题颇有共性。我来借助这个地方,统一地和诸位探讨,很多问题我也是在摸索中,不能直接给大家答案,呵呵,大家见谅啊!

说说锁问题。 MS SQL支持的锁类型和Oracle差异是很大的!
Oracle支持的锁定方案为行锁,一种称为“精细的”锁模型。在该模型下,一个数据库用户的读操作不会妨碍其他并发用户针对该数据的更新类型操作,正在更新的数据行也可以被其他并发用户读取,如果发生了并行的、在同样数据上的更新行为,则Oracle的锁机制会即刻生效,以防止数据的脏读和数据覆盖。
Oracle的行锁方案为整体数据库提供了较高的并发性能,同时也维护了数据库数据的原子性和一致性,在如图所示的两个用户并发进程——它们同时完成了各自的操作,却没有互相产生干扰。

图 Oracle的行锁方案及其效果
在MS SQL Server / Sybase ASE系统中,锁定方案是可以指定的,每个表都可以拥有自己的锁模式,可以有如下的锁定方案:
所有页:索引页和数据页都被锁定
数据页:锁定数据页
数据行:仅锁定数据行
在MS SQL Server中,还可以启用基于行版本控制的隔离级别,应用可以指定事务使用行版本查看事务或查询开始时存在的数据,而不使用锁保护所有读取。通过使用行版本控制,读取操作会很少阻止其他事务的进行。
在Sybase中, 默认的锁定方案是所有页——数据更新中同时锁定数据对应的数据页和索引对应的索引页,也可以采用DOL表——在数据更新中仅锁定数据页,或者Row Locking锁定方案,仅锁定数据行即可。Sybase允许更改表的锁定方案,如图16-14所示,可以修改锁定方案为所有页、数据页或数据行。

所以,MS SQL Server、Sybase、Oracle真的是各有不同,各有千秋,程序要是移植,需要做的工作许多…
文平


相关文档:

sql 2005 存储过程分页 java 代码

 create PROCEDURE pagelist
@tablename nvarchar(50),
@fieldname nvarchar(50)='*',         
@pagesize int output,--每页显示记录条数
@currentpage int output,--第几页
@orderid nvarchar(50),--主键排序
@sort int,--排序方式,1表示升序,0表示降序排列 ......

航空公司管理系统(VC++ 与SQL 2005)

系统环境:Windows 7
软件环境:Visual C++ 2008 SP1 +SQL Server 2005
本次目的:编写一个航空管理系统
      这是数据库课程设计的成果,虽然成绩不佳,但是作为我用VC++ 以来编写的最大程序还是传到网上,以供参考。用VC++ 做数据库设计并不容易,但也不是不可能。以下是我的程序界面,后面 ......

Oracle EBS 如何月结之应付(AP)对账详解

应付模块的多数业务基于采购和库存的操作,因此应付模块的月结应该在采购模块和库存模块月结后才能关闭会计期。
月结步骤
在每个会计期末,应付模块的月结应遵循以下流程:
1.检查业务是否全部录入;
2.检查是否有未验证、暂挂发票;
3.更新到期的远期付款状态;
4.检查应付业务是否生成分录;
5.应付业务传送到总帐;
6 ......

oracle SQL命令大全

delete 删除一张大表时空间不释放,非常慢是因为占用大量的系统资源,支持回退操作,空间还被这张表占用着。
truncate table 表名 (删除表中记录时释放表空间)
DML 语句:
表级共享锁: 对于操作一张表中的不同记录时,互不影响
行级排它锁:对于一行记录,oracle 会只允许只有一个用户对它在同一时间进行修改操作 ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号