SimpleDataBank.java 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315
  1. package me.km.databank;
  2. import java.sql.Connection;
  3. import java.sql.ResultSet;
  4. import java.sql.SQLException;
  5. import java.sql.Statement;
  6. import java.util.ArrayList;
  7. import me.hammerle.code.Code;
  8. import me.km.api.Module;
  9. import me.km.table.Table;
  10. public abstract class SimpleDataBank
  11. {
  12. private final DataBank c;
  13. private final Module m;
  14. public SimpleDataBank(Module m, DataBank c)
  15. {
  16. this.c = c;
  17. this.m = m;
  18. init();
  19. }
  20. public Module getModule()
  21. {
  22. return m;
  23. }
  24. protected abstract void init();
  25. /** Führt den gegebenen Query aus und gibt den Erfolg zurück.
  26. *
  27. * @param query ein Query, irgendetwas mit "INSERT, UPDATE, ..."
  28. * @param ignore gibt keine Fehlermeldung aus, falls auf <code> true </code>
  29. * @return <code> true </code> falls kein Error auftrat, sonst <code> false </code>
  30. */
  31. public boolean update(String query, boolean ignore)
  32. {
  33. try(Statement stmt = c.createStatement())
  34. {
  35. stmt.executeUpdate(query);
  36. return true;
  37. }
  38. catch(SQLException ex)
  39. {
  40. if(!ignore)
  41. {
  42. m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
  43. m.sendWarningToConsole(query);
  44. m.sendWarningToConsole(ex.toString());
  45. }
  46. return false;
  47. }
  48. }
  49. /** Führt den gegebenen Query aus und gibt die erste Spalte der ersten Reihe zurück.
  50. *
  51. * @param <T> die Klasse der Rückgabe
  52. * @param query ein Query, irgendetwas mit "SELECT"
  53. * @param r die Klasse der Rückgabe
  54. * @return das gewünschte Objekt, null falls ein Fehler auftrat oder der ResultSet leer ist
  55. */
  56. @SuppressWarnings("unchecked")
  57. public <T> T getFirst(String query, Class<T> r)
  58. {
  59. //System.out.println(query);
  60. try(Statement stmt = c.createStatement();)
  61. {
  62. ResultSet rs = stmt.executeQuery(query);
  63. if(rs.next())
  64. {
  65. return (T) rs.getObject(1);
  66. }
  67. return null;
  68. }
  69. catch(SQLException ex)
  70. {
  71. m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
  72. m.sendWarningToConsole(query);
  73. m.sendWarningToConsole(ex.toString());
  74. return null;
  75. }
  76. }
  77. /** Führt den gegebenen Query aus und gibt die erste Spalte der ersten Reihe zurück.
  78. *
  79. * @param query ein Query, irgendetwas mit "SELECT"
  80. * @return der gewünschte Byte, null falls ein Fehler auftrat oder der ResultSet leer ist
  81. */
  82. public Byte getFirstByte(String query)
  83. {
  84. //System.out.println(query);
  85. try(Statement stmt = c.createStatement();)
  86. {
  87. ResultSet rs = stmt.executeQuery(query);
  88. if(rs.next())
  89. {
  90. return rs.getByte(1);
  91. }
  92. return null;
  93. }
  94. catch(SQLException ex)
  95. {
  96. m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
  97. m.sendWarningToConsole(query);
  98. m.sendWarningToConsole(ex.toString());
  99. return null;
  100. }
  101. }
  102. /** Führt den gegebenen Query aus und gibt alle Spalten der ersten Reihe zurück.
  103. *
  104. * @param query ein Query, irgendetwas mit "SELECT"
  105. * @return alle Spalten als Liste, bei einem Error kann sie null sein
  106. */
  107. @SuppressWarnings("unchecked")
  108. public ArrayList<Object> getFirstRow(String query)
  109. {
  110. //System.out.println(query);
  111. ArrayList<Object> list = new ArrayList();
  112. try(Statement stmt = c.createStatement();)
  113. {
  114. ResultSet rs = stmt.executeQuery(query);
  115. if(rs.next())
  116. {
  117. int i = 1;
  118. while(true)
  119. {
  120. list.add(rs.getObject(i));
  121. i++;
  122. }
  123. }
  124. return list;
  125. }
  126. catch(SQLException ex)
  127. {
  128. if(!ex.getLocalizedMessage().startsWith("Column Index"))
  129. {
  130. m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
  131. m.sendWarningToConsole(query);
  132. m.sendWarningToConsole(ex.toString());
  133. return null;
  134. }
  135. return list;
  136. }
  137. }
  138. /** Führt den gegebenen Query aus und gibt alle Zeilen der ersten Spalte zurück.
  139. *
  140. * @param query ein Query, irgendetwas mit "SELECT"
  141. * @return alle Spalten als Liste, bei einem Error kann sie null sein
  142. */
  143. @SuppressWarnings("unchecked")
  144. public ArrayList<Object> getFirstColumn(String query)
  145. {
  146. //System.out.println(query);
  147. ArrayList<Object> list = new ArrayList();
  148. try(Statement stmt = c.createStatement();)
  149. {
  150. ResultSet rs = stmt.executeQuery(query);
  151. while(rs.next())
  152. {
  153. list.add(rs.getObject(1));
  154. }
  155. return list;
  156. }
  157. catch(SQLException ex)
  158. {
  159. m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
  160. m.sendWarningToConsole(query);
  161. m.sendWarningToConsole(ex.toString());
  162. return null;
  163. }
  164. catch(IllegalStateException ex)
  165. {
  166. return list;
  167. }
  168. }
  169. /** Führt den gegebenen Query aus und gibt alle Zeilen der ersten Spalte zurück.
  170. *
  171. * @param query ein Query, irgendetwas mit "SELECT"
  172. * @return alle Spalten als Liste, bei einem Error kann sie null sein
  173. */
  174. @SuppressWarnings("unchecked")
  175. public ArrayList<Byte> getFirstByteColumn(String query)
  176. {
  177. //System.out.println(query);
  178. ArrayList<Byte> list = new ArrayList();
  179. try(Statement stmt = c.createStatement();)
  180. {
  181. ResultSet rs = stmt.executeQuery(query);
  182. while(rs.next())
  183. {
  184. list.add(rs.getByte(1));
  185. }
  186. return list;
  187. }
  188. catch(SQLException ex)
  189. {
  190. m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
  191. m.sendWarningToConsole(query);
  192. m.sendWarningToConsole(ex.toString());
  193. return null;
  194. }
  195. catch(IllegalStateException ex)
  196. {
  197. return list;
  198. }
  199. }
  200. /** Führt den gegebenen Query aus und gibt alle Spalten als Liste in einer Liste zurück.
  201. *
  202. * @param query ein Query, irgendetwas mit "SELECT"
  203. * @return alle Spalten als Liste in einer Liste, bei einem Error kann sie null sein
  204. */
  205. @SuppressWarnings("unchecked")
  206. public ArrayList<ArrayList<Object>> get(String query)
  207. {
  208. //System.out.println(query);
  209. ArrayList<ArrayList<Object>> list = new ArrayList();
  210. try(Statement stmt = c.createStatement();)
  211. {
  212. ResultSet rs = stmt.executeQuery(query);
  213. while(rs.next())
  214. {
  215. ArrayList<Object> columns = new ArrayList();
  216. try
  217. {
  218. int i = 1;
  219. while(true)
  220. {
  221. columns.add(rs.getObject(i));
  222. i++;
  223. }
  224. }
  225. catch(SQLException ex)
  226. {
  227. if(!ex.getLocalizedMessage().startsWith("Column Index"))
  228. {
  229. m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
  230. m.sendWarningToConsole(query);
  231. m.sendWarningToConsole(ex.toString());
  232. return null;
  233. }
  234. }
  235. list.add(columns);
  236. }
  237. return list;
  238. }
  239. catch(SQLException ex)
  240. {
  241. m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
  242. m.sendWarningToConsole(query);
  243. m.sendWarningToConsole(ex.toString());
  244. return null;
  245. }
  246. catch(IllegalStateException ex)
  247. {
  248. return list;
  249. }
  250. }
  251. /** Führt den gegebenen Query aus und gibt zwei Spalten als Table zurück.
  252. *
  253. * @param query ein Query, irgendetwas mit "SELECT"
  254. * @return zwei Spalten als List-Map, bei einem Error kann sie null sein
  255. */
  256. public Table getTable(String query)
  257. {
  258. Table table = new Table(2);
  259. try(Statement stmt = c.createStatement();)
  260. {
  261. ResultSet rs = stmt.executeQuery(query);
  262. while(rs.next())
  263. {
  264. table.addRow(new Object[] {rs.getString(1), Code.convertInput(null, rs.getString(2), false)});
  265. }
  266. return table;
  267. }
  268. catch(SQLException ex)
  269. {
  270. m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
  271. m.sendWarningToConsole(query);
  272. m.sendWarningToConsole(ex.toString());
  273. return null;
  274. }
  275. catch(IllegalStateException ex)
  276. {
  277. return table;
  278. }
  279. }
  280. /** Gibt zurück, ob eine Tabelle existiert oder nicht.
  281. *
  282. * @param table der Name der Tabelle
  283. * @return <code> true </code> falls die Tabelle existiert, sonst <code> false </code>
  284. */
  285. public boolean doesTableExist(String table)
  286. {
  287. try(Statement stmt = c.createStatement();)
  288. {
  289. return stmt.executeQuery("SHOW TABLES IN minecraft LIKE '" + table + "';").next();
  290. }
  291. catch(SQLException ex)
  292. {
  293. m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
  294. m.sendWarningToConsole("SHOW TABLES LIKE '" + table + "';");
  295. m.sendWarningToConsole(ex.toString());
  296. return false;
  297. }
  298. }
  299. }