王朝网络
分享
 
 
 

临时表在特定的条件下同样可以灵活易用

王朝other·作者佚名  2008-06-01
宽屏版  字体: |||超大  

本文介绍了一个四用户同步更新的存储过程实例,通过这个实例的学习,你可以发现临时表在某种条件下也可以是灵活易用的,在数据量小的时候,它并不会显现出临时表速度不行的问题。

SET QUOTED_IDENTIFIER ON

GO

SET ANSI_NULLS ON

GO

/*

Name:游戏中四人数据同时更新

Designed By :whbo

Designed At :2005-10-12

Modified By :

Modified At :

Memo:

*/

ALTER PROC [PrMoney_UpdateCash2]

@chvModeName varchar(16),

@chvSourceName varchar(64),

@chvRemark varchar(128),

@intUserID1 int,

@intUserID2 int,

@intUserID3 int,

@intUserID4 int,

@intWantedAmount1 int,

@intWantedAmount2 int,

@intWantedAmount3 int,

@intWantedAmount4 int,

@chvIPAddress1 varchar(15),

@chvIPAddress2 varchar(15),

@chvIPAddress3 varchar(15),

@chvIPAddress4 varchar(15),

@inyLog tinyint

as

set nocount on

set xact_abort on

Declare @intCashAmount1 int,@intCashAmount2 int,@intCashAmount3 int,@intCashAmount4 int

Declare @FRate float,@FTemp float

Declare @bNeedReCalc bit --0:不用重算 ;1:需要重算

set @FRate=1.0

set @FTemp=1.0

set @bNeedReCalc=0

Declare @FTemp1 float,@FTemp2 float,@FTemp3 float,@FTemp4 float

--这里要注意,更新用户现金取数据库中的数据,跟游戏服务器能否保持一致

--取得用户现金

select @intCashAmount1=[Amount] from [dbo].[Money] where [UserID]=@intUserID1

select @intCashAmount2=[Amount] from [dbo].[Money] where [UserID]=@intUserID2

select @intCashAmount3=[Amount] from [dbo].[Money] where [UserID]=@intUserID3

select @intCashAmount4=[Amount] from [dbo].[Money] where [UserID]=@intUserID4

Create Table #Temp1(TTemp float)

if @intCashAmount1+@intWantedAmount1<0

begin

set @FTemp=-@intCashAmount1/@intWantedAmount1

insert into #temp1 values(@FTemp)

end

if @intCashAmount2+@intWantedAmount2<0

begin

set @FTemp=-@intCashAmount2/@intWantedAmount2

insert into #temp1 values(@FTemp)

end

if @intCashAmount3+@intWantedAmount3<0

begin

set @FTemp=-@intCashAmount3/@intWantedAmount3

insert into #temp1 values(@FTemp)

end

if @intCashAmount4+@intWantedAmount4<0

begin

set @FTemp=-@intCashAmount4/@intWantedAmount4

insert into #temp1 values(@FTemp)

end

set @FTemp=(select min(@FTemp) from #temp)

drop table #temp1

if @FTemp<@FRate

begin

set @FRate=@FTemp

set @BNeedReCalc=1

end

if @BNeedReCalc=1

begin

set @intWantedAmount1=@intWantedAmount1*@FRate

set @intWantedAmount2=@intWantedAmount2*@FRate

set @intWantedAmount3=@intWantedAmount3*@FRate

set @intWantedAmount4=@intWantedAmount4*@FRate

end

begin tran

exec [prMoney_UpdateCash]

@chvModeName, -- 通过什么方式,如'WEB'、'GameServer'等

@chvSourceName, -- 方式的源,如'金币麻将服务器'、'虚拟股市'等

@chvRemark, -- 其它信息 注释.

@intUserID1, -- 用户ID

0, -- 相关的用户ID

@intWantedAmount1, -- 希望更新的数量(>0 加金, <0 扣金)

0, -- 税金(税金>0,要在现金中扣除,游戏服务器可以置为0)

@chvIPAddress1, -- IP地址

0, -- 机器码

1 -- 是否做Log,如果>0,则表示做Log,否则不做Log

exec [prMoney_UpdateCash]

@chvModeName, -- 通过什么方式,如'WEB'、'GameServer'等

@chvSourceName, -- 方式的源,如'金币麻将服务器'、'虚拟股市'等

@chvRemark, -- 其它信息 注释.

@intUserID2, -- 用户ID

0, -- 相关的用户ID

@intWantedAmount2, -- 希望更新的数量(>0 加金, <0 扣金)

0, -- 税金(税金>0,要在现金中扣除,游戏服务器可以置为0)

@chvIPAddress2, -- IP地址

0, -- 机器码

1 -- 是否做Log,如果>0,则表示做Log,否则不做Log

exec [prMoney_UpdateCash]

@chvModeName, -- 通过什么方式,如'WEB'、'GameServer'等

@chvSourceName, -- 方式的源,如'金币麻将服务器'、'虚拟股市'等

@chvRemark, -- 其它信息 注释.

@intUserID3, -- 用户ID

0, -- 相关的用户ID

@intWantedAmount3, -- 希望更新的数量(>0 加金, <0 扣金)

0, -- 税金(税金>0,要在现金中扣除,游戏服务器可以置为0)

@chvIPAddress3, -- IP地址

0, -- 机器码

1 -- 是否做Log,如果>0,则表示做Log,否则不做Log

exec [prMoney_UpdateCash]

@chvModeName, -- 通过什么方式,如'WEB'、'GameServer'等

@chvSourceName, -- 方式的源,如'金币麻将服务器'、'虚拟股市'等

@chvRemark, -- 其它信息 注释.

@intUserID4, -- 用户ID

0, -- 相关的用户ID

@intWantedAmount4, -- 希望更新的数量(>0 加金, <0 扣金)

0, -- 税金(税金>0,要在现金中扣除,游戏服务器可以置为0)

@chvIPAddress4, -- IP地址

0, -- 机器码

1 -- 是否做Log,如果>0,则表示做Log,否则不做Log

commit tran

return 1

GO

SET QUOTED_IDENTIFIER OFF

GO

SET ANSI_NULLS ON

GO

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
>>返回首页<<
推荐阅读
 
 
频道精选
 
静静地坐在废墟上,四周的荒凉一望无际,忽然觉得,凄凉也很美
© 2005- 王朝网络 版权所有