liquibase将列默认值设置为null

d8tt03nd  于 2021-06-15  发布在  Mysql
关注(0)|答案(2)|浏览(1197)

我用liquibase“adddefaultvalue”语法尝试将我的列的默认值设置为null:

  1. <changeSet id="20181213171501-2">
  2. <!-- Add default value -->
  3. <addDefaultValue tableName="myTable"
  4. columnDataType="boolean"
  5. columnName="myColumn"
  6. defaultValueBoolean="null" />
  7. </changeSet>

但是在mytable中插入新行表明默认值仍然设置为“false”,就像以前一样。所以liquibase变更集不起作用。
如何使用liquibase将列默认值设置为null?

7nbnzgx9

7nbnzgx91#

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

  1. <changeSet id="20181213171501-2">
  2. <!-- Reset default value to NULL -->
  3. <dropDefaultValue tableName="myTable" columnName="mColumn" />
  4. </changeSet>
7eumitmz

7eumitmz2#

我找到的解决方案是使用原始sql查询,而不是使用liquibase“adddefaultvalue”语法:

  1. <changeSet id="20181213171501-2">
  2. <!-- Add default value -->
  3. <sql dbms="mysql">
  4. ALTER TABLE myTable MODIFY myColumn BOOLEAN NULL DEFAULT NULL
  5. </sql>
  6. </changeSet>

相关问题