我正在使用 Liquibase,我需要在一个表中插入数据,具体取决于另一个表中的条目(创建外键引用)
Table: Entities (currently empty)
PK id
INT data
Table: Existing_table (contains data)
PK id
... data
FK entities_id (references Entities.id)
Run Code Online (Sandbox Code Playgroud)
对于中的每个条目,Existing_table我需要使用Entities创建entities_id的.Existing_tableEntities.id key
我怎样才能实现这个目标?
找不到创建参数化循环的方法,因此使用临时列来存储引用的 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>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9309 次 |
| 最近记录: |