首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Liquibase将列默认值设置为null

Liquibase将列默认值设置为null
EN

Stack Overflow用户
提问于 2018-12-14 22:37:21
回答 2查看 5.5K关注 0票数 3

我尝试使用liquibase "addDefaultValue“语法将我的列的默认值设置为null:

代码语言:javascript
复制
<changeSet id="20181213171501-2">
    <!-- Add default value -->
    <addDefaultValue tableName="myTable"
        columnDataType="boolean"
        columnName="myColumn"
        defaultValueBoolean="null" />
</changeSet>

但是,在myTable中插入一个新行后,默认值仍然设置为'false',就像以前一样。因此,liquibase变更集不起作用。

如何使用liquibase将列默认值设置为null?

EN

回答 2

Stack Overflow用户

发布于 2018-12-14 22:37:21

我找到的解决方案是使用原始的SQL查询,而不是液基"addDefaultValue“语法:

代码语言:javascript
复制
<changeSet id="20181213171501-2">
    <!-- Add default value -->
    <sql dbms="mysql">
        ALTER TABLE myTable MODIFY myColumn BOOLEAN NULL DEFAULT NULL
    </sql>
</changeSet>
票数 1
EN

Stack Overflow用户

发布于 2019-07-01 23:53:40

这正是dropDefaultValue重构所做的事情:它将可为空的列的默认值重置为null。

代码语言:javascript
复制
<changeSet id="20181213171501-2">
    <!-- Reset default value to NULL -->
    <dropDefaultValue tableName="myTable" columnName="mColumn" />
</changeSet>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53781733

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档