本文整理匯總了Java中com.fsryan.forsuredb.api.migration.MigrationSet類的典型用法代碼示例。如果您正苦於以下問題:Java MigrationSet類的具體用法?Java MigrationSet怎麽用?Java MigrationSet使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
MigrationSet類屬於com.fsryan.forsuredb.api.migration包,在下文中一共展示了MigrationSet類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: generateMigrationSql
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
@Override
public List<String> generateMigrationSql(MigrationSet migrationSet) {
if (migrationSet == null || !migrationSet.containsMigrations() || migrationSet.getTargetSchema() == null) {
return new ArrayList<>();
}
QueryGeneratorFactory qgf = new QueryGeneratorFactory(migrationSet);
List<Migration> migrations = migrationSet.getOrderedMigrations();
Collections.sort(migrations, new MigrationComparator(migrationSet.getTargetSchema()));
List<String> sqlList = new ArrayList<>();
Set<String> recreatedTables = new HashSet<>();
for (Migration m : migrations) {
if (recreatedTables.contains(m.getTableName()) && isMigrationHandledOnCreate(m, migrationSet.getTargetSchema())) {
continue;
}
if (TYPES_REQUIRING_TABLE_RECREATION.contains(m.getType())) {
recreatedTables.add(m.getTableName());
}
sqlList.addAll(qgf.getFor(m, migrationSet.getTargetSchema()).generate());
}
return sqlList;
}
示例2: createNewForeignKeyMap
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
/**
* <p>
* Foreign key migrations are difficult in that, in SQLite, they mist be added when the table is created.
* This is problematic because, if you have multiple foreign keys to add to the same table in one migration
* set, then you cannot know the correct temp table to create for temporary data storage simply by looking at
* the target context. You actually have to know all of the foreign key columns to add for a table prior to
* adding any foreign key column.
* </p>
* @param migrationSet the full set of migrations that this query generator factory is creating queries
* @return a map of tableName to list of column names that are new foreign keys
*/
private Map<String, List<String>> createNewForeignKeyMap(MigrationSet migrationSet) {
if (migrationSet == null || !migrationSet.containsMigrations() || migrationSet.getTargetSchema() == null) {
return Collections.emptyMap();
}
Map<String, List<String>> retMap = new HashMap<>();
for (Migration m : migrationSet.getOrderedMigrations()) {
if (m.getType() != Migration.Type.ADD_FOREIGN_KEY_REFERENCE) {
continue;
}
List<String> newForeignKeyColumns = retMap.get(m.getTableName());
if (newForeignKeyColumns == null) {
List<String> columnNames = new ArrayList<>();
columnNames.add(m.getColumnName());
retMap.put(m.getTableName(), columnNames);
} else {
newForeignKeyColumns.add(m.getColumnName());
}
}
return retMap;
}
示例3: TwoMigrationSetTest
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
public TwoMigrationSetTest(List<Migration> firstMigrations,
Map<String, TableInfo> firstExpectedSchema,
List<Migration> secondMigrations,
Map<String, TableInfo> secondExpectedSchema) {
super(Arrays.asList(MigrationSet.builder()
.orderedMigrations(firstMigrations)
.dbVersion(1)
.targetSchema(firstExpectedSchema)
.build(),
MigrationSet.builder()
.orderedMigrations(secondMigrations)
.dbVersion(2)
.targetSchema(secondExpectedSchema)
.build()),
2,
secondExpectedSchema);
}
示例4: getMigrationSets
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
/**
* @return a sorted list of Migration
*/
public List<MigrationSet> getMigrationSets() {
if (migrationSets == null) {
createMigrationSets();
}
return migrationSets;
}
示例5: FSDBHelper
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
private FSDBHelper(Context context, String dbName, List<FSTableCreator> tables, List<MigrationSet> migrationSets, boolean debugMode) {
super(context, dbName, cursorFactory, identifyDbVersion(migrationSets));
this.context = context;
this.tables = tables;
this.migrationSets = migrationSets;
this.debugMode = debugMode;
}
示例6: identifyDbVersion
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
/**
* @param migrationSets The {@link List} of {@link Migration}
* @return either 1 or the largest dbVersion in the migrationSets list
*/
private static int identifyDbVersion(List<MigrationSet> migrationSets) {
if (migrationSets == null || migrationSets.size() == 0) {
return 1;
}
int version = 1;
for (MigrationSet migrationSet : migrationSets) {
version = migrationSet.getDbVersion() > version ? migrationSet.getDbVersion() : version;
}
return version;
}
示例7: applyMigrations
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
private void applyMigrations(SQLiteDatabase db, int previousVersion) {
for (MigrationSet migrationSet : migrationSets) {
if (previousVersion >= migrationSet.getDbVersion()) {
continue;
}
executeSqlList(db, Sql.generator().generateMigrationSql(migrationSet), "performing migration sql: ");
}
}
示例8: getCode
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
@Override
protected String getCode() {
MigrationSet migrationSet = new DiffGenerator(new MigrationContext(mr), mr.latestDbVersion()).analyzeDiff(pContext);
APLog.i(LOG_TAG, "Number of migrations in set = " + migrationSet.getOrderedMigrations().size());
if (migrationSet.getOrderedMigrations().size() == 0) {
return null;
}
return new Gson().toJson(migrationSet);
}
示例9: analyzeDiff
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
/**
* <p>
* Anayzes the diff between this instance's {@link TableContext TableContext} and that of
* the argument
* </p>
* @param targetContext The {@link TableContext TableContext} that you would like to reach from
* the {@link TableContext TableContext} member of this
* {@link DiffGenerator DiffGenerator}
* @return a priority queue of {@link Migration} that describes a sequence of migrations to
* apply to migrate a database from the schema of this instance's {@link TableContext} to that
* of the {@link TableContext TableContext} argument.
*/
public MigrationSet analyzeDiff(TableContext targetContext) {
APLog.i(LOG_TAG, "analyzing diff: targetContext.allTables().size() = " + targetContext.allTables().size());
PriorityQueue<Migration> migrationQueue = new PriorityQueue<>();
migrationQueue.addAll(additiveChanges(targetContext));
migrationQueue.addAll(subtractiveChanges(targetContext));
return MigrationSet.builder().dbVersion(sourceDbVersion + 1)
.orderedMigrations(toList(migrationQueue))
.targetSchema(targetContext.tableMap())
.build();
}
示例10: OneMigrationSetTest
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
public OneMigrationSetTest(List<Migration> migrations, Map<String, TableInfo> expectedSchema) {
super(Arrays.asList(MigrationSet.builder()
.orderedMigrations(migrations)
.dbVersion(1)
.targetSchema(expectedSchema)
.build()),1, expectedSchema);
}
示例11: QueryGeneratorFactory
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
public QueryGeneratorFactory(MigrationSet migrationSet) {
newForeignKeyColumnMap = createNewForeignKeyMap(migrationSet);
}
示例12: setUp
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
@Before
public void setUp() {
MigrationSet migrationSet = new Gson().fromJson(inputMigrationJson, MigrationSet.class);
actualSqlOutput = new SqlGenerator().generateMigrationSql(migrationSet);
}
示例13: MigrationContextTest
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
public MigrationContextTest(List<MigrationSet> input, int latestDbVersion, Map<String, TableInfo> expectedSchema) {
this.input = input;
this.latestDbVersion = latestDbVersion;
this.expectedSchema = expectedSchema;
}
示例14: SmallDiffGeneratorTest
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
public SmallDiffGeneratorTest(int sourceDbVersion, TableContext migrationContext, TableContext processingContext, MigrationSet expectedMigrationSet) {
super(sourceDbVersion, migrationContext, processingContext, expectedMigrationSet);
}
示例15: BaseDiffGeneratorTest
import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
public BaseDiffGeneratorTest(int sourceDbVersion, TableContext migrationContext, TableContext processingContext, MigrationSet expectedMigrationSet) {
this.sourceDbVersion = sourceDbVersion;
this.migrationContext = migrationContext;
this.processingContext = processingContext;
this.expectedMigrationSet = expectedMigrationSet;
}