123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315 |
- package me.km.databank;
- import java.sql.Connection;
- import java.sql.ResultSet;
- import java.sql.SQLException;
- import java.sql.Statement;
- import java.util.ArrayList;
- import me.km.api.Module;
- import me.km.snuviscript.ScriptUtils;
- import me.km.table.Table;
- public abstract class SimpleDataBank
- {
- private final Connection c;
- private final Module m;
-
- public SimpleDataBank(Module m, Connection c)
- {
- this.c = c;
- this.m = m;
-
- init();
- }
-
- public Module getModule()
- {
- return m;
- }
-
- protected abstract void init();
-
- /** Führt den gegebenen Query aus und gibt den Erfolg zurück.
- *
- * @param query ein Query, irgendetwas mit "INSERT, UPDATE, ..."
- * @param ignore gibt keine Fehlermeldung aus, falls auf <code> true </code>
- * @return <code> true </code> falls kein Error auftrat, sonst <code> false </code>
- */
-
- public boolean update(String query, boolean ignore)
- {
- try(Statement stmt = c.createStatement())
- {
- stmt.executeUpdate(query);
- return true;
- }
- catch(SQLException ex)
- {
- if(!ignore)
- {
- m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
- m.sendWarningToConsole(query);
- m.sendWarningToConsole(ex.toString());
- }
- return false;
- }
- }
-
- /** Führt den gegebenen Query aus und gibt die erste Spalte der ersten Reihe zurück.
- *
- * @param <T> die Klasse der Rückgabe
- * @param query ein Query, irgendetwas mit "SELECT"
- * @param r die Klasse der Rückgabe
- * @return das gewünschte Objekt, null falls ein Fehler auftrat oder der ResultSet leer ist
- */
- @SuppressWarnings("unchecked")
- public <T> T getFirst(String query, Class<T> r)
- {
- //System.out.println(query);
- try(Statement stmt = c.createStatement();)
- {
- ResultSet rs = stmt.executeQuery(query);
- if(rs.next())
- {
- return (T) rs.getObject(1);
- }
- return null;
- }
- catch(SQLException ex)
- {
- m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
- m.sendWarningToConsole(query);
- m.sendWarningToConsole(ex.toString());
- return null;
- }
- }
-
- /** Führt den gegebenen Query aus und gibt die erste Spalte der ersten Reihe zurück.
- *
- * @param query ein Query, irgendetwas mit "SELECT"
- * @return der gewünschte Byte, null falls ein Fehler auftrat oder der ResultSet leer ist
- */
- public Byte getFirstByte(String query)
- {
- //System.out.println(query);
- try(Statement stmt = c.createStatement();)
- {
- ResultSet rs = stmt.executeQuery(query);
- if(rs.next())
- {
- return rs.getByte(1);
- }
- return null;
- }
- catch(SQLException ex)
- {
- m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
- m.sendWarningToConsole(query);
- m.sendWarningToConsole(ex.toString());
- return null;
- }
- }
-
- /** Führt den gegebenen Query aus und gibt alle Spalten der ersten Reihe zurück.
- *
- * @param query ein Query, irgendetwas mit "SELECT"
- * @return alle Spalten als Liste, bei einem Error kann sie null sein
- */
- @SuppressWarnings("unchecked")
- public ArrayList<Object> getFirstRow(String query)
- {
- //System.out.println(query);
- ArrayList<Object> list = new ArrayList();
- try(Statement stmt = c.createStatement();)
- {
- ResultSet rs = stmt.executeQuery(query);
- if(rs.next())
- {
- int i = 1;
- while(true)
- {
- list.add(rs.getObject(i));
- i++;
- }
- }
- return list;
- }
- catch(SQLException ex)
- {
- if(!ex.getLocalizedMessage().startsWith("Column Index"))
- {
- m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
- m.sendWarningToConsole(query);
- m.sendWarningToConsole(ex.toString());
- return null;
- }
- return list;
- }
- }
- /** Führt den gegebenen Query aus und gibt alle Zeilen der ersten Spalte zurück.
- *
- * @param query ein Query, irgendetwas mit "SELECT"
- * @return alle Spalten als Liste, bei einem Error kann sie null sein
- */
- @SuppressWarnings("unchecked")
- public ArrayList<Object> getFirstColumn(String query)
- {
- //System.out.println(query);
- ArrayList<Object> list = new ArrayList();
- try(Statement stmt = c.createStatement();)
- {
- ResultSet rs = stmt.executeQuery(query);
- while(rs.next())
- {
- list.add(rs.getObject(1));
- }
- return list;
- }
- catch(SQLException ex)
- {
- m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
- m.sendWarningToConsole(query);
- m.sendWarningToConsole(ex.toString());
- return null;
- }
- catch(IllegalStateException ex)
- {
- return list;
- }
- }
-
- /** Führt den gegebenen Query aus und gibt alle Zeilen der ersten Spalte zurück.
- *
- * @param query ein Query, irgendetwas mit "SELECT"
- * @return alle Spalten als Liste, bei einem Error kann sie null sein
- */
- @SuppressWarnings("unchecked")
- public ArrayList<Byte> getFirstByteColumn(String query)
- {
- //System.out.println(query);
- ArrayList<Byte> list = new ArrayList();
- try(Statement stmt = c.createStatement();)
- {
- ResultSet rs = stmt.executeQuery(query);
- while(rs.next())
- {
- list.add(rs.getByte(1));
- }
- return list;
- }
- catch(SQLException ex)
- {
- m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
- m.sendWarningToConsole(query);
- m.sendWarningToConsole(ex.toString());
- return null;
- }
- catch(IllegalStateException ex)
- {
- return list;
- }
- }
-
- /** Führt den gegebenen Query aus und gibt alle Spalten als Liste in einer Liste zurück.
- *
- * @param query ein Query, irgendetwas mit "SELECT"
- * @return alle Spalten als Liste in einer Liste, bei einem Error kann sie null sein
- */
- @SuppressWarnings("unchecked")
- public ArrayList<ArrayList<Object>> get(String query)
- {
- //System.out.println(query);
- ArrayList<ArrayList<Object>> list = new ArrayList();
- try(Statement stmt = c.createStatement();)
- {
- ResultSet rs = stmt.executeQuery(query);
- while(rs.next())
- {
- ArrayList<Object> columns = new ArrayList();
- try
- {
- int i = 1;
- while(true)
- {
- columns.add(rs.getObject(i));
- i++;
- }
- }
- catch(SQLException ex)
- {
- if(!ex.getLocalizedMessage().startsWith("Column Index"))
- {
- m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
- m.sendWarningToConsole(query);
- m.sendWarningToConsole(ex.toString());
- return null;
- }
- }
- list.add(columns);
- }
- return list;
- }
- catch(SQLException ex)
- {
- m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
- m.sendWarningToConsole(query);
- m.sendWarningToConsole(ex.toString());
- return null;
- }
- catch(IllegalStateException ex)
- {
- return list;
- }
- }
-
- /** Führt den gegebenen Query aus und gibt zwei Spalten als Table zurück.
- *
- * @param query ein Query, irgendetwas mit "SELECT"
- * @return zwei Spalten als List-Map, bei einem Error kann sie null sein
- */
- public Table getTable(String query)
- {
- Table table = new Table(2);
- try(Statement stmt = c.createStatement();)
- {
- ResultSet rs = stmt.executeQuery(query);
- while(rs.next())
- {
- table.addRow(new Object[] {rs.getString(1), ScriptUtils.convertInput(rs.getString(2))});
- }
- return table;
- }
- catch(SQLException ex)
- {
- m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
- m.sendWarningToConsole(query);
- m.sendWarningToConsole(ex.toString());
- return null;
- }
- catch(IllegalStateException ex)
- {
- return table;
- }
- }
-
- /** Gibt zurück, ob eine Tabelle existiert oder nicht.
- *
- * @param table der Name der Tabelle
- * @return <code> true </code> falls die Tabelle existiert, sonst <code> false </code>
- */
- public boolean doesTableExist(String table)
- {
- try(Statement stmt = c.createStatement();)
- {
- return stmt.executeQuery("SHOW TABLES IN minecraft LIKE '" + table + "';").next();
- }
- catch(SQLException ex)
- {
- m.sendWarningToConsole("Der folgende Query hat einen Error ausgelöst:");
- m.sendWarningToConsole("SHOW TABLES LIKE '" + table + "';");
- m.sendWarningToConsole(ex.toString());
- return false;
- }
- }
- }
|