Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2372242
  • 博文数量: 473
  • 博客积分: 12252
  • 博客等级: 上将
  • 技术积分: 4307
  • 用 户 组: 普通用户
  • 注册时间: 2007-10-12 10:02
文章分类

全部博文(473)

文章存档

2012年(8)

2011年(63)

2010年(73)

2009年(231)

2008年(98)

分类: Mysql/postgreSQL

2009-07-01 11:12:07

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);
阅读(3198) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

yueliangdao06082009-08-13 10:56:59

为什么会有如此的需求?