SYBASE的事务

本篇文章描述了数据库事务隔离级对锁的影响,通过对比事务隔离级0和1,理解锁与脏读的关系。

实验内容:分别设置0和1级隔离级,执行两个不同但又有相关的事务。本实验环境如下:

1、有权访问用户数据库(在此是aca_database)和对数据库表有修改和查询权限。

2、数据库中有表auths,包含salary列(数据类型是money),有一定数据量(在此有1万行)。

步骤:

1、如在同一台机器,可分别执行两次“SQL Advantage”,分别用合法帐号登录,准备各自执行一个事务。

2、在各自界面打开用户数据库aca_database,设置隔离级为1(此亦为缺省值):

set transaction isolation level 1,查看当前隔离级别用select @@isolation

3、执行第一个事务的前两句,暂不执行后面的提交或回滚。

begin transaction

update auths set salary=salary+100

commit transaction

(rollback transaction)

4、执行第二个事务 select sum(salary) from auths

5、第一个事务正常执行结束,但只在内存缓冲区完成修改,事务并没有真正结束,相应也不释放锁,第二个事务处于等待状态。可执行sp_lock和sp_who命令查看。

6、执行第3步中的提交或回滚命令,第二个事务得到执行。

7、改变事务隔离级为0,重复执行3-4步。第一个事务没有任何变化,第二个事务很快出来根据第一个事务修改数据而成的结果,似乎在执行响应上并不受第一个事务的影响。

8、重复第6步结束。

通过上面的实验我们知道:

1、隔离级0时事务允许脏读,隔离级1时事务不允许脏读,而只是等待前一个修改事务真正结束并释放锁。

2、隔离级为0时,如果在修改事务的最后是回滚操作,则查询读事务将不能读到正确的数据。

3、在确信事务中没有回滚操作的可能,并要求更高的执行效率和并行性,只有这时可考虑设置隔离级为0。

时间: 2024-10-02 01:58:00

SYBASE的事务的相关文章

Sybase-Oracle异构数据库互联与数据库复制

SYBASE复制服务器(Sybase Replication Server)除用来与Sybase系统连接复制数据外,还用来进行异构数据库的复制,包括Oracle.MS SQLServer.DB2.iAnyWhere等系统,并且成为企业范围内客户/服务器应用模式的基础. Sybase-Sybase复制服务器的工作方式 SYBASE复制服务器产品操作的示意图如下: Sybase-Sybase复制服务器的工作方式 SYBASE到异构服务器(Oracle)产品操作的示意图如下: 一般情况下,复制节点数据

sybase 性能诊断sp_sysmon事务管理

本篇文章描述了通过sp_sysmon对Adaptive Server系统运行情况有一个全面系统了解,有利于更好地熟悉系统性能,更为有效地进行系统管理,合理地利用和配置系统资源,达到系统性能调优的目的. 从18个方面了解在用系统性能状况,并在适当的时候利用环境参数进行性能调优: 1.内核管理(kernal)     2.应用管理(appmgmt)     3.数据缓存管理(dcache) 4.ESP管理(esp)          5.索引管理(indexmgmt)     6.锁管理(locks

Sybase在两台分离的服务器间通过复制实现数据库的双机热备

Sybase复制服务器应用方案之一 复制服务器支持一对一的复制模式,复制服务器的Warm standby 对于Adaptive Server或SQL Server保持一个双份数据库,其中一个作为另一个活动数据库的暖备份.当用户修改活动的数据库时,复制服务器复制相应事务到备份数据库,使得二者保持一致.一但活动数据库因为各种原因失败,可以切换到备份数据库,使其成为活动数据库,除了一点点间断以外,几乎不影响对数据库的操作. 示意图如下: 该方案需要配置系统软件:ASE.Rep .SQL Remote.

Sybase数据复制与热切换的实现

SYBASE复制服务器(Sybase Replication Server)用来满足日益发展的企业客户/服务器计算机环境的需要.自从复制服务器被广泛应用以来,已成为企业范围内客户/服务器应用模式的基础. 复制服务器的工作方式 SYBASE复制服务器产品操作的示意图如下: StandBy 模式下的数据复制 一般情况下,复制节点数据跟随主节点而变化.如果主节点发生错误后可否切换到复制节点呢?SYBASE复制服务器可否作成类似双机热备模式呢? 在SYBASE复制服务器环境中,我们可以按照如下方式安装各

Sybase SQL Server日志问题普及

Sybase SQL Server 的每一个数据库,无论是系统数据库(master,model, sybsystemprocs, tempdb),还是用户数据库,都有自己的transaction log,每个库都有 syslogs表.Log记录用户对数据库修改的操作,所以如果不用命令清除, log会一直增长直至 占满空间.清除log可用dump transaction 命令:或者开放数据库选项trunc log on chkpt, 数据库会每隔一段间隔自动清除log.管理好数据库log是用户操作

Sybase SQL Server体系结构介绍

Sybase SQL Server是一个多库结构的RDBMS,体系结构大致如下: 1.数据库 服务器自身所使用的数据库,也可以说是管理服务器和用户数据库的数据库.Sybase在安装时,自动创建了四个系统数据库: master.model.tempdb.sybsystemprocs 1) master数据库 它是管理和控制用户数据库以及维护服务器正常运行的核心数据库,它保存了大量的系统信息,如服务器配置.用户.设备等. 在master数据库中不允许普通用户在其中创建数据库对象,否则会使得maste

超级PK:Sybase与Oracle的十二场性能比拼

Sybase公司成立于1986年,立足于在开放系统平台上研制具有Client/Server体系结构的数据库系统软件产品.当时的Sybase公司由于有效地汲取了其它RDBMS设计过程中的先进技术和概念,以满足联机事务处理(OLTP)应用的高性能要求为目标,同时加强联网对异构数据源的开放互联,使Sybase取得了很大成功,特别是Sybase有效的拓展市场行动,使Sybase曾一度成为世界数据库市场增长最快的产品.然而,由于产品本身的技术问题,不能提供对大型多处理器系统的支持,使得Sybase的市场份

用Sybase复制服务器实现Sybase双机备份

随着数据库管理系统的不断普及和深入应用,企业要求数据库的重要数据不会因为各种意外情况的发生而导致数据丢失或者数据不可用.相应地,数据库数据的备份与恢复机制愈加显示其重要性.不难想象,金融.税务.建筑工程各行各业如果没有数据库的备份,一旦出现数据库损坏.数据不可使用的情况,对企业正常的业务工作带来如何灾难的后果! 当然,现在对数据的备份手段很多,例如对包含数据的硬件设备备份,或者对硬件设备做镜像,还有Sybase系统中单独对数据库的备份,等等.但可用于建立经济.可靠.高性能.避免自然灾害的数据库备

Sybase数据库中存储过程的建立和使用

Sybase的存储过程是集中存储在SQL Server中的预先定义且已经编译好的事务.存储过程由SQL语句和流程控制语句组成.它的功能包括:接受参数;调用另一过程;返回一个状态值给调用过程或批处理,指示调用成功或失败;返回若干个参数值给调用过程或批处理,为调用者提供动态结果;在远程SQL Server中运行等. 存储过程的性能特点如下: ·存储过程是预编译过的,这就意味着它与普通的SQL语句或批处理的SQL语句不同,当首次运行一个存储过程时,SQL Server的查询处理器对其进行分析,在排除了