当前位置: 首页 > 编程日记 > 正文

数据库加锁(转)

1 如何锁一个表的某一行 SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED SELECT * FROM table ROWLOCK WHERE id = 1 2 锁定数据库的一个表 SELECT * FROM table WITH (HOLDLOCK) 加锁语句: sybase: update 表 set col1=col1 where 1=0 ; MSSQL: select col1 from 表 (tablockx) where 1=0 ; oracle: LOCK TABLE 表 IN EXCLUSIVE MODE ; 加锁后其它人不可操作,直到加锁用户解锁,用commit或rollback解锁 几个例子帮助大家加深印象 设table1(A,B,C) A B C a1 b1 c1 a2 b2 c2 a3 b3 c3 1)排它锁 新建两个连接 在第一个连接中执行以下语句 begin tran update table1 set A='aa' where B='b2' waitfor delay '00:00:30' --等待30秒 commit tran 在第二个连接中执行以下语句 begin tran select * from table1 where B='b2' commit tran 若同时执行上述两个语句,则select查询必须等待update执行完毕才能执行即要等待30秒 2)共享锁 在第一个连接中执行以下语句 begin tran select * from table1 holdlock -holdlock人为加锁 where B='b2' waitfor delay '00:00:30' --等待30秒 commit tran 在第二个连接中执行以下语句 begin tran select A,C from table1 where B='b2' update table1 set A='aa' where B='b2' commit tran 若同时执行上述两个语句,则第二个连接中的select查询可以执行 而update必须等待第一个事务释放共享锁转为排它锁后才能执行 即要等待30秒 3)死锁 增设table2(D,E) D E d1 e1 d2 e2 在第一个连接中执行以下语句 begin tran update table1 set A='aa' where B='b2' waitfor delay '00:00:30' update table2 set D='d5' where E='e1' commit tran 在第二个连接中执行以下语句 begin tran update table2 set D='d5' where E='e1' waitfor delay '00:00:10' update table1 set A='aa' where B='b2' commit tran 同时执行,系统会检测出死锁,并中止进程 补充一点: Sql Server2000支持的表级锁定提示 HOLDLOCK 持有共享锁,直到整个事务完成,应该在被锁对象不需要时立即释放,等于SERIALIZABLE事务隔离级别 NOLOCK 语句执行时不发出共享锁,允许脏读 ,等于 READ UNCOMMITTED事务隔离级别 PAGLOCK 在使用一个表锁的地方用多个页锁 READPAST 让sql server跳过任何锁定行,执行事务,适用于READ UNCOMMITTED事务隔离级别只跳过RID锁,不跳过页,区域和表锁 ROWLOCK 强制使用行锁 TABLOCKX 强制使用独占表级锁,这个锁在事务期间阻止任何其他事务使用这个表 UPLOCK 强制在读表时使用更新而不用共享锁 应用程序锁: 应用程序锁就是客户端代码生成的锁,而不是sql server本身生成的锁 处理应用程序锁的两个过程 sp_getapplock 锁定应用程序资源 sp_releaseapplock 为应用程序资源解锁 注意: 锁定数据库的一个表的区别 SELECT * FROM table WITH (HOLDLOCK) 其他事务可以读取表,但不能更新删除 SELECT * FROM table WITH (TABLOCKX) 其他事务不能读取表,更新和删除 1 如何锁一个表的某一行 /* 测试环境:windows 2K server + Mssql 2000 所有功能都进行测试过,并有相应的结果集,如果有什么疑义在论坛跟帖 关于版权的说明:部分资料来自互联网,如有不当请联系版主,版主会在第一时间处理。 功能:sql遍历文件夹下的文本文件名,当然你修改部分代码后可以完成各种文件的列表。 */ 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 --可立即执行 2 锁定数据库的一个表 SELECT * FROM table WITH (HOLDLOCK) 注意: 锁定数据库的一个表的区别 SELECT * FROM table WITH (HOLDLOCK) 其他事务可以读取表,但不能更新删除 SELECT * FROM table WITH (TABLOCKX) 其他事务不能读取表,更新和删除

转自:http://www.cnblogs.com/lingmaozhijia/articles/1339222.html

转载于:https://www.cnblogs.com/wangjingblogs/archive/2012/01/12/2320307.html

相关文章:

学好web前端开发要注意哪些问题

web前端学起来是比较困难的&#xff0c;当然想要学好web前端技术&#xff0c;那么有一些注意事项一定是要看的&#xff0c;下面小编就为大家详细的介绍一下学好web前端开发要注意哪些问题? ​  学好web前端开发要注意哪些问题? 基础&#xff1a;无论做什么都一定要有扎实的…

Android include 标签

android中include标签是为了便于控件的覆用的一个很好解决方案。 但是也有一些需要注意的地方&#xff0c;下面是本人在项目中碰到过的一个问题&#xff0c;做此记录&#xff0c;便于以后查看。 include标签用法。 1.新建一个xml文件&#xff0c;命名 head.xml head.xml文件内容…

刻意练习:LeetCode实战 -- 不同的二叉搜索树

背景 今天&#xff0c;第二期基础算法&#xff08;Leetcode&#xff09;刻意练习训练营 的打卡任务是“不同的二叉搜索树 II”&#xff0c;而LeetCode也有“不同的二叉搜索树”题目&#xff0c;故一起写了。 题目 题号&#xff1a;96难度&#xff1a;中等https://leetcode-cn.…

15. Python 函数

1. 函数的写法&#xff0c;函数的调用【函数的一般形式】定义一个函数要有以下规则&#xff1a;&#xff08;1&#xff09;函数代码块以 def 关键词开头&#xff0c;后接函数标识符名称和小括号&#xff08;&#xff09;&#xff1b;&#xff08;2&#xff09;任何传入参数和自…

Java培训找什么样的机构比较好

​ Java培训找什么样的机构比较好?很多人都比较关注java技术&#xff0c;想要学习java技术&#xff0c;参加相关工作&#xff0c;但如今市面上的java培训机构那么多&#xff0c;怎么样选择比较靠谱呢?来看看下面的详细介绍吧。 ​  Java培训找什么样的机构比较好?小编这里…

刻意练习:LeetCode实战 -- Task23. 不同的二叉搜索树 II

背景 本篇图文是LSGO软件技术团队组织的 第二期基础算法&#xff08;Leetcode&#xff09;刻意练习训练营 的打卡任务。本期训练营采用分类别练习的模式&#xff0c;即选择了五个知识点&#xff08;数组、链表、字符串、树、贪心算法&#xff09;&#xff0c;每个知识点选择了…

windows phone 越狱教程:利用学生帐号解锁并部署软件教程(图文并茂)

之前老是看到有学生帐号可以越狱,但一直以来都觉得比较复杂,不想下手.近日,TX微信出来了,很多人都想装,可是装不了,所以下决心研究一下学生帐号越狱.网上看教程,发现很多都是不全面,有些只有一半,最后还是决定按我自己申请学生帐号时的流程写一个教程,希望对大家有所帮助. 学生…

基于web创建逼真的3D图形 | CSS技巧

在成为一名web开发者之前&#xff0c;我从事于视觉设计行业&#xff0c;创造屡获殊荣&#xff0c;电影和电视节目等高端3D效果&#xff0c;例如 Tron, The Thing, Resident Evil,和 Vikings 。为了能够创造这些效果&#xff0c;我们需要使用高度复杂的动画软件&#xff0c;例如…

jQuery元素内容操作的方法有多少种?

jQuery中操作元素内容的方法&#xff0c;主要包括html()方法、text()方法和val()方法。html()方法用于获取或设置元素的HTML内容&#xff0c;text()方法用于获取或设置元素的文本内容&#xff0c;val()方法用来获取或设置表单元素的value值。具体使用说明如表1所示。 表1 元素内…

获取SQLServer数据库中所有表

对于获取SQLSERVER数据库中所有表&#xff0c;首先第一步引有SQLDMO.dll 找到文件路径: C:\Program Files\Microsoft SQL Server\80\Tools\Binn\SQLDMO.dll 找到SQLDOM.DLL //在后台写方法 using System;using System.Collections.Generic;using System.Linq;using Syst…

刻意练习:LeetCode实战 -- Task24. 恢复二叉搜索树

背景 本篇图文是LSGO软件技术团队组织的 第二期基础算法&#xff08;Leetcode&#xff09;刻意练习训练营 的打卡任务。本期训练营采用分类别练习的模式&#xff0c;即选择了五个知识点&#xff08;数组、链表、字符串、树、贪心算法&#xff09;&#xff0c;每个知识点选择了…

Solaris下ftp配置(初稿-待补充)

1.自带ftp版本 Version wu-2.6.2 2.ftp启动与停止 启动并启用ftp: svcadm enable network/ftp 停止并禁用ftp: svcadm disable network/ftp 3.使某个系统用户无法使用ftp或者恢复使用ftp vi /etc/ftpd/ftpusers 向其中添加要禁止使用ftp的…

女生参加web前端培训可以吗

​ 近几年&#xff0c;web前端被视为互联网行业最热门编程语言技术之一&#xff0c;越来越多的人开始想要学习web前端技术&#xff0c;其中不乏有一些女性学习&#xff0c;那么很多人就要问了&#xff0c;女生参加web前端培训可以吗?我们来看看下面的详细介绍吧。 ​  女生参…

春节期间停止更新

非常抱歉地跟各位说一下&#xff0c;因为老家并没有拉宽带&#xff0c;所以春节期间无法进行更新。虽然说我可以背着笔记本回家&#xff0c;然后再到朋友处蹭一下网络。但想到一年365天&#xff0c;能回家的就那么几天&#xff0c;只是想好好陪陪父母&#xff0c;伴伴自己的老婆…

刻意练习:LeetCode实战 -- Task26.判断子序列

背景 本篇图文是LSGO软件技术团队组织的 第二期基础算法&#xff08;Leetcode&#xff09;刻意练习训练营 的打卡任务。本期训练营采用分类别练习的模式&#xff0c;即选择了五个知识点&#xff08;数组、链表、字符串、树、贪心算法&#xff09;&#xff0c;每个知识点选择了…

spring @component的作用

转自&#xff1a;https://www.cnblogs.com/lyjing/p/8427832.html1、controller 控制器&#xff08;注入服务&#xff09; 2、service 服务&#xff08;注入dao&#xff09; 3、repository dao&#xff08;实现dao访问&#xff09; 4、component &#xff08;把普通pojo实例化到…

使用JavaScript变量需要注意哪些语法细节?

使用JavaScript变量需要注意哪些语法细节?JavaScript在很多地方经常会涉及到&#xff0c;尤其是JavaScript变量这方面&#xff0c;在使用变量时&#xff0c;还有一些值得注意的语法细节&#xff0c;下面进行详细讲解。 使用JavaScript变量需要注意哪些语法细节? 1. 更新变量的…

手把手教你搭建一个学习Python好看的 Jupyter 环境

又到摆脱重复工作&#xff0c;换个心情&#xff0c;然而并没有软用的时间了。这次&#xff0c;教大家如何搭建一个好看的jupyter环境。安装Jupyter先来展示一下我的环境python: 3.5.*macos: 10.12.4安装Jupyter的过程只需安装Anaconda即可。测试一下初始设置&#xff1a;jupyte…

刻意练习:LeetCode实战 -- Task27.分发饼干

背景 本篇图文是LSGO软件技术团队组织的 第二期基础算法&#xff08;Leetcode&#xff09;刻意练习训练营 的打卡任务。本期训练营采用分类别练习的模式&#xff0c;即选择了五个知识点&#xff08;数组、链表、字符串、树、贪心算法&#xff09;&#xff0c;每个知识点选择了…

祝贺《WCF邮件通信系统》在高阳市场研究汇编第五期发表

上次给公司的市场研究汇编投稿&#xff0c;只写了一个PPT格式的《WCF邮件通信系统》&#xff0c;编辑把它整理成了PDF格式的内容&#xff0c;感觉很好&#xff0c;所以我把PDF原文中的有关内容存储成了图片&#xff0c;发表在这里&#xff0c;庆贺一下。PDF原文地址&#xff1a…

学软件测试有前途吗

学软件测试有前途吗?很多人都关心这个问题&#xff0c;最近几年&#xff0c;软件测试这个行业在很多企业都是非常刚需的&#xff0c;随着互联网的飞快发展&#xff0c;IT行业出现日新月异的变化&#xff0c;企业的大量需求&#xff0c;人才的严重匮乏&#xff0c;导致IT行业&a…

Active Directory 账号迁移配置介绍

首先介绍一下环境: 生产域环境: example.cn 测试域环境: fengdian.info 系统平台: 2K08 R2 林、域功能级别&#xff1a;Windows Server 2008 要求: 测试域环境“fengdian.info”同步生产域环境所有用户账号&#xff0c;实现测试环境和生产环境的基本统 一&#xff0c;方便功能测…

VIM命令快速记忆(转自杰哥)

因为自己也是个linuxer 熟练运用VIM是必须的&#xff0c;恰好学长杰哥对此有研究&#xff0c; 转来给大家分享。对此表达对杰哥的敬意。 有好东西分享给大家才能相互学习是吧。 要做个Linuxer&#xff0c;VIM的操作是必须就跟手指头盲打键盘那么熟练。 首先说下Vim的两种最常用…

刻意练习:LeetCode实战 -- Task28.跳跃游戏

背景 本篇图文是LSGO软件技术团队组织的 第二期基础算法&#xff08;Leetcode&#xff09;刻意练习训练营 的打卡任务。本期训练营采用分类别练习的模式&#xff0c;即选择了五个知识点&#xff08;数组、链表、字符串、树、贪心算法&#xff09;&#xff0c;每个知识点选择了…

类操作是什么意思?jQuery的类操作教程

类操作就是通过操作元素的类名进行元素样式操作&#xff0c;当元素样式比较复杂时&#xff0c;如果通过css()方法实现&#xff0c;需要在CSS里编写很长的代码&#xff0c;既不美观也不方便。而通过写一个类名&#xff0c;把类名加上或去掉就会显得很方便。下面通过代码演示类的…

刻意练习:LeetCode实战 -- Task29. 加油站

背景 本篇图文是LSGO软件技术团队组织的 第二期基础算法&#xff08;Leetcode&#xff09;刻意练习训练营 的打卡任务。本期训练营采用分类别练习的模式&#xff0c;即选择了五个知识点&#xff08;数组、链表、字符串、树、贪心算法&#xff09;&#xff0c;每个知识点选择了…

C#从SQL server数据库中读取l图片和存入图片

一、从图片中获得二进制值的基本方法&#xff1a;Image.Save 方法 (String, ImageFormat) 这会将保存 Image 写入指定的文件中指定的格式。 命名空间: System.Drawing 程序集: System.Drawing&#xff08;位于 System.Drawing.dll&#xff09; 语法&#xff1a; public void S…

linux下查看内存使用情况

在Linux下查看内存我们一般用free命令&#xff1a;[rootscs-2 tmp]# free total used free shared buffers cachedMem: 3266180 3250004 16176 0 110652 2668236-/ buffers/cache: 471116 2795064Swa…

现在转行学习UI设计好不好就业

​ UI设计是很多企业都会有需求的一个岗位&#xff0c;对于现在转行学习UI设计好不好就业这个问题&#xff0c;小编的回答是肯定的&#xff0c;最直接的方法就是上招聘信息&#xff0c;如果说招聘网站上UI设计师职位很少&#xff0c;那就说明UI设计行业已经差不多饱和了。 ​ …

刻意练习:LeetCode实战 -- Task30.通配符匹配

背景 本篇图文是LSGO软件技术团队组织的 第二期基础算法&#xff08;Leetcode&#xff09;刻意练习训练营 的打卡任务。本期训练营采用分类别练习的模式&#xff0c;即选择了五个知识点&#xff08;数组、链表、字符串、树、贪心算法&#xff09;&#xff0c;每个知识点选择了…