Liquibase for/for 每次操作(迁移 table 数据)

Liquibase for/for each operation (migrating table data)

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

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.id keyEntities 中插入一个值并在 Existing_table 中更新 entities_id。 =18=]

我怎样才能做到这一点?

找不到创建参数化循环的方法,因此使用临时列来存储引用的 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>