diff options
author | Xanadu <none@none> | 2010-12-23 05:49:23 +0100 |
---|---|---|
committer | Xanadu <none@none> | 2010-12-23 05:49:23 +0100 |
commit | cfa26522adccff5c42ce34668783ad50d6f3af59 (patch) | |
tree | b794fc706934ad6ce3ec8aee2224f14d452c0267 /src/server/shared/Database/Implementation | |
parent | 66b4c8003c8b6ed4b826ba5b0da512f4dd073f68 (diff) |
Core: Fixed occasional wrong order of async operations at respawn time saving. Closes issue #5239.
DB schema: Sorted out a discrepancy in respawn time column format.
--HG--
branch : trunk
Diffstat (limited to 'src/server/shared/Database/Implementation')
-rwxr-xr-x | src/server/shared/Database/Implementation/CharacterDatabase.cpp | 8 | ||||
-rwxr-xr-x | src/server/shared/Database/Implementation/CharacterDatabase.h | 8 |
2 files changed, 10 insertions, 6 deletions
diff --git a/src/server/shared/Database/Implementation/CharacterDatabase.cpp b/src/server/shared/Database/Implementation/CharacterDatabase.cpp index 63cbac6ead0..598223415c0 100755 --- a/src/server/shared/Database/Implementation/CharacterDatabase.cpp +++ b/src/server/shared/Database/Implementation/CharacterDatabase.cpp @@ -237,9 +237,11 @@ bool CharacterDatabaseConnection::Open() PrepareStatement(CHAR_CLEAN_GUILD_BANK_TABS, "DELETE FROM guild_bank_tab WHERE guildId NOT IN (SELECT guildid FROM guild)", true); PrepareStatement(CHAR_CLEAN_GUILD_BANK_RIGHTS, "DELETE FROM guild_bank_right WHERE guildId NOT IN (SELECT guildid FROM guild)", true); PrepareStatement(CHAR_CLEAN_GUILD_BANK_ITEMS, "DELETE FROM guild_bank_item WHERE guildId NOT IN (SELECT guildid FROM guild)", true); - PrepareStatement(CHAR_DEL_GAMEOBJECT_RESPAWN_TIMES, "DELETE FROM gameobject_respawn WHERE respawntime <= UNIX_TIMESTAMP(NOW())", true); - PrepareStatement(CHAR_DEL_CRESPAWNTIME, "DELETE FROM creature_respawn WHERE guid = ? AND instance = ?", true); - PrepareStatement(CHAR_ADD_CRESPAWNTIME, "INSERT INTO creature_respawn VALUES (?, ?, ?)", true); + PrepareStatement(CHAR_DEL_CREATURE_RESPAWN_TIME, "DELETE FROM creature_respawn WHERE guid = ? AND instance = ?", true); + PrepareStatement(CHAR_ADD_CREATURE_RESPAWN_TIME, "REPLACE INTO creature_respawn VALUES (?, ?, ?)", true); + PrepareStatement(CHAR_DEL_EXPIRED_GO_RESPAWN_TIMES, "DELETE FROM gameobject_respawn WHERE respawntime <= UNIX_TIMESTAMP()"); + PrepareStatement(CHAR_DEL_GO_RESPAWN_TIME, "DELETE FROM gameobject_respawn WHERE guid = ? AND instance = ?", true); + PrepareStatement(CHAR_ADD_GO_RESPAWN_TIME, "REPLACE INTO gameobject_respawn VALUES (?, ?, ?)", true); // Chat channel handling PrepareStatement(CHAR_LOAD_CHANNEL, "SELECT m_announce, m_ownership, m_password, BannedList FROM channels WHERE m_name = ? AND m_team = ?"); diff --git a/src/server/shared/Database/Implementation/CharacterDatabase.h b/src/server/shared/Database/Implementation/CharacterDatabase.h index e9b83fcfad8..3d203bf67e3 100755 --- a/src/server/shared/Database/Implementation/CharacterDatabase.h +++ b/src/server/shared/Database/Implementation/CharacterDatabase.h @@ -196,9 +196,11 @@ enum CharacterDatabaseStatements CHAR_CLEAN_GUILD_BANK_RIGHTS, CHAR_CLEAN_GUILD_BANK_ITEMS, - CHAR_DEL_GAMEOBJECT_RESPAWN_TIMES, - CHAR_DEL_CRESPAWNTIME, - CHAR_ADD_CRESPAWNTIME, + CHAR_DEL_CREATURE_RESPAWN_TIME, + CHAR_ADD_CREATURE_RESPAWN_TIME, + CHAR_DEL_EXPIRED_GO_RESPAWN_TIMES, + CHAR_DEL_GO_RESPAWN_TIME, + CHAR_ADD_GO_RESPAWN_TIME, CHAR_LOAD_CHANNEL, CHAR_ADD_CHANNEL, |