MySQL - 如何修改列默认值?

Use*_*ser 6 mysql sql default alter

如何将列的默认值从None更改为其他值?例如,如果我在创建行时没有指定日期,我希望我的日期有一个默认值0000-00-00.

我在phpMyAdmin中理解这一点,但我不确定如何通过命令提示符来完成.

我还了解在添加列时如何执行此操作.但我的所有专栏都已制作完成并且其中一些专栏中包含数据.

ALTER TABLE table1 ADD COLUMN foo INT DEFAULT 0;
Run Code Online (Sandbox Code Playgroud)

从搜索中,我找到了这条线,但我不确定这是不是我想要的?

ALTER TABLE foobar_data MODIFY COLUMN col VARCHAR(255) NOT NULL DEFAULT '{}';
Run Code Online (Sandbox Code Playgroud)

Sah*_*hah 11

使用ALTER TABLECHANGEMODIFYDEFAULT列的值.检查此链接ALTER TABLE SYNTAX

ALTER TABLE `tableName` CHANGE `columnName` `columnName` DATE DEFAULT '0000-00-00'; 
ALTER TABLE `tableName` MODIFY `columnName` DATE DEFAULT '0000-00-00'; 
Run Code Online (Sandbox Code Playgroud)

  • @macdonjo它将把“0000-00-00”应用于列中字段为“null”的所有行。 (2认同)