CREATE PROCEDURE dbo.InsertChar @user_uid AS INT, /* À¯Àú °íÀ¯ ¾ÆÀ̵ð */ @user_pos AS INT, /* ij¸¯ÅÍ À§Ä¡ (3°³ÀÇ ½½·Ô) */ @user_name AS VARCHAR(16), /* ij¸¯ÅÍ À̸§ */ @user_Sex AS TINYINT, /* ij¸¯ÅÍ ¼º */ @user_Hair AS TINYINT, /* ij¸¯ÅÍ ¸Ó¸® ¸ð¾ç */ @user_Face AS TINYINT, /* ij¸¯ÅÍ ¾ó±¼ ¸ð¾ç */ @user_Nation AS TINYINT, /* ij¸¯ÅÍ ±¹°¡ */ @user_Class AS SMALLINT, /* ij¸¯ÅÍ Å¬·¡½º */ @C_Gold AS INT, /* ij¸¯ÅÍ ¼ÒÁö±Ý */ @C_STR AS SMALLINT, /* ij¸¯ÅÍ STR */ @C_DEX AS SMALLINT, /* ij¸¯ÅÍ DEX */ @C_CON AS SMALLINT, /* ij¸¯ÅÍ CON */ @C_INT AS SMALLINT, /* ij¸¯ÅÍ INT */ @C_WIS AS SMALLINT, /* ij¸¯ÅÍ WIS */ @PointX AS REAL, /* ij¸¯ÅÍ Point X ÁÂÇ¥ */ @PointY AS REAL, /* ij¸¯ÅÍ Point Y ÁÂÇ¥ */ @PointZ AS REAL, /* ij¸¯ÅÍ Point Z ÁÂÇ¥ */ @C_Equip AS varBINARY(30), /* Àåºñ (2 * 15 = 30) */ @Skill AS varBinary(84), @UserInfoType TINYINT, @CID INT OUTPUT AS SET NOCOUNT ON --DECLARE @UID INT DECLARE @C_HP INT, @C_MP INT /* ij¸¯ÅÍ À̸§ È®ÀÎ */ SELECT @CID = CID FROM CharInfo WHERE Name = @user_name IF @CID <> 0 BEGIN SET @CID = -1 /* µ¿ÀÏ À̸§ Á¸Àç */ RETURN END /* ½½·Ô È®ÀÎ */ DECLARE @CharSlot INT IF @user_pos = 0 BEGIN SELECT @CharSlot = Char1 FROM UserInfo WHERE UID = @user_uid AND OldServerGroupID = @UserInfoType END ELSE IF @user_pos = 1 BEGIN SELECT @CharSlot = Char2 FROM UserInfo WHERE UID = @user_uid AND OldServerGroupID = @UserInfoType END ELSE IF @user_pos = 2 BEGIN SELECT @CharSlot = Char3 FROM UserInfo WHERE UID = @user_uid AND OldServerGroupID = @UserInfoType END ELSE IF @user_pos = 3 BEGIN SELECT @CharSlot = Char4 FROM UserInfo WHERE UID = @user_uid AND OldServerGroupID = @UserInfoType END ELSE IF @user_pos = 4 BEGIN SELECT @CharSlot = Char5 FROM UserInfo WHERE UID = @user_uid AND OldServerGroupID = @UserInfoType END IF @CharSlot <> 0 BEGIN SET @CID = -2 /* ½½·ÔÀÌ Â÷ÀÖÀ½ */ RETURN END SET @C_HP = 100 + @C_CON * 8 + 2 IF @C_INT > @C_WIS BEGIN SET @C_MP = 100 + @C_INT * 8 + 2 END ELSE BEGIN SET @C_MP = 100 + @C_WIS * 8 + 2 END BEGIN TRAN SELECT @CID = MAX(CID) + 1 FROM CharInfo WITH (UPDLOCK) IF (@CID IS NULL) SET @CID = 1 INSERT INTO CharInfo (CID,Name, Sex, Hair, Face, Race, Class, Equip, Gold, STR, DEX, CON, Intell, WIS, HP, MP) VALUES (@CID,@user_name, @user_Sex, @user_Hair, @user_Face, @user_Nation, @user_Class, @C_Equip, @C_Gold, @C_STR, @C_DEX, @C_CON, @C_INT, @C_WIS, @C_HP, @C_MP) IF @@ERROR <> 0 BEGIN ROLLBACK TRAN SET @CID = -100 RETURN END COMMIT TRAN INSERT INTO CharInfoEx (CID) VALUES (@CID) INSERT INTO CharItem (CID) VALUES (@CID) INSERT INTO CharItemEx (CID) VALUES (@CID) INSERT INTO CharSkill (CID, Skill) VALUES (@CID, @Skill) INSERT INTO CharSpell (CID) VALUES (@CID) INSERT INTO CharPos (CID, LastPointX, LastPointY, LastPointZ, SavePointX, SavePointY, SavePointZ) VALUES (@CID, @PointX, @PointY, @PointZ, @PointX, @PointY, @PointZ) INSERT INTO CharInfo_Time(CID,CreateTime,UpdateTime) VALUES (@CID,GETDATE(),GETDATE()) INSERT INTO Friend (CID) VALUES (@CID) INSERT INTO Quest (CID) VALUES (@CID) -- UnifiedCharListÁ¤º¸Å×ÀÌºí¿¡ ÀÔ·ÂÇϱâ INSERT TblUnifiedCharList(UID,OldServerGroupID,BeforeCID,NewCID,BeforeCharName) VALUES (@user_uid,@UserInfoType,@CID,@CID,@user_name) /* À¯Àú Á¤º¸ Å×ÀÌºí ¾÷µ¥ÀÌÆ® */ EXEC UpdateCharUID @user_uid, @user_pos, @CID , @UserInfoType GO