易截截图软件、单文件、免安装、纯绿色、仅160KB

讨论 并发执行SQL时的更新丢失,如何解决这种问题

    最近遇到一个问题,在操作SQL更新账户余额时,常常发现更新后的余额与实际的不相符,马上想到了是不是存在并发更新,一查果然如此。之前也曾遇到过这样的问题,当时没太在意,现在是解决的时候了。用Mysql模拟了一下这个过程:创建两张表,paralltable和parallalter,每次根据paratable表更新parallalter表,有如下几条逻辑
    ① parallProcess.jsp页面接收parall.jsp传过来的值,首先向paralltable插入一条记录,同时用paralltable的id,num,向parallalter表插入一条新记录;
    ② 之后parallProcess.jsp准备更新刚插入的paralltable记录,随之用更新后的paralltable的id,num,向parallalter表插入一条新记录,但在更新之前,先人为的设置一个延时,在延时期内执行并发操作③ ;
    ③ 从parall2.jsp页面向parallProcess2.jsp页面传值,在parallProcess.jsp延时期内,更新①中向paralltable插入的记录,同时用更新后的paralltable的id,num,向parallalter表插入一条新记录;
    ④ 执行完③的操作后,立刻执行②的操作。
    如此的话,就会发现本来③是在②完全执行后,对paralltable进行更新,结果由于并发操作,③的更新结果丢失了,这种问题在SQL操作中经常发生。不知大家有在遇到这种问题时,是如何解决的。
附:模拟程序见  http://download.csdn.net/source/2389003
  


相关文档:

Sql语句学习笔记(2) 创建数据表

use RetalDB--表示在数据库RetalDB中进行的操作
go
if exists (select * from sysobjects where name='tb_user')
 drop table tb_user
go
--创建客户表tb_user
create table tb_user
(
 user_id int primary key,--指定为主键时,此列默认为非空,指定过多个限制条件时不用“'”隔开
 us ......

Sql语句学习笔记(4) 查询1

这里使用的数据库和数据表分别来自Sql语句学习笔记(1)——创建数据库和Sql语句学习笔记(2)——创建数据表
use RetalDB
/********************
单表查询
*********************/
--查询tb_user中的数据:无条件查询
--(1)
select * from tb_user--查询所有信息
--(2)
select top 2 * from ......

sql格式化日期

Select CONVERT(varchar(100), GETDATE(), 0): 05 16 2010 10:57AM
Select CONVERT(varchar(100), GETDATE(), 1): 05/16/06
Select CONVERT(varchar(100), GETDATE(), 2): 06.05.16
Select CONVERT(varchar(100), GETDATE(), 3): 16/05/06
Select CONVERT(varchar(100), GETDATE(), 4): 16.05.06
Select CONVERT(varch ......

我的SQL之路2

   至今未有成就,甚感彷徨。
   并不是很突然的想学SQL,而是在之前说的那样,在我绕了一大圈之后,才知道自己也是一无所知,枉学了这么多年。
   我一直想脱离学校的教育模式来自学,然而我并不承认学校的教育方式是一无所用的,至少学到的东西是实在的。从学校的角度来考虑, ......

IBatisNet SQL Server的float类型转换为c# float出错

今天写一个商品的修改功能时遇到的问题
商品中重量 weight 的数据库(SQL Server2005)类型定义为 float
在mappings 中转换为c#类型的一句为
<result property="Goods_Weight" column="Goods_Weight" type="float" dbType="float"/>
按理说这个 float 是一样的,转换完全不会出现问题,
实际程序运行时,系统报错 ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号