讨论 并发执行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
相关文档:
1:当 SQL 语句引用非索引视图时,分析器和查询优化器将分析 SQL 语句的源和视图的源,然后将它们解析为单个执行计划。没有单独用于 SQL 语句或视图的计划。
2:索引视图的行以表的格式存储在数据库中。如果查询优化器决定使用查询计划的索引视图,则索引视图将按照基表的处理方式进行处理 ......
至今未有成就,甚感彷徨。
并不是很突然的想学SQL,而是在之前说的那样,在我绕了一大圈之后,才知道自己也是一无所知,枉学了这么多年。
我一直想脱离学校的教育模式来自学,然而我并不承认学校的教育方式是一无所用的,至少学到的东西是实在的。从学校的角度来考虑, ......
原文转自 http://blog.csdn.net/jyh_jack/archive/2008/04/07/2257512.aspx
SQL Native Client ODBC Driver
标准安全连接
Driver={SQL Native Client};Server=myServerAddress;Database=myDataBase;Uid=myUsername;Pwd=myPassword;
您是否在使用SQL Server 2005 Express? 请 ......
--sqlserver 2000
SELECT 表名=case when a.colorder=1 then d.name else '' end,
--字段序号=a.colorder,
字段名=a.name,
--
标识=case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end,
/**/
主键=case when exists(SELECT 1 from sysobjects where xtype='PK' and name
in ( ......
1.sql是一种脚本语言
2.sql可写脚本程序,但最重要的作用发挥在对数据库的操作上
3.sql server2005中的注释有两种/***/多行注释,--可以单行注释
4.sql中的自定义变量以@开头,系统变量以@@开头
5.sql中声明变量和VB类似,使用declare声明变量如:declare @i int,@j int,此语句声明了2个整形变量@i和@j
6.sql中的数据 ......