在SQL Server 中如何解决多用户发生的锁定问题.在线等侯.急急急

强人很牛 2003-10-20 08:17:44
我的开发工具前台是PB9,后台是 SQL Server 2000,当多用户同时登录同一窗口并对其操作时,只允许一个用户对其操作,而其它用户都必须进入等待状态,这时就会发生了窗口的假死现象,请问各位高手如何解决这一问题.如果有更好的解决方法,分不成问题.请发到我的邮箱 wangyong@bigtide.com
...全文
164 13 打赏 收藏 转发到动态 举报
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
zztmonster 2003-10-22
  • 打赏
  • 举报
回复
你说的假死现象我个人认为是你的PB程序产生的,原因可能是你在事务处理中,谈出对话框等等。在事务处理中要返回的信息,必须是在roll back 或 commit后。(个人意见,供参考)
lvltt 2003-10-22
  • 打赏
  • 举报
回复
学习
aierong 2003-10-22
  • 打赏
  • 举报
回复
edchild 2003-10-22
  • 打赏
  • 举报
回复
好贴收藏
老本 2003-10-21
  • 打赏
  • 举报
回复
确认你的业务是核心业务;
开发一个中间层,专门处理对该资源的请求;
数据修改时,对每一个客户进行推送(Sock编程解决);
建议采用Delphi开发。
enhydraboy 2003-10-21
  • 打赏
  • 举报
回复
各位高手,我是说如何解决锁定问题,不是如何加锁,解决多用户的问题.

==>sql server肯定考虑过多用户下数据一致性的问题。同时sql server也采取了措施,主动检测死锁并且解决。

我的开发工具前台是PB9,后台是 SQL Server 2000,当多用户同时登录同一窗口并对其操作时,只允许一个用户对其操作,而其它用户都必须进入等待状态,这时就会发生了窗口的假死现象

==>这正是说明了,sql server的锁的机制充分发挥了作用。此时,你说的假死现象,是处于等待的问题。所以,我认为,你的问题在于,你pb程序上要解决,当程序处于等待状态是,要能够把操作权交给用户。就是程序处理上面的异步的问题。在vb中一般是采用doevents,使得操作权马上交给用户。pb中怎么写,你还是查查文档。
pengdali 2003-10-20
  • 打赏
  • 举报
回复
在事务结束后它自己会解琐,如果发生死锁需要用kill杀掉。如:
use master
go
create proc killspid (@dbname varchar(20))
as
begin
declare @sql nvarchar(500),@temp varchar(1000)
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
set @temp='kill '+rtrim(@spid)
exec(@temp)
fetch next from getspid into @spid
end
close getspid
deallocate getspid
end

--用法
use master
exec killspid '数据库名'

这是杀掉数据库上所有的连接,你可以每天晚上用作业执行。
强人很牛 2003-10-20
  • 打赏
  • 举报
回复
各位高手,我是说如何解决锁定问题,不是如何加锁,解决多用户的问题.
sql1 2003-10-20
  • 打赏
  • 举报
回复
http://expert.csdn.net/Expert/topic/2218/2218218.xml?temp=.099621
bubugao 2003-10-20
  • 打赏
  • 举报
回复
检查PB代码,可以解决锁定问题
在每一个update或 delete 语句执行完后都要commit using sqlca 或 roolback using sqlca
执行完存储过程以后最好也调用此语句
shanshanzheng 2003-10-20
  • 打赏
  • 举报
回复
怎麼可能一天到晚去執行 kill spid,這樣做的化,系統就不要用了.
可以試試對 read 操作降低鎖級別 , 減小 transaction 粒度 ,
優化程序以減少對系統資源的佔用,提高運行速度. 這些方法
在 CSDN 的 sql 版有許多好建議 , 我有部分參考使系統起死回生 ,這還要感謝大家 .
另外我不知道 pb與 DB 的連接方式SQLCA 中是否有優化的方法 ,因該可以朝這個方向去研究一下.
txlicenhe 2003-10-20
  • 打赏
  • 举报
回复

http://expert.csdn.net/Expert/topic/2218/2218218.xml?temp=.099621
/********** 加锁 ***************
设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

同时执行,系统会检测出死锁,并中止进程


--------------------------------------------------------------
SET IMPLICIT_TRANSACTIONS ON --用户每次必须显式提交或回滚。否则当用户断开连接时,
--事务及其所包含的所有数据更改将回滚

SET IMPLICIT_TRANSACTIONS OFF --自动提交模式。在自动提交模式下,如果各个语句成功
--完成则提交。
伍子V5 2003-10-20
  • 打赏
  • 举报
回复
1 如何锁一个表的某一行


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)
其他事务不能读取表,更新和删除
本课程根据讲师十多年在世界500强外企的生产环境SQL Serer数据库管理和项目实施经验倾心打造。课程系统性强,知识体系完整,覆盖90%以上的企业环境下SQL Server高可用场景,课程不仅演示详细的操作步骤,更加突出最常见的故障和问题,让学员少走“弯路”,不只是让学员学会“操作”更能让学员“操作”的规范,满满的干货分享,一些课程资料(架构图、部署规划表格等)不仅可以帮助学员掌握技能,也可以作为学员在企业生产环境实施SQL Server高可用的配置文档、操作手册等。课程的实验环境介绍:1)全部基于微软域环境和企业版SQL Server AOAG - 95%以上的企业环境都是在域环境,不介绍非域环境和标准版的SQL Server高可用性组,这的配置在企业较罕见,没有实践意义,不浪费学员时间。2)相应域环境已提前部署和配置好 - 学员导入虚拟机即可开始实验,无需从零开始搭建域环境,所有实验SQL Server均已加域,直入主题,节省大量时间。3)最新的Windows Server故障转移集群(WS2016、WS2019)和最新版本的SQL ServerSQL2017、SQL2019) -  WS2016-SQL2017与WS2019-SQL2019是目前大多数企业SQL Server高可用的主要平台,基于微软产品生命周期现在一些企业也在讲早期的AOAG向这两个版本迁移,掌握这两种组合不仅让学员学会,更能学有所用。本课程为后续SQL Server进阶课程铺垫,是通向SQL Server DBA 专家的必经之路,讲师每周答疑两次。所有课程资料包括:课程PPT、架构图、部署规划表格、各类脚本学员均可下载。     

27,579

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧