當前位置: 首頁>>代碼示例>>Java>>正文


Java MigrationSet類代碼示例

本文整理匯總了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;
}
 
開發者ID:ryansgot,項目名稱:forsuredbsqlitelib,代碼行數:24,代碼來源:SqlGenerator.java

示例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;
}
 
開發者ID:ryansgot,項目名稱:forsuredbsqlitelib,代碼行數:34,代碼來源:QueryGeneratorFactory.java

示例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);
}
 
開發者ID:ryansgot,項目名稱:forsuredbcompiler,代碼行數:18,代碼來源:MigrationContextTest.java

示例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;
}
 
開發者ID:ryansgot,項目名稱:forsuredbandroid,代碼行數:10,代碼來源:Migrator.java

示例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;
}
 
開發者ID:ryansgot,項目名稱:forsuredbandroid,代碼行數:8,代碼來源:FSDBHelper.java

示例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;
}
 
開發者ID:ryansgot,項目名稱:forsuredbandroid,代碼行數:16,代碼來源:FSDBHelper.java

示例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: ");
    }
}
 
開發者ID:ryansgot,項目名稱:forsuredbandroid,代碼行數:9,代碼來源:FSDBHelper.java

示例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);
}
 
開發者ID:ryansgot,項目名稱:forsuredbcompiler,代碼行數:11,代碼來源:MigrationGenerator.java

示例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();
}
 
開發者ID:ryansgot,項目名稱:forsuredbcompiler,代碼行數:25,代碼來源:DiffGenerator.java

示例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);
}
 
開發者ID:ryansgot,項目名稱:forsuredbcompiler,代碼行數:8,代碼來源:MigrationContextTest.java

示例11: QueryGeneratorFactory

import com.fsryan.forsuredb.api.migration.MigrationSet; //導入依賴的package包/類
public QueryGeneratorFactory(MigrationSet migrationSet) {
    newForeignKeyColumnMap = createNewForeignKeyMap(migrationSet);
}
 
開發者ID:ryansgot,項目名稱:forsuredbsqlitelib,代碼行數:4,代碼來源:QueryGeneratorFactory.java

示例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);
}
 
開發者ID:ryansgot,項目名稱:forsuredbsqlitelib,代碼行數:6,代碼來源:MigrationSqlQueryTest.java

示例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;
}
 
開發者ID:ryansgot,項目名稱:forsuredbcompiler,代碼行數:6,代碼來源:MigrationContextTest.java

示例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);
}
 
開發者ID:ryansgot,項目名稱:forsuredbcompiler,代碼行數:4,代碼來源:SmallDiffGeneratorTest.java

示例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;
}
 
開發者ID:ryansgot,項目名稱:forsuredbcompiler,代碼行數:7,代碼來源:BaseDiffGeneratorTest.java


注:本文中的com.fsryan.forsuredb.api.migration.MigrationSet類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。