1
0
mirror of https://github.com/Zrips/Jobs.git synced 2025-01-23 16:41:25 +01:00

Improve database loading

This commit is contained in:
montlikadani 2020-04-13 17:44:14 +02:00
parent a9c94d36d8
commit 47280b04d0
5 changed files with 62 additions and 98 deletions

View File

@ -59,6 +59,7 @@ import org.bukkit.plugin.java.JavaPlugin;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.sql.SQLException;
import java.util.*; import java.util.*;
import java.util.Map.Entry; import java.util.Map.Entry;
import java.util.logging.Logger; import java.util.logging.Logger;
@ -510,9 +511,31 @@ public class Jobs extends JavaPlugin {
/** /**
* Executes close connections * Executes close connections
*/ */
public static void ChangeDatabase() { public static void convertDatabase() {
getDBManager().switchDataBase(); try {
getPlayerManager().reload(); List<Convert> archivelist = dao.convertDatabase();
getDBManager().switchDataBase();
getPlayerManager().reload();
dao.truncateAllTables();
getPlayerManager().convertChacheOfPlayers(true);
dao.continueConvertions(archivelist);
getPlayerManager().clearMaps();
getPlayerManager().clearCache();
dao.saveExplore();
// Do we really need to convert Block protection?
// Jobs.getJobsDAO().saveBlockProtection();
} catch (SQLException e) {
e.printStackTrace();
Jobs.consoleMsg("&cCan't write data to data base, please send error log to dev's.");
return;
}
reload();
loadAllPlayersData();
} }
/** /**
@ -592,14 +615,6 @@ public class Jobs extends JavaPlugin {
@Override @Override
public void onEnable() { public void onEnable() {
instance = this; instance = this;
setEnabled(true);
if (instance == null) {
System.out.println("Plugin instance is null. Plugin will be disabled.");
System.out.println("Try restart your server completely. If this not work contact the developers.");
setEnabled(false);
return;
}
// itemManager = new ItemManager(this); // itemManager = new ItemManager(this);
@ -625,7 +640,6 @@ public class Jobs extends JavaPlugin {
} }
try { try {
YmlMaker jobConfig = new YmlMaker(this, "jobConfig.yml"); YmlMaker jobConfig = new YmlMaker(this, "jobConfig.yml");
jobConfig.saveDefaultConfig(); jobConfig.saveDefaultConfig();
@ -673,7 +687,6 @@ public class Jobs extends JavaPlugin {
getCommandManager().fillCommands(); getCommandManager().fillCommands();
getDBManager().getDB().triggerTableIdUpdate(); getDBManager().getDB().triggerTableIdUpdate();
} catch (Throwable e) { } catch (Throwable e) {
e.printStackTrace(); e.printStackTrace();
System.out.println("There was some issues when starting plugin. Please contact dev about this. Plugin will be disabled."); System.out.println("There was some issues when starting plugin. Please contact dev about this. Plugin will be disabled.");
@ -727,11 +740,7 @@ public class Jobs extends JavaPlugin {
getGCManager().reload(); getGCManager().reload();
getLanguage().reload(); getLanguage().reload();
try { getConfigManager().reload();
getConfigManager().reload();
} catch (IOException e) {
e.printStackTrace();
}
getDBManager().getDB().loadAllJobsWorlds(); getDBManager().getDB().loadAllJobsWorlds();
getDBManager().getDB().loadAllJobsNames(); getDBManager().getDB().loadAllJobsNames();
@ -740,7 +749,7 @@ public class Jobs extends JavaPlugin {
ToggleBarHandling.load(); ToggleBarHandling.load();
usedSlots.clear(); usedSlots.clear();
for (Job job : jobs) { for (Job job : jobs) {
usedSlots.put(job, dao.getSlotsTaken(job)); usedSlots.put(job, getDBManager().getDB().getSlotsTaken(job));
} }
getPlayerManager().reload(); getPlayerManager().reload();
getPermissionHandler().registerPermissions(); getPermissionHandler().registerPermissions();
@ -755,7 +764,7 @@ public class Jobs extends JavaPlugin {
paymentThread = new BufferedPaymentThread(getGCManager().getEconomyBatchDelay()); paymentThread = new BufferedPaymentThread(getGCManager().getEconomyBatchDelay());
paymentThread.start(); paymentThread.start();
dao.loadPlayerData(); getDBManager().getDB().loadPlayerData();
// Schedule // Schedule
if (getGCManager().enableSchedule) { if (getGCManager().enableSchedule) {
@ -771,17 +780,14 @@ public class Jobs extends JavaPlugin {
if (instance == null) if (instance == null)
return; return;
try { // GUIManager.CloseInventories();
// GUIManager.CloseInventories(); // shopManager.CloseInventories();
// shopManager.CloseInventories(); dao.saveExplore();
dao.saveExplore();
getBpManager().saveCache();
FurnaceBrewingHandling.save();
ToggleBarHandling.save();
getBpManager().saveCache();
FurnaceBrewingHandling.save();
ToggleBarHandling.save();
} catch (Throwable e) {
e.printStackTrace();
}
shutdown(); shutdown();
instance = null; instance = null;
consoleMsg("&e[Jobs] &2Plugin has been disabled successfully."); consoleMsg("&e[Jobs] &2Plugin has been disabled successfully.");

View File

@ -114,8 +114,7 @@ public class PlayerManager {
public void addPlayerToMap(PlayerInfo info) { public void addPlayerToMap(PlayerInfo info) {
PlayerUUIDMap.put(info.getUuid(), info); PlayerUUIDMap.put(info.getUuid(), info);
PlayerIDMap.put(info.getID(), info); PlayerIDMap.put(info.getID(), info);
if (info.getName() != null) PlayerNameMap.put(info.getName().toLowerCase(), info);
PlayerNameMap.put(info.getName().toLowerCase(), info);
} }
public void addPlayerToCache(JobsPlayer jPlayer) { public void addPlayerToCache(JobsPlayer jPlayer) {

View File

@ -1,8 +1,5 @@
package com.gamingmesh.jobs.commands.list; package com.gamingmesh.jobs.commands.list;
import java.sql.SQLException;
import java.util.List;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@ -10,7 +7,6 @@ import org.bukkit.entity.Player;
import com.gamingmesh.jobs.Jobs; import com.gamingmesh.jobs.Jobs;
import com.gamingmesh.jobs.commands.Cmd; import com.gamingmesh.jobs.commands.Cmd;
import com.gamingmesh.jobs.commands.JobCommand; import com.gamingmesh.jobs.commands.JobCommand;
import com.gamingmesh.jobs.container.Convert;
import com.gamingmesh.jobs.dao.JobsManager.DataBaseType; import com.gamingmesh.jobs.dao.JobsManager.DataBaseType;
public class convert implements Cmd { public class convert implements Cmd {
@ -28,41 +24,7 @@ public class convert implements Cmd {
return true; return true;
} }
Bukkit.getScheduler().runTaskAsynchronously(plugin, new Runnable() { Bukkit.getScheduler().runTaskAsynchronously(plugin, () -> Jobs.convertDatabase());
@Override
public void run() {
List<Convert> archivelist = null;
try {
archivelist = Jobs.getJobsDAO().convertDatabase();
} catch (SQLException e) {
e.printStackTrace();
Jobs.consoleMsg("&cCan't write data to data base, please send error log to dev's.");
return;
}
Jobs.ChangeDatabase();
try {
Jobs.getJobsDAO().truncateAllTables();
Jobs.getPlayerManager().convertChacheOfPlayers(true);
Jobs.getJobsDAO().continueConvertions(archivelist);
Jobs.getPlayerManager().clearMaps();
Jobs.getPlayerManager().clearCache();
Jobs.getJobsDAO().saveExplore();
// Do we really need to convert Block protection?
// Jobs.getJobsDAO().saveBlockProtection();
} catch (SQLException e) {
e.printStackTrace();
Jobs.consoleMsg("&cCan't write data to data base, please send error log to dev's.");
return;
}
Jobs.reload();
Jobs.loadAllPlayersData();
}
});
String from = "MySQL"; String from = "MySQL";
String to = "SQLite"; String to = "SQLite";

View File

@ -269,9 +269,13 @@ public class ConfigManager {
cfg.save(); cfg.save();
} }
public void reload() throws IOException { public void reload() {
// job settings // job settings
loadJobSettings(); try {
loadJobSettings();
} catch (IOException e) {
e.printStackTrace();
}
} }
public YamlConfiguration getJobConfig() { public YamlConfiguration getJobConfig() {

View File

@ -649,21 +649,20 @@ public abstract class JobsDAO {
res = prest.executeQuery(); res = prest.executeQuery();
while (res.next()) { while (res.next()) {
int id = res.getInt(JobsTableFields.userid.getCollumn()); int id = res.getInt(JobsTableFields.userid.getCollumn());
List<JobsDAOData> ls = map.get(id); String jobName = res.getString(JobsTableFields.job.getCollumn());
if (ls == null) List<JobsDAOData> ls = new ArrayList<>();
ls = new ArrayList<>();
int jobId = res.getInt(JobsTableFields.jobid.getCollumn()); int jobId = res.getInt(JobsTableFields.jobid.getCollumn());
if (jobId == 0) { if (jobId == 0) {
ls.add(new JobsDAOData(res.getString(JobsTableFields.job.getCollumn()), res.getInt(JobsTableFields.level.getCollumn()), res.getDouble(JobsTableFields.experience.getCollumn()))); ls.add(new JobsDAOData(jobName, res.getInt(JobsTableFields.level.getCollumn()), res.getDouble(JobsTableFields.experience.getCollumn())));
converted = false; converted = false;
} else { } else {
// This should be removed when we switch over to id only method // This should be removed when we switch over to id only method
if (converted) if (converted)
if (res.getString(JobsTableFields.job.getCollumn()) == null || res.getString(JobsTableFields.job.getCollumn()).isEmpty()) if (jobName == null || jobName.isEmpty())
converted = false; converted = false;
Job job = Jobs.getJob(jobId); Job job = Jobs.getJob(jobName);
if (job != null) if (job != null)
ls.add(new JobsDAOData(job.getName(), res.getInt(JobsTableFields.level.getCollumn()), res.getDouble(JobsTableFields.experience.getCollumn()))); ls.add(new JobsDAOData(job.getName(), res.getInt(JobsTableFields.level.getCollumn()), res.getDouble(JobsTableFields.experience.getCollumn())));
} }
@ -1479,13 +1478,7 @@ public abstract class JobsDAO {
String jobName = res.getString(ArchiveTableFields.job.getCollumn()); String jobName = res.getString(ArchiveTableFields.job.getCollumn());
int jobid = res.getInt(ArchiveTableFields.jobid.getCollumn()); int jobid = res.getInt(ArchiveTableFields.jobid.getCollumn());
Job job = null; Job job = jobid != 0 ? Jobs.getJob(jobid) : Jobs.getJob(jobName);
if (jobid != 0) {
job = Jobs.getJob(jobid);
} else {
job = Jobs.getJob(jobName);
}
if (job == null) if (job == null)
continue; continue;
@ -1740,27 +1733,26 @@ public abstract class JobsDAO {
public void loadPlayerData() { public void loadPlayerData() {
Jobs.getPlayerManager().clearMaps(); Jobs.getPlayerManager().clearMaps();
JobsConnection conn = getConnection(); JobsConnection conn = getConnection();
if (conn == null) if (conn == null)
return; return;
PreparedStatement prest = null; PreparedStatement prest = null;
ResultSet res = null; ResultSet res = null;
try { try {
prest = conn.prepareStatement("SELECT * FROM `" + DBTables.UsersTable.getTableName() + "`;"); prest = conn.prepareStatement("SELECT * FROM `" + DBTables.UsersTable.getTableName() + "`;");
res = prest.executeQuery(); res = prest.executeQuery();
while (res.next()) { while (res.next()) {
long seen = System.currentTimeMillis(); long seen = res.getLong(UserTableFields.seen.getCollumn());
try {
seen = res.getLong(UserTableFields.seen.getCollumn()); Jobs.getPlayerManager().addPlayerToMap(new PlayerInfo(
Jobs.getPlayerManager().addPlayerToMap(new PlayerInfo( res.getString(UserTableFields.username.getCollumn()),
res.getString(UserTableFields.username.getCollumn()), res.getInt("id"),
res.getInt("id"), UUID.fromString(res.getString(UserTableFields.player_uuid.getCollumn())),
UUID.fromString(res.getString(UserTableFields.player_uuid.getCollumn())), seen,
seen, res.getInt(UserTableFields.donequests.getCollumn()),
res.getInt(UserTableFields.donequests.getCollumn()), res.getString(UserTableFields.quests.getCollumn())));
res.getString(UserTableFields.quests.getCollumn())));
} catch (Exception e) {
}
} }
} catch (SQLException e) { } catch (SQLException e) {
e.printStackTrace(); e.printStackTrace();
@ -1768,6 +1760,7 @@ public abstract class JobsDAO {
close(res); close(res);
close(prest); close(prest);
} }
return; return;
} }