Adjustments
This commit is contained in:
parent
780bad6dbd
commit
6e8eec3ffa
@ -1,9 +1,20 @@
|
|||||||
package migration;
|
package migration;
|
||||||
|
|
||||||
|
import data.source.GameobjectSource;
|
||||||
import data.source.ModSource;
|
import data.source.ModSource;
|
||||||
|
import data.target.GameobjectTarget;
|
||||||
import data.target.ModTarget;
|
import data.target.ModTarget;
|
||||||
|
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.sql.Connection;
|
||||||
|
import java.sql.Date;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class ModMigration extends ETL<ModSource, ModTarget>
|
public class ModMigration extends ETL<ModSource, ModTarget>
|
||||||
@ -16,18 +27,51 @@ public class ModMigration extends ETL<ModSource, ModTarget>
|
|||||||
@Override
|
@Override
|
||||||
protected List<ModSource> extract()
|
protected List<ModSource> extract()
|
||||||
{
|
{
|
||||||
return null;
|
DataStorer<ModSource> dataStorer = (resultSet) -> {
|
||||||
|
var extractedData = new ArrayList<ModSource>();
|
||||||
|
while (resultSet.next())
|
||||||
|
{
|
||||||
|
extractedData.add(new ModSource(
|
||||||
|
resultSet.getInt("modId"),
|
||||||
|
resultSet.getString("name"),
|
||||||
|
resultSet.getDate("installationDate").toLocalDate(),
|
||||||
|
resultSet.getBlob("binary")
|
||||||
|
));
|
||||||
|
}
|
||||||
|
return extractedData;
|
||||||
|
};
|
||||||
|
|
||||||
|
var sql = "select * from `mod`;";
|
||||||
|
StatementPreparerExtractor statementPreparer = (preparedStatement) -> {};
|
||||||
|
|
||||||
|
return new Extractor<>(super.source, dataStorer, statementPreparer, sql).doExtract();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected List<ModTarget> transform(List<ModSource> extractedData)
|
protected List<ModTarget> transform(List<ModSource> extractedData)
|
||||||
{
|
{
|
||||||
return null;
|
DataTransformer<ModSource, ModTarget> transformer = (dataset) -> new ModTarget(
|
||||||
|
dataset.getModId(),
|
||||||
|
dataset.getName(),
|
||||||
|
dataset.getInstallationDate(),
|
||||||
|
dataset.getBinary()
|
||||||
|
);
|
||||||
|
|
||||||
|
return new Transformer<>(transformer, extractedData).doTransform();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void load(List<ModTarget> transformedData)
|
protected void load(List<ModTarget> transformedData)
|
||||||
{
|
{
|
||||||
|
StatementPreparerLoader<ModTarget> statementPreparerLoader = (preparedStatement, data) -> {
|
||||||
|
preparedStatement.setInt(1, data.getModId());
|
||||||
|
preparedStatement.setString(2, data.getName());
|
||||||
|
preparedStatement.setDate(3, Date.valueOf(data.getModInstallationDate()));
|
||||||
|
preparedStatement.setBinaryStream(4, data.getModBinary().getBinaryStream());
|
||||||
|
};
|
||||||
|
|
||||||
|
var sql = "insert into \"mod\" values (?, ?, ?, ?)";
|
||||||
|
|
||||||
|
new Loader<>(super.target, statementPreparerLoader, transformedData, sql).doLoad();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -50,6 +50,7 @@ public class ThesisMigration
|
|||||||
this.migrations.add(new CharacterMigration(this.mariadb, this.postgresql));
|
this.migrations.add(new CharacterMigration(this.mariadb, this.postgresql));
|
||||||
this.migrations.add(new GameobjectMigration(this.mariadb, this.postgresql));
|
this.migrations.add(new GameobjectMigration(this.mariadb, this.postgresql));
|
||||||
this.migrations.add(new QuestMigration(this.mariadb, this.postgresql));
|
this.migrations.add(new QuestMigration(this.mariadb, this.postgresql));
|
||||||
|
this.migrations.add(new ModMigration(this.mariadb, this.postgresql));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void executeMigrations()
|
public void executeMigrations()
|
||||||
|
Loading…
Reference in New Issue
Block a user