我正在使用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 key
在Existing_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>