首页  登陆  注册  博客集  下载频道  网络硬盘  学院论坛  家园
IT学院 网站地图 网站地图
收藏本站 收藏本站
高级搜索 高级搜索
 新闻IT新闻 互联网 微软 黑客新闻 网络网络协议 故障 网络管理 TCP/IP 无线技术 解决方案 黑客技术 漏洞 软件评测 安全资讯
 数据MSsql Oracle Mysql PL/SQL 备份 系统:Linux vista Windows FTP 防火墙 注册表 服务器行情 服务器应用 解决方案 WEB服务器
 墙纸风景壁纸 游戏壁纸 体育壁纸 汽车壁纸 人文壁纸 影视壁纸 广告壁纸 花卉壁纸 节日壁纸 动漫壁纸 明星壁纸 绘画壁纸 月历壁纸
当前位置: > 主页>数据库技术>MSsql >SQL7中LOCK的理解(1)
热门文章排行
 
热门文章排行 巧用触发器对"SQL Serve
SQL Server 2000问答
  问:SQL Server 200
ADO数据访问一点通
SQL Server成为低成本建
SQL Server数据库六种数
SQL Server性能分析参
将ACCESS的转化为SQL SE
拷贝的SQL Server 7数据
优化SQL Server服务器内
精采文章推荐
 
精采文章推荐 SQL Server存储过程入门
SQL的基本操作(1.数据类
SQLMail的原理及实际应
维护SQL Server数据库
简单查询和联合查询两方
怎样用SQL 2000 生成XML
SQL Server 2000的安全
SQL配合3389的一次入侵
SQL SERVER 2000 SP2 12
SQL SERVER 2000通讯管
最新更新文章
 
最新更新文章 SQL Server存储过程入门
用ASP调用SQL的视图和存
SQL的基本操作(4.数据的
SQL的基本操作(3.表的相
SQL的基本操作(2.数据库
SQL的基本操作(1.数据类
SQLMail的原理及实际应
维护SQL Server数据库
配置SQL Server 2000选
Jboss下MS SQL Server配

SQL7中LOCK的理解(1)

编辑:   来源:  日期:2008-02-14   我要投稿      家园

  下面我将SQL7中的lock做个简单的介绍,
  
  小型数据库以及大多数的MIS系统,对lock没什么要求,原因是数据量小,并发少,客户端的响应要求不高。
  
  由此可见,上面三个因素正是我们实现lock策略的目的。
  
  在SQL7中,QueryAnalyzer是一个非常好的工具,用它可以清楚的分析不同的语句在不同的环境下产生的锁,并发性操作等等。
  
  简单的说,就是利用sp_Lock和隐式交易来做到这一点。
  
  首先需要强调的是lock完全依赖你的需要。并不是说lock越多越好。或是lock越少越好。我们应该制定合适的lock策略来满足我们的需要。那就是在并发性和数据完整性的平衡点。
  用过word的都知道,user1打开了一个word文挡,user2打开同一个文挡时,word会有提示告之user2只能在只读方式下工作。在这里,为了保护文挡的数据完整性(user1加了lock),并发操作受到了限制(user2 readonly)。SQL7也有同样的情况。
  
  其次,我们要认识到lock是由SQL7来产生的,也是由SQL7来管理的,lock产生的数量和种类依赖我们的sql语句和环境。我们通常是通过控制环境变量来间接控制lock的产生,(虽然SQL7支持在sql语句中直接加锁,但这种用法少)。
  
  再有的就是lock的生命期。当语句执行时产生锁,当语句结束时lock被释放,在事务中lock要到事务结束才释放。从这个特点中我们就可以找到观察lock的方法。那就是不让交易结束。SQL7的隐式交易就具有这种能力,需要说明的是,SQL7的隐式交易经常被用于改写production数据库中的数据。当改写正确时才提交,避免出错。SQL7的隐式交易有很强的实践意义。
  
  下面介绍的是SQL7 lock的种类
  SQL7中锁的种类很多,有DB级,表级,PAGE级,行级(key),行级是7中的新功能,这也是大型数据库的一个标志。但即使这样,SQL7的锁也不如DB2和ORACLE。我们最关心的是表级和行级,这里介绍锁主要目的是为了了解在SP_LOCK中出现的信息的含义。
  
  先介绍表级,主要两种,S,X。 S和S兼容,X和任何都不兼容。例:statement1 在表A上施加了S,此时如果statement2在表A上也将施加S,那么statement2就可以被执行(并发),如果statement2在表A上将施加X,那么statement2将等待,直到statement1执行完后(S被释放)才被执行(没了并发)。
  
  如果statement1 在表A上施加了X,此时如果statement2在表A上也将施加S或X,那么statement2将等待,直到statement1执行完后(X被释放)才被执行(没了并发)。
  
  接着介绍行级,从表级锁就可以看出,表级锁对并发的支持有限,因此大型数据库才利用行级锁来支持更多的并发。行级锁也主要有两种,S,X。 S和S兼容,X和任何都不兼容。当SQL7实现行级锁的时候,它自动在表上施加表级锁IS,IX。
  也就是只有在表上先施加IS,才能在行上施加S,只有在表上先施加IX,才能在行上施加X。一一对应。例:statement1 在表A上的行A施加了S,自然在表A上施加了IS,此时如果statement2在表A的任一行上将施加S(自然在表A上施加了IS),那么statement2就可以被执行(并发),如果statement2在表A上除行A上将施加X(自然在表A上施加了IX),那么statement2也可以被执行(并发),如果statement2在表A上行A上将施加X(自然在表A上施加了IX),那么statement2将等待,直到statement1执行完后(S被释放)才被执行(没了并发)。
  
  在表级锁中还有一种是SIX,也就是首先在表级加S,同时需要在行级加X。
  
  从上面的介绍就可以得到各表级锁,S X IS IX SIX的兼容关系。我们也可以从后面的实验来验证这一点。
  
  实验:实验中要建立到DB的两个连接。其中一个连接运行在隐含交易下。
  目标一,在运行在隐含交易下的连接里,运行DML,再运行sp_lock,理解DML语句所产生的锁的不同。
  目标二,在运行在隐含交易下的连接里,设置不同的事物隔离级别,再运行DML,理解在不同隔离级别下的同一语句所产生不同的锁。
  目标三,同时在另一连接中运行不同的DML,通过执行情况,来验证锁的兼容性。


上一篇:优化SQL Server服务器内存配置的策略  
下一篇:SQL7中LOCK的理解(2)
 关键字:  
文章评论】 【收藏本文】 【推荐好友】 【打印本文】 【论坛讨论

   相关文章:

   文章评论:(0条)
  
 请留名: 匿名评论   点击查看所有评论
 

  责任编辑:IT学院  声明:刊登此文章是为了传递更多信息,文章内容仅供参考,转载请注明出处。