Added few Migrations
This commit is contained in:
parent
f6bb596455
commit
780bad6dbd
@ -1,31 +0,0 @@
|
||||
package data.source;
|
||||
|
||||
import data.SourceDataset;
|
||||
|
||||
public class QuestParticipationSource implements SourceDataset
|
||||
{
|
||||
private int questId;
|
||||
private int personId;
|
||||
|
||||
public QuestParticipationSource(int questId, int personId)
|
||||
{
|
||||
this.questId = questId;
|
||||
this.personId = personId;
|
||||
}
|
||||
|
||||
public int getPersonId()
|
||||
{
|
||||
return personId;
|
||||
}
|
||||
|
||||
public int getQuestId()
|
||||
{
|
||||
return questId;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString()
|
||||
{
|
||||
return String.format("QuestParticipation { %d, %d }", this.questId, this.personId);
|
||||
}
|
||||
}
|
@ -2,17 +2,23 @@ package data.source;
|
||||
|
||||
import data.SourceDataset;
|
||||
|
||||
import java.sql.Clob;
|
||||
import java.sql.SQLException;
|
||||
import java.util.Objects;
|
||||
|
||||
public class QuestSource implements SourceDataset
|
||||
{
|
||||
private int questId;
|
||||
private String name;
|
||||
private String dialogue;
|
||||
private Clob dialogue;
|
||||
private int personId;
|
||||
|
||||
public QuestSource(int questId, String name, String dialogue)
|
||||
public QuestSource(int questId, String name, Clob dialogue, int personId)
|
||||
{
|
||||
this.questId = questId;
|
||||
this.name = name;
|
||||
this.dialogue = dialogue;
|
||||
this.personId = personId;
|
||||
}
|
||||
|
||||
public int getQuestId()
|
||||
@ -25,14 +31,49 @@ public class QuestSource implements SourceDataset
|
||||
return name;
|
||||
}
|
||||
|
||||
public String getDialogue()
|
||||
public Clob getDialogue()
|
||||
{
|
||||
return dialogue;
|
||||
}
|
||||
|
||||
public int getPersonId()
|
||||
{
|
||||
return personId;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(Object o)
|
||||
{
|
||||
if (this == o)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
if (o == null || getClass() != o.getClass())
|
||||
{
|
||||
return false;
|
||||
}
|
||||
QuestSource that = (QuestSource) o;
|
||||
return questId == that.questId;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashCode()
|
||||
{
|
||||
return Objects.hash(questId);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString()
|
||||
{
|
||||
return String.format("Quest { %d, %s, %s... }", this.questId, this.name, this.dialogue.substring(0, 10));
|
||||
try
|
||||
{
|
||||
return String.format("Quest { %d, %s, %s..., %d }", this.questId, this.name, this.dialogue.getSubString(1, 10), this.personId);
|
||||
}
|
||||
catch (SQLException e)
|
||||
{
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
@ -7,9 +7,9 @@ public class AbilityTarget implements TargetDataset
|
||||
private int abilityId;
|
||||
private String abilityName;
|
||||
private String abilityDescription;
|
||||
private int abilityLevel;
|
||||
private float abilityLevel;
|
||||
|
||||
public AbilityTarget(int abilityId, String abilityName, String abilityDescription, int abilityLevel)
|
||||
public AbilityTarget(int abilityId, String abilityName, String abilityDescription, float abilityLevel)
|
||||
{
|
||||
this.abilityId = abilityId;
|
||||
this.abilityName = abilityName;
|
||||
@ -32,7 +32,7 @@ public class AbilityTarget implements TargetDataset
|
||||
return abilityDescription;
|
||||
}
|
||||
|
||||
public int getAbilityLevel()
|
||||
public float getAbilityLevel()
|
||||
{
|
||||
return abilityLevel;
|
||||
}
|
||||
@ -40,7 +40,7 @@ public class AbilityTarget implements TargetDataset
|
||||
@Override
|
||||
public String toString()
|
||||
{
|
||||
return String.format("Ability [ %d, %s, %s, %d ]", this.abilityId, this.abilityName, this.abilityDescription, this.abilityLevel);
|
||||
return String.format("Ability [ %d, %s, %s, %f ]", this.abilityId, this.abilityName, this.abilityDescription, this.abilityLevel);
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -2,14 +2,17 @@ package data.target;
|
||||
|
||||
import data.TargetDataset;
|
||||
|
||||
import java.sql.Clob;
|
||||
import java.sql.SQLException;
|
||||
|
||||
public class QuestTarget implements TargetDataset
|
||||
{
|
||||
private int questId;
|
||||
private String name;
|
||||
private String involvedCharacters;
|
||||
private String dialogue;
|
||||
private Clob dialogue;
|
||||
|
||||
public QuestTarget(int questId, String name, String involvedCharacters, String dialogue)
|
||||
public QuestTarget(int questId, String name, String involvedCharacters, Clob dialogue)
|
||||
{
|
||||
this.questId = questId;
|
||||
this.name = name;
|
||||
@ -32,7 +35,7 @@ public class QuestTarget implements TargetDataset
|
||||
return involvedCharacters;
|
||||
}
|
||||
|
||||
public String getDialogue()
|
||||
public Clob getDialogue()
|
||||
{
|
||||
return dialogue;
|
||||
}
|
||||
@ -40,6 +43,15 @@ public class QuestTarget implements TargetDataset
|
||||
@Override
|
||||
public String toString()
|
||||
{
|
||||
return String.format("Quest [ %d, %s, %s, %s... ]", this.questId, this.name, this.involvedCharacters, this.dialogue.substring(0, 10));
|
||||
try
|
||||
{
|
||||
return String.format("Quest [ %d, %s, { %s }, %s... ]", this.questId, this.name, this.involvedCharacters, this.dialogue.getSubString(1, 10));
|
||||
}
|
||||
catch (SQLException e)
|
||||
{
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
@ -1,5 +1,6 @@
|
||||
package migration;
|
||||
|
||||
import com.mysql.cj.exceptions.NumberOutOfRange;
|
||||
import data.source.AbilitiesSource;
|
||||
import data.source.PersonSource;
|
||||
import data.target.AbilityTarget;
|
||||
@ -48,13 +49,18 @@ public class AbilityMigration extends ETL<AbilitiesSource, AbilityTarget>
|
||||
@Override
|
||||
protected List<AbilityTarget> transform(List<AbilitiesSource> extractedData)
|
||||
{
|
||||
DataTransformer<AbilitiesSource, AbilityTarget> transformer =
|
||||
(dataset) -> new AbilityTarget(
|
||||
abilityId++,
|
||||
dataset.getName(),
|
||||
dataset.getDescription(),
|
||||
dataset.getLevel()
|
||||
);
|
||||
DataTransformer<AbilitiesSource, AbilityTarget> transformer = (dataset) -> {
|
||||
if (dataset.getLevel() < 0 || dataset.getLevel() > 100)
|
||||
log.error("level-value out of range",
|
||||
new NumberOutOfRange("level must be within 0 an 100 (both inclusive)"));
|
||||
var levelCorrection = 100f;
|
||||
return new AbilityTarget(
|
||||
abilityId++,
|
||||
dataset.getName(),
|
||||
dataset.getDescription(),
|
||||
dataset.getLevel() / levelCorrection
|
||||
);
|
||||
};
|
||||
|
||||
return new Transformer<>(transformer, extractedData).doTransform();
|
||||
}
|
||||
@ -66,7 +72,7 @@ public class AbilityMigration extends ETL<AbilitiesSource, AbilityTarget>
|
||||
preparedStatement.setInt(1, data.getAbilityId());
|
||||
preparedStatement.setString(2, data.getAbilityName());
|
||||
preparedStatement.setString(3, data.getAbilityDescription());
|
||||
preparedStatement.setInt(4, data.getAbilityLevel());
|
||||
preparedStatement.setFloat(4, data.getAbilityLevel());
|
||||
};
|
||||
|
||||
var sql = "insert into ability values (?, ?, ?, ?)";
|
||||
|
@ -6,6 +6,7 @@ import data.source.PersonSource;
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
import java.sql.Connection;
|
||||
import java.sql.SQLException;
|
||||
import java.util.List;
|
||||
|
||||
public abstract class ETL<T extends SourceDataset, E extends TargetDataset>
|
||||
@ -27,6 +28,15 @@ public abstract class ETL<T extends SourceDataset, E extends TargetDataset>
|
||||
var extractedData = this.extract();
|
||||
var transformedData = this.transform(extractedData);
|
||||
this.load(transformedData);
|
||||
|
||||
try
|
||||
{
|
||||
this.target.commit();
|
||||
}
|
||||
catch (SQLException e)
|
||||
{
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
protected abstract List<T> extract();
|
||||
|
@ -1,9 +1,20 @@
|
||||
package migration;
|
||||
|
||||
import com.mysql.cj.exceptions.NumberOutOfRange;
|
||||
import data.source.AbilitiesSource;
|
||||
import data.source.GameobjectSource;
|
||||
import data.target.AbilityTarget;
|
||||
import data.target.GameobjectTarget;
|
||||
import etl.Extractor;
|
||||
import etl.Loader;
|
||||
import etl.Transformer;
|
||||
import utils.DataStorer;
|
||||
import utils.DataTransformer;
|
||||
import utils.StatementPreparerExtractor;
|
||||
import utils.StatementPreparerLoader;
|
||||
|
||||
import java.sql.Connection;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
public class GameobjectMigration extends ETL<GameobjectSource, GameobjectTarget>
|
||||
@ -16,18 +27,48 @@ public class GameobjectMigration extends ETL<GameobjectSource, GameobjectTarget>
|
||||
@Override
|
||||
protected List<GameobjectSource> extract()
|
||||
{
|
||||
return null;
|
||||
DataStorer<GameobjectSource> dataStorer = (resultSet) -> {
|
||||
var extractedData = new ArrayList<GameobjectSource>();
|
||||
while (resultSet.next())
|
||||
{
|
||||
extractedData.add(new GameobjectSource(
|
||||
resultSet.getInt("objectId"),
|
||||
resultSet.getString("name"),
|
||||
resultSet.getString("description")
|
||||
));
|
||||
}
|
||||
return extractedData;
|
||||
};
|
||||
|
||||
var sql = "select * from gameobject;";
|
||||
StatementPreparerExtractor statementPreparer = (preparedStatement) -> {};
|
||||
|
||||
return new Extractor<>(super.source, dataStorer, statementPreparer, sql).doExtract();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected List<GameobjectTarget> transform(List<GameobjectSource> extractedData)
|
||||
{
|
||||
return null;
|
||||
DataTransformer<GameobjectSource, GameobjectTarget> transformer = (dataset) -> new GameobjectTarget(
|
||||
dataset.getObjectId(),
|
||||
dataset.getName(),
|
||||
dataset.getDescription()
|
||||
);
|
||||
|
||||
return new Transformer<>(transformer, extractedData).doTransform();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void load(List<GameobjectTarget> transformedData)
|
||||
{
|
||||
StatementPreparerLoader<GameobjectTarget> statementPreparerLoader = (preparedStatement, data) -> {
|
||||
preparedStatement.setInt(1, data.getObjectId());
|
||||
preparedStatement.setString(2, data.getName());
|
||||
preparedStatement.setString(3, data.getDescription());
|
||||
};
|
||||
|
||||
var sql = "insert into gameobject values (?, ?, ?)";
|
||||
|
||||
new Loader<>(super.target, statementPreparerLoader, transformedData, sql).doLoad();
|
||||
}
|
||||
}
|
||||
|
33
src/main/java/migration/ModMigration.java
Normal file
33
src/main/java/migration/ModMigration.java
Normal file
@ -0,0 +1,33 @@
|
||||
package migration;
|
||||
|
||||
import data.source.ModSource;
|
||||
import data.target.ModTarget;
|
||||
|
||||
import java.sql.Connection;
|
||||
import java.util.List;
|
||||
|
||||
public class ModMigration extends ETL<ModSource, ModTarget>
|
||||
{
|
||||
public ModMigration(Connection source, Connection target)
|
||||
{
|
||||
super(source, target);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected List<ModSource> extract()
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected List<ModTarget> transform(List<ModSource> extractedData)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void load(List<ModTarget> transformedData)
|
||||
{
|
||||
|
||||
}
|
||||
}
|
93
src/main/java/migration/QuestMigration.java
Normal file
93
src/main/java/migration/QuestMigration.java
Normal file
@ -0,0 +1,93 @@
|
||||
package migration;
|
||||
|
||||
import data.source.QuestSource;
|
||||
import data.target.QuestTarget;
|
||||
import etl.Extractor;
|
||||
import etl.Loader;
|
||||
import etl.Transformer;
|
||||
import utils.DataStorer;
|
||||
import utils.DataTransformer;
|
||||
import utils.StatementPreparerExtractor;
|
||||
import utils.StatementPreparerLoader;
|
||||
|
||||
import java.sql.Connection;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
public class QuestMigration extends ETL<QuestSource, QuestTarget>
|
||||
{
|
||||
public QuestMigration(Connection source, Connection target)
|
||||
{
|
||||
super(source, target);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected List<QuestSource> extract()
|
||||
{
|
||||
DataStorer<QuestSource> dataStorer = (resultSet) -> {
|
||||
var extractedData = new ArrayList<QuestSource>();
|
||||
while (resultSet.next())
|
||||
{
|
||||
extractedData.add(new QuestSource(
|
||||
resultSet.getInt("questId"),
|
||||
resultSet.getString("name"),
|
||||
resultSet.getClob("dialogue"),
|
||||
resultSet.getInt("personId")));
|
||||
}
|
||||
return extractedData;
|
||||
};
|
||||
|
||||
var sql = "select * from quest q join questParticipation qp on q.questId = qp.questId;";
|
||||
StatementPreparerExtractor statementPreparer = (preparedStatement) -> {};
|
||||
|
||||
return new Extractor<>(super.source, dataStorer, statementPreparer, sql).doExtract();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected List<QuestTarget> transform(List<QuestSource> extractedData)
|
||||
{
|
||||
var map = new HashMap<Integer, String>();
|
||||
|
||||
for (QuestSource extractedDatum : extractedData)
|
||||
{
|
||||
var key = extractedDatum.getQuestId();
|
||||
if (!map.containsKey(key))
|
||||
{
|
||||
map.put(key, String.valueOf(extractedDatum.getPersonId()));
|
||||
}
|
||||
else
|
||||
{
|
||||
var involvedPersons = String.format("%s, %s", map.get(key), extractedDatum.getPersonId());
|
||||
map.replace(key, involvedPersons);
|
||||
}
|
||||
}
|
||||
|
||||
extractedData = extractedData.stream().distinct().collect(Collectors.toList());
|
||||
|
||||
DataTransformer<QuestSource, QuestTarget> transformer = (dataset) -> new QuestTarget(
|
||||
dataset.getQuestId(),
|
||||
dataset.getName(),
|
||||
map.get(dataset.getQuestId()),
|
||||
dataset.getDialogue()
|
||||
);
|
||||
|
||||
return new Transformer<>(transformer, extractedData).doTransform();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void load(List<QuestTarget> transformedData)
|
||||
{
|
||||
StatementPreparerLoader<QuestTarget> statementPreparerLoader = (preparedStatement, data) -> {
|
||||
preparedStatement.setInt(1, data.getQuestId());
|
||||
preparedStatement.setString(2, data.getName());
|
||||
preparedStatement.setString(3, data.getInvolvedCharacters());
|
||||
preparedStatement.setClob(4, data.getDialogue());
|
||||
};
|
||||
|
||||
var sql = "insert into quest values (?, ?, ?, ?)";
|
||||
|
||||
new Loader<>(super.target, statementPreparerLoader, transformedData, sql).doLoad();
|
||||
}
|
||||
}
|
@ -32,11 +32,24 @@ public class ThesisMigration
|
||||
final var postgresInfo = new DatabaseInformation("localhost", "targetdb", "test", "test", 25001);
|
||||
this.postgresql= new ConnectionHelper(DatabaseType.POSTGRESQL, postgresInfo).createConnection();
|
||||
|
||||
try
|
||||
{
|
||||
this.mariadb.setAutoCommit(false);
|
||||
this.mysql.setAutoCommit(false);
|
||||
this.postgresql.setAutoCommit(false);
|
||||
}
|
||||
catch (SQLException e)
|
||||
{
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
this.migrations = new ArrayList<>();
|
||||
this.migrations.add(new PlayerMigration(null, this.postgresql));
|
||||
this.migrations.add(new AbilityMigration(this.mysql, this.postgresql));
|
||||
this.migrations.add(new PlayerAbilitiesMigration(this.postgresql, this.postgresql));
|
||||
this.migrations.add(new CharacterMigration(this.mariadb, this.postgresql));
|
||||
this.migrations.add(new GameobjectMigration(this.mariadb, this.postgresql));
|
||||
this.migrations.add(new QuestMigration(this.mariadb, this.postgresql));
|
||||
}
|
||||
|
||||
public void executeMigrations()
|
||||
|
@ -64,7 +64,6 @@ public class ConnectionHelper
|
||||
SQLState: %s;
|
||||
VendorError:%s""",
|
||||
e.getMessage(), e.getSQLState(), e.getErrorCode()));
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
return connection;
|
||||
|
Loading…
Reference in New Issue
Block a user