implement atomic group insertion

This commit is contained in:
Luck 2017-04-22 22:53:29 +01:00
parent 4382d5c56d
commit 7bfd5d4bc8
No known key found for this signature in database
GPG Key ID: EFA9B3EC5FD90F8B

View File

@ -96,7 +96,10 @@ public class SQLBacking extends AbstractBacking {
private static final String GROUP_PERMISSIONS_SELECT_PERMISSION = "SELECT name, value, server, world, expiry, contexts FROM {prefix}group_permissions WHERE permission=?"; private static final String GROUP_PERMISSIONS_SELECT_PERMISSION = "SELECT name, value, server, world, expiry, contexts FROM {prefix}group_permissions WHERE permission=?";
private static final String GROUP_SELECT_ALL = "SELECT name FROM {prefix}groups"; private static final String GROUP_SELECT_ALL = "SELECT name FROM {prefix}groups";
private static final String GROUP_INSERT = "INSERT INTO {prefix}groups VALUES(?)"; private static final String MYSQL_GROUP_INSERT = "INSERT INTO {prefix}groups (name) VALUES(?) ON DUPLICATE KEY UPDATE name=name";
private static final String H2_GROUP_INSERT = "MERGE INTO {prefix}groups (name) VALUES(?)";
private static final String SQLITE_GROUP_INSERT = "INSERT OR IGNORE INTO {prefix}groups (name) VALUES(?)";
private static final String POSTGRESQL_GROUP_INSERT = "INSERT INTO {prefix}groups (name) VALUES(?) ON CONFLICT (name) DO NOTHING";
private static final String GROUP_DELETE = "DELETE FROM {prefix}groups WHERE name=?"; private static final String GROUP_DELETE = "DELETE FROM {prefix}groups WHERE name=?";
private static final String TRACK_INSERT = "INSERT INTO {prefix}tracks VALUES(?, ?)"; private static final String TRACK_INSERT = "INSERT INTO {prefix}tracks VALUES(?, ?)";
@ -537,30 +540,30 @@ public class SQLBacking extends AbstractBacking {
@Override @Override
public boolean createAndLoadGroup(String name) { public boolean createAndLoadGroup(String name) {
List<String> groups = new ArrayList<>(); String query;
try (Connection c = provider.getConnection()) { switch (provider.getName()) {
try (PreparedStatement ps = c.prepareStatement(prefix.apply(GROUP_SELECT_ALL))) { case "H2":
try (ResultSet rs = ps.executeQuery()) { query = H2_GROUP_INSERT;
while (rs.next()) { break;
groups.add(rs.getString("name").toLowerCase()); case "SQLite":
} query = SQLITE_GROUP_INSERT;
} break;
case "PostgreSQL":
query = POSTGRESQL_GROUP_INSERT;
break;
default:
query = MYSQL_GROUP_INSERT;
break;
} }
} catch (SQLException e) {
e.printStackTrace();
return false;
}
if (!groups.contains(name)) {
try (Connection c = provider.getConnection()) { try (Connection c = provider.getConnection()) {
try (PreparedStatement ps = c.prepareStatement(prefix.apply(GROUP_INSERT))) { try (PreparedStatement ps = c.prepareStatement(prefix.apply(query))) {
ps.setString(1, name); ps.setString(1, name);
ps.execute(); ps.execute();
} }
} catch (SQLException e) { } catch (SQLException e) {
e.printStackTrace(); e.printStackTrace();
} return false;
} }
return loadGroup(name); return loadGroup(name);