mirror of
https://github.com/songoda/SongodaCore.git
synced 2025-01-24 16:21:23 +01:00
Fixes getNextId method for empty databases. Adds some new saving methods. TODO: clean up this class
This commit is contained in:
parent
9d94232ab5
commit
54ef2c0b29
@ -51,8 +51,6 @@ public class DataManager {
|
|||||||
@Deprecated
|
@Deprecated
|
||||||
private static final Map<String, LinkedList<Runnable>> queues = new HashMap<>();
|
private static final Map<String, LinkedList<Runnable>> queues = new HashMap<>();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
DataManager() {
|
DataManager() {
|
||||||
this.databaseConfig = null;
|
this.databaseConfig = null;
|
||||||
this.plugin = null;
|
this.plugin = null;
|
||||||
@ -233,27 +231,50 @@ public class DataManager {
|
|||||||
// }, () -> this.autoIncrementCache.put(prefixedTable, new AtomicInteger(1)));
|
// }, () -> this.autoIncrementCache.put(prefixedTable, new AtomicInteger(1)));
|
||||||
//
|
//
|
||||||
//recreate upper method using java 8 syntax
|
//recreate upper method using java 8 syntax
|
||||||
|
try {
|
||||||
Optional<Integer> max = context.select(DSL.max(DSL.field("id"))).from(prefixedTable).fetchOptional().map(record -> record.get(0, Integer.class));
|
Optional<Integer> max = context.select(DSL.max(DSL.field("id"))).from(prefixedTable).fetchOptional().map(record -> record.get(0, Integer.class));
|
||||||
this.autoIncrementCache.put(prefixedTable, new AtomicInteger(max.orElse(1)));
|
this.autoIncrementCache.put(prefixedTable, new AtomicInteger(max.orElse(1)));
|
||||||
|
} catch (Exception e) {
|
||||||
|
//Table is empty
|
||||||
|
this.autoIncrementCache.put(prefixedTable, new AtomicInteger(1));
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
return this.autoIncrementCache.get(prefixedTable).incrementAndGet();
|
return this.autoIncrementCache.get(prefixedTable).incrementAndGet();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//TODO: Fix/create javadocs for all methods
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Saves the data to the database
|
* Saves the data to the database
|
||||||
*/
|
*/
|
||||||
public void save(Data data) {
|
public void save(Data data) {
|
||||||
asyncPool.execute(() -> {
|
asyncPool.execute(() -> {
|
||||||
|
saveSync(data);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Saves the data to the database
|
||||||
|
*/
|
||||||
|
public void save(Data data, String idField, Object idValue) {
|
||||||
|
asyncPool.execute(() -> {
|
||||||
|
saveSync(data, idField, idValue);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Saves the data to the database
|
||||||
|
*/
|
||||||
|
public void saveSync(Data data, String idField, Object idValue) {
|
||||||
databaseConnector.connectDSL(context -> {
|
databaseConnector.connectDSL(context -> {
|
||||||
context.insertInto(DSL.table(getTablePrefix() + data.getTableName()))
|
context.insertInto(DSL.table(getTablePrefix() + data.getTableName()))
|
||||||
.set(data.serialize())
|
.set(data.serialize())
|
||||||
.onConflict(data.getId() != -1 ? DSL.field("id") : DSL.field("uuid")).doUpdate()
|
.onConflict(DSL.field(idField)).doUpdate()
|
||||||
.set(data.serialize())
|
.set(data.serialize())
|
||||||
.where(data.getId() != -1 ? DSL.field("id").eq(data.getId()) : DSL.field("uuid").eq(data.getUniqueId().toString()))
|
.where(DSL.field(idField).eq(idValue))
|
||||||
.execute();
|
.execute();
|
||||||
});
|
});
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -275,18 +296,7 @@ public class DataManager {
|
|||||||
*/
|
*/
|
||||||
public void saveBatch(Collection<Data> dataBatch) {
|
public void saveBatch(Collection<Data> dataBatch) {
|
||||||
asyncPool.execute(() -> {
|
asyncPool.execute(() -> {
|
||||||
databaseConnector.connectDSL(context -> {
|
saveBatchSync(dataBatch);
|
||||||
List<Query> queries = new ArrayList<>();
|
|
||||||
for (Data data : dataBatch) {
|
|
||||||
queries.add(context.insertInto(DSL.table(getTablePrefix() + data.getTableName()))
|
|
||||||
.set(data.serialize())
|
|
||||||
.onConflict(data.getId() != -1 ? DSL.field("id") : DSL.field("uuid")).doUpdate()
|
|
||||||
.set(data.serialize())
|
|
||||||
.where(data.getId() != -1 ? DSL.field("id").eq(data.getId()) : DSL.field("uuid").eq(data.getUniqueId().toString())));
|
|
||||||
}
|
|
||||||
|
|
||||||
context.batch(queries).execute();
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -313,12 +323,19 @@ public class DataManager {
|
|||||||
*/
|
*/
|
||||||
public void delete(Data data) {
|
public void delete(Data data) {
|
||||||
asyncPool.execute(() -> {
|
asyncPool.execute(() -> {
|
||||||
|
deleteSync(data);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deletes the data from the database
|
||||||
|
*/
|
||||||
|
public void deleteSync(Data data) {
|
||||||
databaseConnector.connectDSL(context -> {
|
databaseConnector.connectDSL(context -> {
|
||||||
context.delete(DSL.table(getTablePrefix() + data.getTableName()))
|
context.delete(DSL.table(getTablePrefix() + data.getTableName()))
|
||||||
.where(data.getId() != -1 ? DSL.field("id").eq(data.getId()) : DSL.field("uuid").eq(data.getUniqueId().toString()))
|
.where(data.getId() != -1 ? DSL.field("id").eq(data.getId()) : DSL.field("uuid").eq(data.getUniqueId().toString()))
|
||||||
.execute();
|
.execute();
|
||||||
});
|
});
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user