`
dannyhz
  • 浏览: 400556 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

mysql 一张表多个TimeStamp设置的方法

 
阅读更多

http://www.jb51.net/article/31872.htm

引用


timestamp设置默认值是Default CURRENT_TIMESTAMP;timestamp设置随着表变化而自动更新是ON UPDATE CURRENT_TIMESTAMP;接下来为您详细介绍
timestamp设置默认值是Default CURRENT_TIMESTAMP
timestamp设置随着表变化而自动更新是ON UPDATE CURRENT_TIMESTAMP

但是由于
一个表中至多只能有一个字段设置CURRENT_TIMESTAMP
两行设置DEFAULT CURRENT_TIMESTAMP是不行的。

还有一点要注意
复制代码 代码如下:

CREATE TABLE `device` (
`id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`toid` INT(10) UNSIGNED NOT NULL DEFAULT '0' COMMENT 'toid',
`createtime` TIMESTAMP NOT NULL COMMENT '创建时间',
`updatetime` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '最后更新时间',
PRIMARY KEY (`id`),
UNIQUE INDEX `toid` (`toid`)
)
COMMENT='设备表'
COLLATE='utf8_general_ci'
ENGINE=InnoDB;

像这个设置也是不行的。
原因是mysql会默认为表中的第一个timestamp字段(且设置了NOT NULL)隐式设置DEFAULAT CURRENT_TIMESTAMP。所以说上例那样的设置实际上等同于设置了两个CURRENT_TIMESTAMP。

分析需求
一个表中,有两个字段,createtime和updatetime。
1 当insert的时候,sql两个字段都不设置,会设置为当前的时间
2 当update的时候,sql中两个字段都不设置,updatetime会变更为当前的时间

这样的需求是做不到的。因为你无法避免在两个字段上设置CURRENT_TIMESTAMP

解决办法有几个:
1 使用触发器
当insert和update的时候触发器触发时间设置。
网上有人使用这种方法。当然不怀疑这个方法的可用性。但是对于实际的场景来说,无疑是为了解决小问题,增加了复杂性。
2 将第一个timestamp的default设置为0
表结构如下:
复制代码 代码如下:

CREATE TABLE `device` (
`id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`toid` INT(10) UNSIGNED NOT NULL DEFAULT '0' COMMENT 'toid',
`createtime` TIMESTAMP NOT NULL DEFAULT 0 COMMENT '创建时间',
`updatetime` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '最后更新时间',
PRIMARY KEY (`id`),
UNIQUE INDEX `toid` (`toid`)
)
COMMENT='设备表'
COLLATE='utf8_general_ci'
ENGINE=InnoDB;

这样的话,你需要的插入和更新操作变为:
insert into device set toid=11,createtime=null;
update device set toid=22 where id=1;

这里注意的是插入操作的createtime必须设置为null!!
虽然我也觉得这种方法很不爽,但是这样只需要稍微修改insert操作就能为sql语句减负,感觉上还是值得的。这也确实是修改数据库最小又能保证需求的方法了。当然这个方法也能和1方法同时使用,就能起到减少触发器编写数量的效果了。
3 老老实实在sql语句中使用时间戳。
这个是最多人也是最常选择的
表结构上不做过多的设计:
复制代码 代码如下:

CREATE TABLE `device` (
`id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`toid` INT(10) UNSIGNED NOT NULL DEFAULT '0' COMMENT 'toid',
`createtime` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updatetime` TIMESTAMP NOT NULL COMMENT '最后更新时间',
PRIMARY KEY (`id`),
UNIQUE INDEX `toid` (`toid`)
)
COMMENT='设备表'
COLLATE='utf8_general_ci'
ENGINE=InnoDB;

这样你就需要在插入和update的操作的时候写入具体的时间戳。
insert device set toid=11,createtime='2012-11-2 10:10:10',updatetime='2012-11-2 10:10:10'
update device set toid=22,updatetime='2012-11-2 10:10:10' where id=1
其实反观想想,这样做的好处也有一个:current_timestamp是mysql特有的,当数据库从mysql转移到其他数据库的时候,业务逻辑代码是不用修改的。

ps:这三种方法的取舍就完全看你自己的考虑了。顺便说一下,最后,我还是选择第三种方法。

分享到:
评论

相关推荐

    MySQL版本低了不支持两个时间戳类型的值解决方法

    there can be only one TIMESTAMP column with CURRENT_TIMESTAMP" 是MySQL在检测到表定义中有多个TIMESTAMP列并且至少其中一个被设置为默认值CURRENT_TIMESTAMP时抛出的。这在MySQL 5.5及更低版本中是一个常见问题...

    MySQL timestamp自动更新时间分享

    不过,你可以创建多个`TIMESTAMP`字段,只要它们的默认值不是`CURRENT_TIMESTAMP`即可,比如这样: ```sql CREATE TABLE `t1` ( `p_c` int(11) NOT NULL, `p_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP...

    Mysql经典面试题答案

    - **多线程SQL服务器**:能够高效处理多个并发连接请求。 - **客户端支持**:支持多种客户端程序和库,便于不同平台上的应用开发。 - **后端支持**:提供多种后端处理方式,适应不同的应用场景需求。 - **API和...

    mysql性能优化综述

    - **分表**:将一张大表分成多个小表,既可以提高查询速度,又便于管理和维护。具体方法包括: - **Merge分表**:将数据分布在多个子表中,通过主表统一管理。 - **纵向分割**:根据字段的更新频率将其分布到不同...

    MySQL的面试题集锦

    在 MySQL 中,一张表的 ID 自增主键是如何工作的?如果删除了一些记录,然后重启 MySQL,再插入一条记录,新记录的 ID 会是多少?答案取决于表的类型。如果表的类型是 MyISAM,那么自增主键的最大 ID 会被记录到数据...

    2024年java面试题-数据库MySQL面试题第一部分

    - 一个表只能有一个主键,但它可以包含多个候选键。 - 主键本身就是候选键的一种。 ### 18. 使用 Unix shell 登录 MySQL - 使用命令行方式登录 MySQL:`# [mysql dir]/bin/mysql -h hostname -u <UserName> -p ...

    MySQL学习笔记与实践代码.zip

    笔记部分可能涵盖了MySQL的基础概念、安装配置、数据类型、SQL语句、索引、存储引擎、触发器、视图、事务处理、备份恢复等多个方面。而实践代码则可能是实际的SQL查询示例,让你有机会亲手操作以巩固理论知识。 1. ...

    数据库面试必备!mysql 面试 55题

    - 候选键是指能够唯一标识一行记录的键,一个表可能有多个候选键,其中一个可被指定为主键,并可用于外键引用。 #### 十八、通过 Unix Shell 登录 MySQL - 登录 MySQL 可以使用以下命令: ```bash [mysqldir]/...

    超全MySQL面试常见题和答案

    - **MERGE**:可以合并多个MyISAM表。 - **MyISAM**:不支持事务,但速度较快,适用于读取密集型应用。 - **InnoDB**:默认引擎,支持事务处理和行级锁,适用于写入密集型应用。 - **Gemeni**:一种实验性的存储...

    55道BAT精选的Mysql面试题!.pdf

    1. **自增主键与ID分配**:在MySQL中,如果一张表有一个自增主键,并且你插入了17条记录,然后删除了第15、16、17条记录,再重启MySQL并插入新记录,新记录的ID会是18,因为自增主键不会重新使用已删除的ID。...

    精选MySQL 55道面试题与答案.docx

    - **多线程SQL服务器**:能够高效处理多个并发请求。 - **广泛的客户端支持**:支持多种客户端程序和库,方便不同平台间的访问。 - **不同的后端**:提供多种存储引擎选项,如InnoDB、MyISAM等。 - **应用程序...

    MySQL面试题(含答案)

    - **多线程SQL服务器**: 支持高并发连接,能够同时处理多个用户请求。 - **客户端/服务器架构**: 允许从不同客户端访问数据。 - **广泛的API支持**: 提供多种编程语言的API,如Java、C++、Python等。 - **管理工具**...

    去BAT面试完的Mysql面试题总结(55道,带完整答案)1

    【MySQL面试题解析】 1、在MySQL中,如果一张表有ID自增主键,插入了17条记录,然后删除了...以上是针对MySQL的一些基础知识点,涵盖了数据类型、事务隔离、存储引擎、性能分析等多个方面,这些都是面试中常见的问题。

    2022年MySQL面试题(含答案)

    1. 关于ID自增主键的问题:如果在MySQL中,一张表的ID是自增主键,删除了部分记录后重启数据库,再插入新记录,ID会跳过已删除的数值继续自增,所以在这例中,新插入的记录ID将是18。 2. MySQL的技术特点包括:开源...

    Mysql数据库学习

    - 当数据分布在多个表中时,需要使用JOIN来关联这些表。 **8.2 多表查询案例** - 示例:假设有两个表`students`和`courses`,可以通过INNER JOIN关联这两张表查询学生选课情况。 **8.3 自连接** - 当表与自身...

    最全MySQL面试60题和答案.docx

    - **主键**:表中的唯一标识符,一张表只能有一个主键,可以由一个或多个字段组成。 - **候选键**:能够唯一标识表中记录的字段,可以成为主键,但不是必须的。 6. **AUTO_INCREMENT的最大值**: 当达到设置的...

    php+mysql留言本

    创建一个新的数据库,并在其中设立一张名为`messages`的表,字段包括`id`(主键,自增长)、`name`(用户名或昵称)、`email`(用户邮箱,用于验证或联系用户)、`content`(留言内容)和`timestamp`(留言时间戳)...

    MySql数据库语法

    * 视图(view):是一个或多个数据表里的数据的逻辑显示,视图就是一张虚拟的表,并不真正存储数据。 * 约束(constraint):执行数据检验规则,用于保证数据完整性的规则。 * 索引(index):用于提高查询性能,...

    《MySQL数据库开发》期末复习答案.doc.pdf

    11. **版本号**:无后缀的MySQL版本意味着它是稳定的发行版,已在多个环境中测试。 12. **选项文件**:MySQL的配置文件通常名为`my.ini`,用于存储启动参数。 13. **ENUM类型**:用于定义只能取预设值之一的列,...

Global site tag (gtag.js) - Google Analytics