求解决Mysql建表时间默认值问题!

dickchen87 2011-09-01 05:25:24
创建 表是 用的图形化工具,出错 1067 invalid default value for 'usetime' usetime该列 为datetime类型 长度为0

下面默认值是NOW()请问应该怎么修改,哪里出问题了
...全文
657 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
zoubifeng 2012-03-27
  • 打赏
  • 举报
回复
为什么看不到?
WWWWA 2011-09-02
  • 打赏
  • 举报
回复
5楼不是已经给出代码了吗?
nicenight 2011-09-02
  • 打赏
  • 举报
回复
BZ总是比别人更有耐心。
ACMAIN_CHM 2011-09-01
  • 打赏
  • 举报
回复
[Quote]麻烦 别发这么多 概念网上多的事 解决问题才是硬道理。 说明下 今天第一次接触mysql[/Quote]i不是已经告诉你了吗? 改成TIMESTAMP 字段类型! 然后不加任何默认值 或者加 CURRENT_TIMESTAMP 。
dickchen87 2011-09-01
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 acmain_chm 的回复:]
引用你可以非常灵便地确定什么时候初始化和更新TIMESTAMP和对哪些列进行初始化和更新:

· 你可以将当前的时间戳指定为默认值和自动更新的值。但只能选择一个,或者两者都不选。(不可能一个列选择一个行为而另一个列选择另一个行为)。

· 你可以指定哪个TIMESTAMP列自动初始化或更新为当前的日期和时间。不再需要为第1个TIMESTAMP列。

请注意下面讨论所信息只适用于创建时未……
[/Quote]
麻烦 别发这么多 概念网上多的事 解决问题才是硬道理。 说明下 今天第一次接触mysql
dickchen87 2011-09-01
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 acmain_chm 的回复:]
你不能使用DATETIME字段,这个字段类型不支持NOW为省缺值。
你应该使用TIMESTAMP 字段。
[/Quote]

还是不行啊,后面的长度要不要设置下 现在长度是0
ACMAIN_CHM 2011-09-01
  • 打赏
  • 举报
回复
[Quote]你可以非常灵便地确定什么时候初始化和更新TIMESTAMP和对哪些列进行初始化和更新:

· 你可以将当前的时间戳指定为默认值和自动更新的值。但只能选择一个,或者两者都不选。(不可能一个列选择一个行为而另一个列选择另一个行为)。

· 你可以指定哪个TIMESTAMP列自动初始化或更新为当前的日期和时间。不再需要为第1个TIMESTAMP列。

请注意下面讨论所信息只适用于创建时未启用MAXDB模式的表的TIMESTAMP列。(如上所述,MAXDB模式使列创建为DATETIME列)。控制TIMESTAMP列的初始化和更新的规则如下所示:

· 如果一个表内的第1个TIMESTAMP列指定为一个DEFAULT值,则不能忽略。 默认值可以为CURRENT_TIMESTAMP或常量日期和时间值。

· DEFAULT NULL与第1个TIMESTAMP 列的DEFAULT CURRENT_TIMESTAMP相同。对于其它TIMESTAMP列,DEFAULT NULL被视为DEFAULT 0。

· 表内的任何一个TIMESTAMP列可以设置为自动初始化为当前时间戳和/或更新。

· 在CREATE TABLE语句中,可以用下面的任何一种方式声明第1个TIMESTAMP列:

o 用DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP子句,列为默认值使用当前的时间戳,并且自动更新。

o 不使用DEFAULT或ON UPDATE子句,与DEFAULT CURRENT_TIMESTAMP ON UPDATECURRENT_TIMESTAMP相同。

o 用DEFAULT CURRENT_TIMESTAMP子句不用ON UPDATE子句,列为默认值使用当前的时间戳但是不自动更新。

o 不用DEFAULT子句但用ON UPDATE CURRENT_TIMESTAMP子句,列有默认值0并自动更新。

o 用常量DEFAULT值,列有给出的 默认值。如果列有一个ON UPDATE CURRENT_TIMESTAMP子句,它自动更新,否则不。

换句话说,你可以为初始值和自动更新的值使用当前的时间戳,或者其中一个使用,或者两个皆不使用。(例如,你可以指定ON UPDATE来启用自动更新而不让列自动初始化)。

· 在DEFAULT和ON UPDATE子句中可以使用CURRENT_TIMESTAMP、CURRENT_TIMESTAMP()或者NOW()。它们均具有相同的效果。

两个属性的顺序并不重要。如果一个TIMESTAMP列同时指定了DEFAULT和ON UPDATE,任何一个可以在另一个的前面。

例子,下面这些语句是等效的:

CREATE TABLE t (ts TIMESTAMP);
CREATE TABLE t (ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP
ON UPDATE CURRENT_TIMESTAMP);
CREATE TABLE t (ts TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
DEFAULT CURRENT_TIMESTAMP);
· 要为TIMESTAMP列而不是第1列指定自动默认或更新,必须通过将第1个TIMESTAMP列显式分配一个常量DEFAULT值来禁用自动初始化和更新。(例如,DEFAULT 0或DEFAULT'2003-01-01 00:00:00')。然后,对于其它TIMESTAMP列,规则与第1个TIMESTAMP列相同,例外情况是不能忽略DEFAULT和ON UPDATE子句。如果这样做,则不会自动进行初始化或更新。

例如:下面这些语句是等效的:

CREATE TABLE t (
ts1 TIMESTAMP DEFAULT 0,
ts2 TIMESTAMP DEFAULT CURRENT_TIMESTAMP
ON UPDATE CURRENT_TIMESTAMP);
CREATE TABLE t (
ts1 TIMESTAMP DEFAULT 0,
ts2 TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
DEFAULT CURRENT_TIMESTAMP);
[/Quote]
wwwwb 2011-09-01
  • 打赏
  • 举报
回复
呵呵,用命令行吧
估计是在CURRENT_TIMESTAMP上加了单引号
ACMAIN_CHM 2011-09-01
  • 打赏
  • 举报
回复
你不能使用DATETIME字段,这个字段类型不支持NOW为省缺值。
你应该使用TIMESTAMP 字段。
dickchen87 2011-09-01
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 wwwwb 的回复:]
CREATE TABLE `aa`.`TableName1`(
`nn` TIMESTAMP DEFAULT CURRENT_TIMESTAMP
)
[/Quote]

我用的图形化操作界面 不是用的sql建表 不知道问题出在哪
wwwwb 2011-09-01
  • 打赏
  • 举报
回复
CREATE TABLE `aa`.`TableName1`(
`nn` TIMESTAMP DEFAULT CURRENT_TIMESTAMP
)
dickchen87 2011-09-01
  • 打赏
  • 举报
回复
[Quote=引用楼主 dickchen87 的回复:]
创建 表是 用的图形化工具,出错 1067 invalid default value for 'usetime' usetime该列 为datetime类型 长度为0

下面默认值是NOW()请问应该怎么修改,哪里出问题了
[/Quote]
忘记说了啊 ,是mysql 数据库
oO寒枫Oo 2011-09-01
  • 打赏
  • 举报
回复
不用选择长度 就选择类型是datetime类型就好了
chuanzhang5687 2011-09-01
  • 打赏
  • 举报
回复
alter table tablename alter column columnname datetime default getdate()
MSSQL
-晴天 2011-09-01
  • 打赏
  • 举报
回复
默认值用 getdate()

56,678

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧