每个操作的 Liquibase(迁移表数据)



我正在使用Liquibase,我需要在一个表中插入数据,具体取决于另一个表中的条目(创建外键引用)

Table: Entities (currently empty)
PK id
INT data
Table: Existing_table (contains data)
PK id
... data
FK entities_id (references Entities.id)

对于Existing_table中的每个条目,我需要在Entities中插入一个值,并使用创建的Entities.id keyExisting_table中更新entities_id

我怎样才能做到这一点?

找不到制作参数化循环的方法,因此使用了一个 temopary 列来存储引用的 id。

<changeSet id="add temp_column to Entities" author="">
    <addColumn tableName="Entities">
        <column name="temp_id" type="BIGINT"></column>
    </addColumn>
 </changeSet>
<changeSet author="" id="insert Existing_table keys into Entities">
    <sql>
        INSERT INTO Entities(type_id, temp_id)
        select 1, id
        from Existing_table;
    </sql>
</changeSet>
<changeSet author="" id="insert entity keys into Existing_table">
    <sql>
        UPDATE Existing_table d set entity_id = ent.id
        FROM (select id, temp_id
        from Entities) ent
        where ent.temp_id = d.id;
    </sql>
</changeSet>

<changeSet id="drop temp_column to Entities" author="">
    <dropColumn tableName="Entities"
                columnName="temp_id"/>
</changeSet>

<changeSet author="" id="addNotNullConstraint Existing_table-Entities">
    <addNotNullConstraint columnDataType="BIGINT"
                          columnName="entity_id"
                          tableName="Existing_table"/>
</changeSet>

相关内容

  • 没有找到相关文章

最新更新