Liquibase 插入具有多个 id 的计算值

Lui*_*kys 5 liquibase

我正在尝试将值插入数据库。我认为 SQL 应该是这样的:

INSERT INTO `tb_config` (`name`, `value`, `description`, `unity_id`)
(SELECT 'new_rule', true, 'rule description', id FROM tb_unity );
Run Code Online (Sandbox Code Playgroud)

但是,我想使用 Liquibase 来完成此操作,使用变更集:

<changeSet author="Luis Sukys" id="1022" >
    <insert tableName="tb_config">
        <column name="name">new_rule</column>
        <column name="value">false</column>
        <column name="descricao">rule description</column>
        <column name="unidade_id" valueComputed="SELECT id FROM tb_unity" />
    </insert>
</changeSet>
Run Code Online (Sandbox Code Playgroud)

我见过 valueCompulated 的使用,但带有 where 子句。这个想法是,它在 tb_config 中为 tb_unity 中的每个 id 包含一行。我实际上从 liquibase 收到了“ValidationFailedException”。有什么帮助吗?

Ste*_*nie -1

如果您尝试使用您使用的任何 SQL 工具运行该 SQL,您将发现问题是您确实需要一个 where 子句。tb_unity您想使用哪一行的id?