一个四用户信息同步更新的存储过程

2016-01-29 16:27 12 1 收藏

一个四用户信息同步更新的存储过程,一个四用户信息同步更新的存储过程

【 tulaoshi.com - SQLServer 】

 

不实用,之所以写,一为领导的要求,另外也熟悉下写代码,代码多写点也没什么坏处,并且写了之后发现临时表还挺容易用的,数据量小的时候,并显不出临时表速度不行的问题.

代码如下:

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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/sqlserver/)

--这里要注意,更新用户现金取数据库中的数据,跟游戏服务器能否保持一致
--取得用户现金
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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/sqlserver/)

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]
 

来源:http://www.tulaoshi.com/n/20160129/1498631.html

延伸阅读
标签: SQLServer
优点如下,简单,直接sql语句输入,高效,效率很高测试过了,不过最好是主键排序,还有少用视图 。 缺点也有,不支持复杂的sql语句,不能多字段排序,sql语句必须小于4000字符 /*   经测试,在 14483461 条记录中查询第 100000 页,每页 10 条记录按升序和降序第一次时间均为 0.47 秒,第二次时间均为 0.43 秒,测试语法如下:   exe...
create proc sp_PublicTurnPageWebSite( @TBName nvarchar(100)='', --表名,如 pinyin @PageSize int=10, --每页的记录数,默认为 10 @CurPage int=1, --表示当前页 1 @KeyField nvarchar(100)='ID', --关键字段名,默认为 ID,该字段要求是表中的索引 或 ...
if not exists (select * from dbo.sysobjects where id = object_id(N'[IndexTable]') and OBJECTPROPERTY(id, N'IsUserTable') = 1) create table IndexTable(Ex char(20), num integer) go create procedure SetIndex @Ex char(20),@result char(30) output,@Fmt integer as   declare @num...
现在很多网站都有做会员邀请好友注册获取积分奖励的推广手段,比如像开心网,就是把这手段做到了极致。在上面玩买卖好友,停车游戏,邀请个好友注册,就能获取更多的游戏币。玩开心农场,钓鱼,拉一个好友进来就能获得一个兑换道具的机会。开心网的人气能够一直这么旺,不段新产品推出是一个原因,另外在新产品里都不忘继续吸引用户拉人进来的...
标签: Web开发
CREATE PROCEDURE GoalerPageSp @IntPageSize int, @IntCurrPage int, @strFields nvarchar(2000), @strTable varchar(200), @strWhere varchar(800), @strOrderType varchar(200), @strKeyField varchar(50) AS SET NOCOUNT ON DECLARE @tmpSQL nvarchar(4000)--存放动态SQL...

经验教程

334

收藏

18
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部