国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > 綜合 > 正文

一個四用戶信息同步更新的存儲過程

2024-07-21 02:31:30
字體:
供稿:網(wǎng)友

不實(shí)用,之所以寫,一為領(lǐng)導(dǎo)的要求,另外也熟悉下寫代碼,代碼多寫點(diǎn)也沒什么壞處,并且寫了之后發(fā)現(xiàn)臨時表還挺容易用的,數(shù)據(jù)量小的時候,并顯不出臨時表速度不行的問題.

代碼如下:

SET QUOTED_IDENTIFIER ON
GO
SET ANSI_NULLS ON
GO
/*
Name:游戲中四人數(shù)據(jù)同時更新
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

--這里要注意,更新用戶現(xiàn)金取數(shù)據(jù)庫中的數(shù)據(jù),跟游戲服務(wù)器能否保持一致
--取得用戶現(xiàn)金
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,  -- 方式的源,如'金幣麻將服務(wù)器'、'虛擬股市'等
 @chvRemark,  -- 其它信息 注釋.
 @intUserID1,    -- 用戶ID
 0, -- 相關(guān)的用戶ID
 @intWantedAmount1,   -- 希望更新的數(shù)量(>0 加金, <0 扣金)
 0,    -- 稅金(稅金>0,要在現(xiàn)金中扣除,游戲服務(wù)器可以置為0)
 @chvIPAddress1,  -- IP地址
 0, -- 機(jī)器碼
 1    -- 是否做Log,如果>0,則表示做Log,否則不做Log

exec [prMoney_UpdateCash]
 @chvModeName,   -- 通過什么方式,如'WEB'、'GameServer'等
 @chvSourceName,  -- 方式的源,如'金幣麻將服務(wù)器'、'虛擬股市'等
 @chvRemark,  -- 其它信息 注釋.
 @intUserID2,    -- 用戶ID
 0, -- 相關(guān)的用戶ID
 @intWantedAmount2,   -- 希望更新的數(shù)量(>0 加金, <0 扣金)
 0,    -- 稅金(稅金>0,要在現(xiàn)金中扣除,游戲服務(wù)器可以置為0)
 @chvIPAddress2,  -- IP地址
 0, -- 機(jī)器碼
 1    -- 是否做Log,如果>0,則表示做Log,否則不做Log

exec [prMoney_UpdateCash]
 @chvModeName,   -- 通過什么方式,如'WEB'、'GameServer'等
 @chvSourceName,  -- 方式的源,如'金幣麻將服務(wù)器'、'虛擬股市'等
 @chvRemark,  -- 其它信息 注釋.
 @intUserID3,    -- 用戶ID
 0, -- 相關(guān)的用戶ID
 @intWantedAmount3,   -- 希望更新的數(shù)量(>0 加金, <0 扣金)
 0,    -- 稅金(稅金>0,要在現(xiàn)金中扣除,游戲服務(wù)器可以置為0)
 @chvIPAddress3,  -- IP地址
 0, -- 機(jī)器碼
 1    -- 是否做Log,如果>0,則表示做Log,否則不做Log
exec [prMoney_UpdateCash]
 @chvModeName,   -- 通過什么方式,如'WEB'、'GameServer'等
 @chvSourceName,  -- 方式的源,如'金幣麻將服務(wù)器'、'虛擬股市'等
 @chvRemark,  -- 其它信息 注釋.
 @intUserID4,    -- 用戶ID
 0, -- 相關(guān)的用戶ID
 @intWantedAmount4,   -- 希望更新的數(shù)量(>0 加金, <0 扣金)
 0,    -- 稅金(稅金>0,要在現(xiàn)金中扣除,游戲服務(wù)器可以置為0)
 @chvIPAddress4,  -- IP地址
 0, -- 機(jī)器碼
 1    -- 是否做Log,如果>0,則表示做Log,否則不做Log
commit tran
return 1


GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 抚远县| 大方县| 定结县| 永川市| 大洼县| 湖口县| 惠来县| 陆良县| 贞丰县| 洛阳市| 高青县| 江口县| 长寿区| 禹城市| 云霄县| 彩票| 黄陵县| 绥棱县| 白朗县| 卓资县| 永川市| 铁岭县| 顺昌县| 安溪县| 渭源县| 丰镇市| 金坛市| 梧州市| 滨州市| 海门市| 阿荣旗| 伊宁市| 阿巴嘎旗| 文安县| 永嘉县| 融水| 蓬安县| 双辽市| 老河口市| 通辽市| 青岛市|