aboutsummaryrefslogtreecommitdiff
path: root/src/server/database/Updater/DBUpdater.cpp
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2022-01-30 15:50:35 +0100
committerShauren <shauren.trinity@gmail.com>2022-01-30 15:50:56 +0100
commitce4981b23f55eee427a850986ebbdd373d0683fe (patch)
treedb2c74f01377419c10b3ebbad0cfed8f33ec19e9 /src/server/database/Updater/DBUpdater.cpp
parent50178650b2d1c123c40aa4d7ed3ecf3d7fefa00d (diff)
Core/DBUpdater: Apply each sql update file in a separate transaction
(cherry picked from commit b79a91039bba12d62e43806d8a20ad76107ac5d7)
Diffstat (limited to 'src/server/database/Updater/DBUpdater.cpp')
-rw-r--r--src/server/database/Updater/DBUpdater.cpp8
1 files changed, 6 insertions, 2 deletions
diff --git a/src/server/database/Updater/DBUpdater.cpp b/src/server/database/Updater/DBUpdater.cpp
index 3c4d52a2639..c61aa506f7b 100644
--- a/src/server/database/Updater/DBUpdater.cpp
+++ b/src/server/database/Updater/DBUpdater.cpp
@@ -332,7 +332,7 @@ void DBUpdater<T>::ApplyFile(DatabaseWorkerPool<T>& pool, std::string const& hos
Path const& path)
{
std::vector<std::string> args;
- args.reserve(7);
+ args.reserve(9);
// CLI Client connection info
args.emplace_back("-h" + host);
@@ -382,13 +382,17 @@ void DBUpdater<T>::ApplyFile(DatabaseWorkerPool<T>& pool, std::string const& hos
#endif
+ // Execute sql file
+ args.emplace_back("-e");
+ args.emplace_back(Trinity::StringFormat("BEGIN; SOURCE %s; COMMIT;", path.generic_string().c_str()));
+
// Database
if (!database.empty())
args.emplace_back(database);
// Invokes a mysql process which doesn't leak credentials to logs
int const ret = Trinity::StartProcess(DBUpdaterUtil::GetCorrectedMySQLExecutable(), args,
- "sql.updates", path.generic_string(), true);
+ "sql.updates", "", true);
if (ret != EXIT_SUCCESS)
{