Inserting default value as current date + 30 days in MySQL

前端 未结 1 947
情书的邮戳
情书的邮戳 2020-12-19 08:17

How can I make a column\'s default value equal to the current date + 30 days in MySQL? For example, if current date is 10-1-2011 then the column value must be inserted as 9-

相关标签:
1条回答
  • 2020-12-19 08:56

    If you're using MySQL >= 5.0, use a trigger:

    CREATE TRIGGER setDefaultDate
        BEFORE INSERT ON tableName
        FOR EACH ROW
        SET NEW.date = ADDDATE(curdate(), INTERVAL 30 DAY);
    

    The trigger will activate when you insert into tableName, setting date to now + 30 days. If your insert sets the date, it will override this default due to the BEFORE. The date is calculated using ADDDATE.

    0 讨论(0)
提交回复
热议问题