文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>在mysql中添加两个自动更新的timestamp字段

在mysql中添加两个自动更新的timestamp字段

时间:2009-07-01  来源:sss0213

在MySql 5.0 的表里同时添加两个自动更新的timestamp字段
有时我们需要在一张表里实现两种timestamp属性的字段,一种是在insert的时候自动赋值,另一种是在update时候赋值,但是在,mysql5.0里面这两种字段十户无法共存,比如你在创建者张表时:
java 代码
  1. CREATE TABLE blog_entries (
  2. `published` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  3. `updated` TIMESTAMP DEFAULT '0000-00-00 00:00:00' ON UPDATE CURRENT_TIMESTAMP,
  4. `title` VARCHAR(128)
  5. );
数据库会报错: ERROR 1293 (HY000): Incorrect table definition; there can be only one
TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause

解决办法是使用trigger,首先将上面新建表格的语句改成以下内容:
java 代码
  1. CREATE TABLE blog_entries (
  2. `published` TIMESTAMP DEFAULT '0000-00-00 00:00:00',
  3. `updated` TIMESTAMP DEFAULT '0000-00-00 00:00:00',
  4. `title` VARCHAR(128)
  5. );
然后写两个trigger:
java 代码
  1. CREATE TRIGGER blog_entries_publish BEFORE INSERT ON `blog_entries`
  2. FOR EACH ROW SET NEW.published = NOW(), NEW.updated = '0000-00-00 00:00:00';
java 代码
  1. CREATE TRIGGER blog_entries_update BEFORE UPDATE ON `blog_entries`
  2. FOR EACH ROW SET NEW.updated = NOW(), NEW.published = OLD.published;
这样子似乎可以了,但是问题却随之而来了,如果你想手动更改updated的值怎么办?没错你改不了,为了解决这个问题我们在此作如下改动:
java 代码
  1. CREATE TABLE blog_entries (
  2. `published` TIMESTAMP NULL DEFAULT NULL,
  3. `updated` TIMESTAMP NULL DEFAULT NULL,
  4. `title` VARCHAR(128)
  5. );
  6. CREATE TRIGGER blog_entries_publish BEFORE INSERT ON `blog_entries` FOR EACH ROW SET
  7. NEW.published = IFNULL(NEW.published, NOW()),
  8. NEW.updated = IFNULL(NEW.updated, '0000-00-00 00:00:00');
  9. CREATE TRIGGER blog_entries_update BEFORE UPDATE ON `blog_entries` FOR EACH ROW SET
  10. NEW.updated = IF(NEW.updated = OLD.updated OR NEW.updated IS NULL, NOW(), NEW.updated),
  11. NEW.published = IFNULL(NEW.published, OLD.published);
好了,现在你可以随意改动update,但是如果你没有传值给update会怎么样呢?这时NEW.updated 默认等于OLD.update值,如果你传NULL给update无效,所以你必须再做一点改动,判断这个条件:
java 代码
  1. CREATE TRIGGER blog_entries_update BEFORE UPDATE ON `blog_entries` FOR EACH ROW SET
  2. NEW.updated = CASE
  3. WHEN NEW.updated IS NULL THEN OLD.updated
  4. WHEN NEW.updated = OLD.updated THEN NOW()
  5. ELSE NEW.updated
  6. END,
  7. NEW.published = IFNULL(NEW.published, OLD.published);
相关阅读 更多 +
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载