使用Liquibase,postgreSQL和序列插入新数据

时间:2019-01-10 15:12:19

标签: postgresql liquibase

如果我的ID是连续的,如何使用Liquibase为PostgreSQL插入内容。我尝试以下方法:

<changeSet author="rparente" id="service-1.1-2019-01-09-01">
        <insert tableName="tenant">
            <column name="id"defaultValueSequenceNext="hibernate_sequence"/>
            <column name="description" value="Prueba"/>
            <column name="name" value="antel"/>
            <column name="service_id" value="antel"/>
        </insert>
    </changeSet>

我尝试

<changeSet author="rparente" id="service-1.1-2019-01-09-01">
        <insert tableName="tenant">
            <column name="id"  value="nextval('hibernate_sequence')"/>
            <column name="description" value="Prueba"/>
            <column name="name" value="antel"/>
            <column name="service_id" value="antel"/>
        </insert>
    </changeSet>

错误是:

  

错误:列“ id”中的空值违反了非空约束

3 个答案:

答案 0 :(得分:1)

我找到了在序列中插入数据的解决方案(无默认ID)

<changeSet author="author_name" id="service-1.1-2019-01-09-01"> 
    <insert tableName="tenant"> 
        <column name="id" valueSequenceNext="name_sequence"/> 
        <column name="description" value="TEST"/> 
        <column name="name" value="test"/> 
        <column name="service_id" value="testl"/> 
        <column name="status" value="ACTIVE"/> 
    </insert> 
</changeSet>

答案 1 :(得分:0)

签出ColumnConfig文档。您应该可以设置一个valueComputed属性,并在其中调用Postgres函数:

<column name="id"  valueComputed="nextval('hibernate_sequence')"/>

答案 2 :(得分:0)

对于我来说,我必须先创建一个序列,然后再使用它。

<changeSet>
    <createSequence sequenceName="runtime_name_seq" dataType="bigint" incrementBy="1" maxValue="10000" minValue="1" startValue="1"/>
</changeSet>

<changeSet>
     <createTable tableName="runtime_name">
        <column name="id" type="INTEGER" defaultValueComputed="nextval('runtime_name_seq')">
            <constraints nullable="false" primaryKey="true" primaryKeyName="pk_runtime_name"/>
        </column>
    </createTable>
</changeSet>

这将通过Liquibase创建SQL(我正在使用v3.8.1)

CREATE TABLE public.runtime_name 
(
    index INTEGER DEFAULT nextval('runtime_name_seq') NOT NULL
)