加锁是在操作数据时进行了,不能事后加锁。

例: begin   tran  
        insert   表   with(TABLOCKX)     --加锁  
        (字段列表)   values(值列表)  
        commit   tran

其他锁的示例  
   
  --设tb(A,B,C)  
  create   table   #tb(A   varchar(2),B   varchar(2),C   varchar(2))  
  insert   into   #tb  
  select   'a1','b1','c1'  
  union   all   select   'a2','b2','c2'  
  union   all   select   'a3','b3','c3'  
   
  --1)排它锁  
  --在第一个连接中执行以下语句  
  begin   tran  
        update   #tb  
        set   A='aa'  
        where   B='b2'  
        waitfor   delay   '00:00:3'     --等待3秒  
  commit   tran  
   
  --在第二个连接中执行以下语句  
  begin   tran  
        select   *   from   #tb  
        where   B='b2'        
  commit   tran  
  --若同时执行上述两个语句,则select查询必须等待update执行完毕才能执行即要等待30秒  
   
  --2)共享锁  
  --在第一个连接中执行以下语句  
  begin   tran  
        select   *   from   #tb   holdlock   --holdlock人为加锁  
        where   B='b2'    
        waitfor   delay   '00:00:3'     --等待3秒  
  commit   tran  
   
  --在第二个连接中执行以下语句  
  begin   tran  
        select   A,C   from   #tb  
        where   B='b2'    
        update   #tb  
        set   A='aa'  
        where   B='b2'        
  commit   tran  
  --若同时执行上述两个语句,则第二个连接中的select查询可以执行  
  --而update必须等待第一个连接中的共享锁结束后才能执行   即要等待30秒  
   
  --3)死锁  
  --增设tb2(D,E)  
  create   table   #tb2(D   varchar(2),E   varchar(2))  
  insert   into   #tb2  
  select   'd1','e1'  
  union   all   select   'd2','e2'  
   
  --在第一个连接中执行以下语句  
  begin   tran  
        update   #tb  
        set   A='aa'  
        where   B='b2'    
        waitfor     delay   '00:00:5'  
        update   #tb2  
        set   D='d5'  
        where   E='e1'    
  commit   tran  
         
  --在第二个连接中执行以下语句  
  begin   tran  
        update   #tb2  
        set   D='d5'  
        where   E='e1'    
        waitfor     delay   '00:00:3'  
        update   #tb  
        set   A='aa'  
        where   B='b2'      
  commit   tran  
   
  --删除临时表  
  drop   table   #tb,#tb2  
   
  --同时执行,系统会检测出死锁,并中止进程  
  /*-------------------------------------------------------------  
  SET   IMPLICIT_TRANSACTIONS     ON   --用户每次必须显式提交或回滚。否则当用户断开连接时,  
                                                              --事务及其所包含的所有数据更改将回滚  
   
  SET   IMPLICIT_TRANSACTIONS     OFF   --自动提交模式。在自动提交模式下,如果各个语句成功  
                                                                --完成则提交。  
-----------------------------------------------------------------------------------------------------------------------參考:  
   
  1.问:有什么样的办法   让几个程序   同时调用   同一个或者不同存贮过程   同时更新数据表的   同一行的不同字段时   互不干扰   各完成各的操作?  
 
A:mssqlserver2000默认的lock  
的粒度是行级,所以如果一个线程在update一条记录时,就在该行加了排他锁,所以其它的线程是无法读取该记录(除非可以脏读),这是因为在
mssqlserver中是不可以同时给一条记录加不同的锁。另外mssqlserver没有锁某一列的锁!  
   
  所以让几个程序   同时调用   同一个或者不同存贮过程   同时更新数据表的   同一行的不同字段时如果一个在更新,其他的就只能WAIT....  
   
   
     
   
  2.   如何锁一个表的某一行  
   
   
  A   连接中执行  
   
  SET   TRANSACTION   ISOLATION   LEVEL   REPEATABLE   READ  
   
  begin   tran  
   
  select   *   from   tablename   with   (rowlock)   where   id=3  
   
  waitfor   delay   '00:00:05'  
   
  commit   tran  
   
  B连接中如果执行  
   
  update   tablename   set   colname='10'   where   id=3   --则要等待5秒  
   
  update   tablename   set   colname='10'   where   id<>3   --可立即执行  
   
   
   
  3.   锁定数据库的一个表  
   
  SELECT   *   FROM   table   WITH   (HOLDLOCK)    
   
   
  注意:   锁定数据库的一个表的区别  
   
  SELECT   *   FROM   table   WITH   (HOLDLOCK)    
  其他事务可以读取表,但不能更新删除  
   
  SELECT   *   FROM   table   WITH   (TABLOCKX)    
  其他事务不能读取表,更新和删除  
   
  SELECT   语句中“加锁选项”的功能说明  
 
SQL   Server提供了强大而完备的锁机制来帮助实现数据库系统的并发性和高性能。用户既能使用SQL  
Server的缺省设置也可以在select   语句中使用“加锁选项”来实现预期的效果。  
本文介绍了SELECT语句中的各项“加锁选项”以及相应的功能说明。  
  功能说明:     
  NOLOCK(不加锁)    
  此选项被选中时,SQL   Server   在读取或修改数据时不加任何锁。   在这种情况下,用户有可能读取到未完成事务(Uncommited   Transaction)或回滚(Roll   Back)中的数据,   即所谓的“脏数据”。    
   
  HOLDLOCK(保持锁)    
  此选项被选中时,SQL   Server   会将此共享锁保持至整个事务结束,而不会在途中释放。    
   
  UPDLOCK(修改锁)    
  此选项被选中时,SQL   Server   在读取数据时使用修改锁来代替共享锁,并将此锁保持至整个事务或命令结束。使用此选项能够保证多个进程能同时读取数据但只有该进程能修改数据。    
   
  TABLOCK(表锁)    
  此选项被选中时,SQL   Server   将在整个表上置共享锁直至该命令结束。   这个选项保证其他进程只能读取而不能修改数据。    
   
  PAGLOCK(页锁)    
  此选项为默认选项,   当被选中时,SQL   Server   使用共享页锁。    
   
  TABLOCKX(排它表锁)    
  此选项被选中时,SQL   Server   将在整个表上置排它锁直至该命令或事务结束。这将防止其他进程读取或修改表中的数据。  
   
   
     
   
  4.我的程序沒有碩操作的﹐但是今天發現某行無法select,別的行都可以。  
  在管理--》目前活動--》鎖定/處理序識別碼﹐看見有被封鎖和封鎖。  
  不知道怎么開鎖。  
   
  use   master  
  go  
  create   proc   killspid   (@dbname   varchar(20))    
  as    
  begin    
  declare   @sql   nvarchar(500)    
  declare   @spid   int    
  set   @sql='declare   getspid   cursor   for    
  select   spid   from   sysprocesses   where   dbid=db_id('''+@dbname+''')'    
  exec   (@sql)    
  open   getspid    
  fetch   next   from   getspid   into   @spid    
  while   @@fetch_status   <   >-1    
  begin    
  exec('kill   '+rtrim(@spid))    
  fetch   next   from   getspid   into   @spid    
  end    
  close   getspid    
  deallocate   getspid    
  end    
   
  --用法    
  use   master    
  exec   killspid   '数据库名'  
   
   
  5.--查看锁信息  
  select   进程id=req_spid  
  ,数据库=db_name(rsc_dbid)  
  ,类型=case   rsc_type   when   1   then   'NULL   资源(未使用)'  
  when   2   then   '数据库'  
  when   3   then   '文件'  
  when   4   then   '索引'  
  when   5   then   '表'  
  when   6   then   '页'  
  when   7   then   '键'  
  when   8   then   '扩展盘区'  
  when   9   then   'RID(行   ID)'  
  when   10   then   '应用程序'  
  end  
  ,rsc_objid,rsc_indid  
  from   master..syslockinfo  
   
   
  6.今想实现一个特定的操作,大概想法是这样的:  
  在SQL   SERVER里实现对某个特定的表进行操作锁定,应用程序要对这个表的数据进行删除操作,必须经过审核(注:只想在SQL   SERVER里控制,不想用应用程序实现)。  
   
  用触发器  
  create   trigger   ...  
  for   delete  
  as  
  if   exists(select   1   from   deleted   where   未审核)  
  rollback  
   
   
 
5.我在SQL  
SERVER里二张一样的表,做了个TRIGGERE,可以将同样的数据复制的那一表,在此将源表叫做A,被TRIGGER的表叫做B,A被一套程序使
用,B被另一个程序使用,当B被程序访问时(读取),A表正好有问题要INSERT或UPDATE,此时TRIGGER起作用但写不进B表,造成访问A表
的程序不正常,请问有什么方法可以解决吗!?  
   
   
  用手工锁定就行了.类似下面的例子:  
   
  --锁定记录,只允许单用户修改的例子:  
   
  --创建测试环境  
  --创建测试表--部门表  
  create   table   部门(departmentid   int,name   varchar(10))  
   
  --记录锁定表  
  create   table   lock(departmentid   int,dt   datetime)  
   
  go  
  --因为函数中不可以用getdate,所以用个视图,得到当前时间  
  create   view   v_getdate   as   select   dt=getdate()  
  go  
  --创建自定义函数,判断记录是否锁定  
  create   function   f_chk(@departmentid   int)  
  returns   bit  
  as  
  begin  
  declare   @re   bit,@dt   datetime  
  select   @dt=dt   from   v_getdate  
  if   exists(select   1   from   lock   where   departmentid=@departmentid  
  and   datediff(ss,dt,@dt)<5)  
  set   @re=1  
  else  
  set   @re=0  
  return(@re)  
  end  
  go  
   
  --数据处理测试  
  if   dbo.f_chk(3)=1  
  print   '记录被锁定'  
  else  
  begin  
  begin   tran  
  insert   into   lock   values(3,getdate())  
  update   部门   set   name='A'   where   departmentid=3  
  delete   from   lock   where   departmentid=3  
  commit   tran  
  end  
   
  --删除测试环境  
  drop   table   部门  
  drop   view   v_getdate  
  drop   function   f_chk  
   
   
   
  即创建一个锁表,在B表被访问时,添加一个记录到锁表中,如果A表发生更新,首先判断锁表的内容,如果被锁定,则触发器失败.  
   
  a.创建锁表  
  create   table   锁表(lock   bit,dt   datetime)  
   
  b.B表被访问时:  
  insert   into   锁表   values(1,getdate())  
  访问B表...  
  访问B表结束  
  truncate   talbe   锁表  
   
  c.A表的触发器  
  create   trigger   t_process   on   A表  
  for   insert,delete,update  
  as  
  if   exists(select   1   from   锁表   where   datediff(ss,dt,getdate())<20)   --判断时间是防止死锁,即B表被锁定的最长时间为20秒,超过此时间表示B表被死锁  
  rollback   tran  
  else  
  begin  
  ..同步处理  
  end  
  go  
   
   
  6.死锁可以查一下:  
  1:sp_who   或   sp_who2  
  2:   Select   *   from   sysprocesses   where   blocked   <>   0  
  3:   企业管理器->服务器->管理工具->活动->当前活动   然后把他kill掉。。。  
  4:SQL事件探查器,监控一下,看主要是那些处理引起的死锁.然后做相应的处理.

sql给数据库加锁问题的更多相关文章

  1. [转] 数据库加锁 sql加锁的

    [导读: 各种大型数据库所采用的锁的基本理论是一致的,但在具体实现上各有差别.SQL Server更强调由系统来管理锁.在用户有SQL请求时,系统分析请求,自动在满足锁定条件和系统性能之间为数据库加上 ...

  2. 转载 50种方法优化SQL Server数据库查询

    原文地址 http://www.cnblogs.com/zhycyq/articles/2636748.html 50种方法优化SQL Server数据库查询 查询速度慢的原因很多,常见如下几种: 1 ...

  3. SQL Server数据库空间管理 (1)

    数据库经常遇到的问题: 1).数据库文件空间用尽  2).日志文件不停增长 3).数据库文件无法收缩  4).自动增长和自动收缩 本系列就以上面的4个问题入手分析并总结数据库空间的管理方法.   1. ...

  4. JAVA程序对MYSQL数据库加锁实验

    什么是脏读,不可重复读,幻读 1. 脏读 :脏读就是指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据. 2. 不可重 ...

  5. 解决死锁之路3 - 常见 SQL 语句的加锁分析 (转)

    出处:https://www.aneasystone.com/archives/2017/12/solving-dead-locks-three.html 这篇博客将对一些常见的 SQL 语句进行加锁 ...

  6. .NET跨平台之旅:升级至ASP.NET 5 RC1,Linux上访问SQL Server数据库

    今天微软正式发布了ASP.NET 5 RC1(详见Announcing ASP.NET 5 Release Candidate 1),.NET跨平台迈出了关键一步. 紧跟这次RC1的发布,我们成功地将 ...

  7. SQL Server数据库定时自动备份

    SQL Server 数据库定时自动备份[转]   在SQL Server中出于数据安全的考虑,所以需要定期的备份数据库.而备份数据库一般又是在凌晨时间基本没有数据库操作的时候进行,所以我们不可能要求 ...

  8. C#操作access和SQL server数据库代码实例

    在C#的学习中,操作数据库是比较常用的技术,而access和sql server 数据库的操作却有着不同.那么,有哪些不同呢? 首先,需要引用不同的类.因为有着不同的数据引擎. access:usin ...

  9. python 使用pymssql连接sql server数据库

    python 使用pymssql连接sql server数据库   #coding=utf-8 #!/usr/bin/env python#------------------------------ ...

随机推荐

  1. switch_to 理解

    最近看linux0.11源码时,看到任务切换函数switch_to,感觉很晦涩,于是在网上查了一些资料,现在终于有些眉目,特记录于此,以方便大家参考,有什么错误或不足之处,还请大家指出~ switch ...

  2. POJ 2255 Tree Recovery(根据前序遍历和中序遍历,输出后序遍历)

    题意:给出一颗二叉树的前序遍历和中序遍历的序列,让你输出后序遍历的序列. 思路:见代码,采用递归. #include <iostream> #include <stdio.h> ...

  3. Ubuntu 启动栏添加eclipse图标

    sudo gedit /usr/share/applications/eclipse.desktop [Desktop Entry] Name=Eclipse Comment=c project ma ...

  4. 【nginx运维基础(1)】Nginx的编译安装与使用

    nginx的官方手册: http://nginx.org/en/docs/ 编译安装 下载地址: http://nginx.org/en/download.html # 为了支持rewrite功能,我 ...

  5. 手动安装UniDAC的过程

    每次安装都不一样,而且有时候挺麻烦的,所以记下来.我这次安装过程是这样的: 0. 修改Source\Delphi7\Make.bat,填入正确的IdeDir 1.找到source\delphi7目录, ...

  6. (转)最新版的SSH框整合(Spring 3.1.1 + Struts 2.3.1.2 + Hibernate 4.1)

    最近一直有朋友在问,最新版的Spring.Struts.Hibernate整合老是有问题,昨晚大概看了一下.从Hibernate 4 开始,本身已经很好的实现了数据库事务模块,而Spring也把Hib ...

  7. Java泛型中的extends和super关键字

    理解List<? extends T> list, T key, Comparator<? super T> c 这些一般用在方法形参类型上,用于接受泛型对象. 1.List& ...

  8. Myeclipse多行注释快捷键及其他快捷键

    当时我看到struts2讲解视频的时候,讲解员居然能一下子注释掉好几行代码,而且注释的很整齐,然我大吃一惊,上网搜了下Myeclipse的快捷键还真多 选择你要注释的那一行或多行代码,按Ctrl+/即 ...

  9. BZOJ 2323 细胞(矩阵)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2323 题意: 题意过于复杂,我直接简化下.给出一个长度为n的数字串,只包含1到9,将数字 ...

  10. Windows XP搜索功能 "包含文字" 搜索不到内容的解决办法

    Windows开始菜单 -- 运行 -- regedit -- 确定,编辑注册表 HKEY_LOCAL_MACHINE\SYSTEM\ControlSet\Control\ContentIndex 右 ...