| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 614 人关注过本帖
标题:关于多用户操作时表锁定问题?
只看楼主 加入收藏
airfei
Rank: 1
等 级:新手上路
帖 子:137
专家分:0
注 册:2007-4-12
收藏
 问题点数:0 回复次数:0 
关于多用户操作时表锁定问题?
是这样的,我有两个表,如下
order表
orderID serviceID serviceName state

service表
sevriceID serviceName

上面两表都是主键自增的。
我的思路是这样的:初始这两个表都是没有记录的,我想在新增一条记录的时候,先从service表取出max(serviceID)+ 1,然后插入到order表中,当这条记录插入order表后,再把order表中的serviceName插入到service表。步骤是这样:

1.从service表取出max(serviceID)+ 1,由于初始两表都无数据,所以取得的serviceID为1,然后插入order表,这时两表情况
order表
orderID serviceID serviceName state
   1        1        软件销售    1
service表
sevriceID serviceName

2.再把order表中的serviceName插入到service表,这时两表情况
order表
orderID serviceID serviceName state
   1        1        软件销售    1
service表
sevriceID serviceName
    1       软件销售

问题出现了:如果只有单个用户这样的操作是没有问题的,但是如果多个用户都在录入订单,就会出现从service表取出max(serviceID)+ 1的数据重复的问题。
1.多用户操作取得的最大serviceID相同,因为都还没有往service表插入数据
order表
orderID serviceID serviceName state
   1        1        软件销售    1
   2        1        牛奶销售    1
   3        1        订购月饼    1
  ...      ...         ...     ...

2.而这时候往service表抽入数据时,表出现这样的情况
service表
sevriceID serviceName
    1       软件销售
     2       牛奶销售
     3       订购月饼
   ...        ...

这里看出order表的serviceID和service表serviceID不一致。

而我想要的结果是这样的:
order表
orderID serviceID serviceName state
   1        1        软件销售    1
   2        2        牛奶销售    1
   3        3        订购月饼    1
  ...      ...         ...     ...

service表
sevriceID serviceName
    1       软件销售
    2       牛奶销售
    3       订购月饼
   ...        ...


我想的办法是在:多用户在程序中提交表单时,先锁定service表,不其他用户允许读,取出当前最大serviceID,插入order表,然后插入service表后,再解除service表的锁定。

但是怎么在程序中实现锁定呢?大家还有其他更好的办法吗?谢谢大家,请多指教。
搜索更多相关主题的帖子: 用户 
2008-09-15 19:16
快速回复:关于多用户操作时表锁定问题?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.028507 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved