免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1942 | 回复: 3
打印 上一主题 下一主题

问下有关SQL锁的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-06-09 22:11 |只看该作者 |倒序浏览
要实现一个限制用户登录个数的功能
我把所有在线用户记录在一张表中
一个用户登录时,
先锁住这张表然后查出这个用户的在线个数,
然后决定添加一个新用户或者报登录个数限制

我现在用的是rowlock行锁 和 xlock 排它锁
我的问题1是: 如果下面的语句根本查询不出一行, 那么是不是不会锁住? 我是不是该用表锁?
begin tran;
select * from onlineuser with(rowlock xlock) where user ='abc'
!-- 在这里判断并决定是否插入一个新用户
commit tran;

问题2: 如果用分布式数据库, 我的两个程序分别访问不同电脑的数据库, 这个行锁和表锁也有作用吗? 难道两个SQL会实时同步它的锁情况?
我还不太懂分布式数据库是怎么弄的.

论坛徽章:
59
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
2 [报告]
发表于 2010-06-10 10:12 |只看该作者
关于ORACLE锁,可以看看ORACLE封锁机制。

论坛徽章:
0
3 [报告]
发表于 2010-06-10 11:04 |只看该作者
好好去关注下oracle权限控制一块,应该有提供相应参数来控制的。

而没必要自己来建所谓的保存用户session数的表,看看v$session,v$process之类的表,oracle都帮你记录好了。

其实这个帖子和oracle的锁没啥关系,目的是控制用户session的个数。

论坛徽章:
0
4 [报告]
发表于 2010-06-10 20:22 |只看该作者
那我去看看, 谢谢两位
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP