同一个存储过程,偶尔出现一两个用户数据没更新到

Mark杨 2015-12-06 11:59:59
INSERT INTO dbo.TPoint( KUserID ,FPointCount ,FPointType ,FPointDesc ,FPointTime)
VALUES(@userid,@fcount,1,'购买商品('+ CONVERT(NVARCHAR(32),@id)+')获得福分',GETDATE())
IF(@@ERROR <> 0)
BEGIN
SELECT 0,'插入福分记录',@orderNo,@id
ROLLBACK TRANSACTION
RETURN
END

UPDATE dbo.TUser SET FUserPoint = FUserPoint + @fcount,FLevelPoint = FLevelPoint + (@fcount *10) WHERE PUserID = @userid
IF(@@ERROR <> 0)
BEGIN
SELECT 0,'修改积分和福分错误',@orderNo,@id
ROLLBACK TRANSACTION
RETURN
END


这个是存储过程中的一段, 我查询了数据库,在TPoint表里面是有记录的,可是在TUser表里面,数据没有被修改到。 也就是上面那句有执行到,下面的没有。

TPoint在这个存储过程是第一次被操作到,TUser是第2次被操作到,会不会有影响? 我在本地测试了,都是正常运行的,在服务器上面,也是偶尔有那么几个人是没有更新到的。
...全文
152 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
Mark杨 2015-12-06
  • 打赏
  • 举报
回复
引用 1 楼 roy_88 的回复:
if @@Rowcount=0 --没有用户时,新增记录 insert into dbo.TUser(PUserID,FUserPoint,FLevelPoint) values(@userid,@fcount,@fcount*10) --加上这一段
begin try
begin tran
INSERT INTO dbo.TPoint( KUserID ,FPointCount ,FPointType ,FPointDesc ,FPointTime)
            VALUES(@userid,@fcount,1,'购买商品('+ CONVERT(NVARCHAR(32),@id)+')获得福分',GETDATE())
UPDATE dbo.TUser SET FUserPoint = FUserPoint + @fcount,FLevelPoint = FLevelPoint + (@fcount *10) WHERE PUserID = @userid
if @@Rowcount=0	--没有用户时,新增记录
insert into dbo.TUser(PUserID,FUserPoint,FLevelPoint)
values(@userid,@fcount,@fcount*10)
commit tran
end try
BEGIN CATCH
	DECLARE @ErrorMessage NVARCHAR(4000),@ErrorSeverity INT,@ErrorState INT;
	SELECT @ErrorMessage = ERROR_MESSAGE(),@ErrorSeverity = ERROR_SEVERITY(),@ErrorState = ERROR_STATE();
	RAISERROR (@ErrorMessage, @ErrorSeverity,@ErrorState);
	ROLLBACK TRAN	
END CATCH
这个地方没问题,自己太大意了。 在其他不可能修改的地方,把数据给修改到了。
Mark杨 2015-12-06
  • 打赏
  • 举报
回复
引用 1 楼 roy_88 的回复:
if @@Rowcount=0 --没有用户时,新增记录 insert into dbo.TUser(PUserID,FUserPoint,FLevelPoint) values(@userid,@fcount,@fcount*10) --加上这一段
begin try
begin tran
INSERT INTO dbo.TPoint( KUserID ,FPointCount ,FPointType ,FPointDesc ,FPointTime)
            VALUES(@userid,@fcount,1,'购买商品('+ CONVERT(NVARCHAR(32),@id)+')获得福分',GETDATE())
UPDATE dbo.TUser SET FUserPoint = FUserPoint + @fcount,FLevelPoint = FLevelPoint + (@fcount *10) WHERE PUserID = @userid
if @@Rowcount=0	--没有用户时,新增记录
insert into dbo.TUser(PUserID,FUserPoint,FLevelPoint)
values(@userid,@fcount,@fcount*10)
commit tran
end try
BEGIN CATCH
	DECLARE @ErrorMessage NVARCHAR(4000),@ErrorSeverity INT,@ErrorState INT;
	SELECT @ErrorMessage = ERROR_MESSAGE(),@ErrorSeverity = ERROR_SEVERITY(),@ErrorState = ERROR_STATE();
	RAISERROR (@ErrorMessage, @ErrorSeverity,@ErrorState);
	ROLLBACK TRAN	
END CATCH
不过我能确定的是,用户是存在的。 根据TPoint表的userid 我在用户表是有查询到数据的
中国风 2015-12-06
  • 打赏
  • 举报
回复
if @@Rowcount=0 --没有用户时,新增记录 insert into dbo.TUser(PUserID,FUserPoint,FLevelPoint) values(@userid,@fcount,@fcount*10) --加上这一段
begin try
begin tran
INSERT INTO dbo.TPoint( KUserID ,FPointCount ,FPointType ,FPointDesc ,FPointTime)
            VALUES(@userid,@fcount,1,'购买商品('+ CONVERT(NVARCHAR(32),@id)+')获得福分',GETDATE())
UPDATE dbo.TUser SET FUserPoint = FUserPoint + @fcount,FLevelPoint = FLevelPoint + (@fcount *10) WHERE PUserID = @userid
if @@Rowcount=0	--没有用户时,新增记录
insert into dbo.TUser(PUserID,FUserPoint,FLevelPoint)
values(@userid,@fcount,@fcount*10)
commit tran
end try
BEGIN CATCH
	DECLARE @ErrorMessage NVARCHAR(4000),@ErrorSeverity INT,@ErrorState INT;
	SELECT @ErrorMessage = ERROR_MESSAGE(),@ErrorSeverity = ERROR_SEVERITY(),@ErrorState = ERROR_STATE();
	RAISERROR (@ErrorMessage, @ErrorSeverity,@ErrorState);
	ROLLBACK TRAN	
END CATCH
内容概要:本文围绕“基于超局部模型与自抗扰ESO观测器的无模型预测电流控制改进策略”展开研究,提出一种结合超局部模型(ULM)与扩张状态观测器(ESO)的无模型预测电流控制(MFPCC)改进方法,旨在提升永磁同步电机(PMSM)电流环的动态响应性能与抗干扰能力。该策略利用超局部模型对系统行为进行局部逼近,避免依赖精确数学模型,同时引入自抗扰控制中的ESO实时观测并补偿系统内外部扰动,有效抑制参数摄动、负载变化及模型不确定性带来的影响。研究通过Simulink搭建完整的控制系统仿真模型,对传统MFPCC与所提改进策略进行对比分析,验证了新方法在电流跟踪精度、响应速度和鲁棒性方面的优越性。; 适合人群:具备电机控制、现代控制理论及Simulink仿真基础的电气工程、自动化及相关专业的研究生、科研人员及工程技术人员。; 使用场景及目标:①用于高性能电机驱动系统中电流环控制器的设计与优化;②为无模型控制与自抗扰控制的融合应用提供技术参考;③支撑相关课题的仿真验证、论文复现与创新方法研究。; 阅读建议:建议读者结合Simulink仿真模型深入理解控制结构与参数整定过程,重点关注ESO的观测性能与扰动补偿机制,并可通过改变负载条件、参数偏差等工况进行鲁棒性测试,进一步掌握该改进策略的核心优势与适用边界。

22,297

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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