MySQL - 触发器 - 插入和使用SK(自动增量)之前

时间:2015-04-14 20:17:55

标签: mysql triggers surrogate-key

我在MySQL中有一个简单的posts表,它有一个POST_ID作为SK(代理键)。 对原始帖子ID的回复存储在PARENT_POST_ID列的同一个表中,但我想执行以下逻辑:

在插入之前(我认为......)

如果在INSERT上没有定义PARENT_POST_ID ,则将行值默认为新生成的POST_ID(来自auto-int序列)

如果在INSERT上定义了PARENT_POST_ID ,则将其设置为已传递的内容。

示例

post_id | parent_post_id | date_time        | message
     12               12   2015-04-14 21:10   A new post (start of a thread)
     13               12   2015-04-14 21:12   A reply to the post ID 12

答案在这里:https://stackoverflow.com/a/11061766/1266457看起来可能是我需要做的事情,虽然我不确定它在做什么。

感谢。

1 个答案:

答案 0 :(得分:1)

对于before insert trigger,你不能获得最后一个插入的主键,另一种方法是从表中获取最大值并递增它。

这是一种方法

delimiter //
create trigger posts_before_ins before insert on posts
for each row 
begin
  declare last_id int; 
  if new.parent_post_id is null then
    select max(post_id) into last_id from posts ;
    if last_id is null then
      set new.parent_post_id = 1 ;
    else
      set new.parent_post_id = last_id+1 ;
    end if ;
   end if ;
end ;//

delimiter ;

因此,触发器将检查插入查询中是否没有parent_post_id的值,它将获得最大post_id。对于第一个条目,它将为null,因此我们将其设置为1,即在每个条目之后的最大post_id + 1之后。

这是mysql中的一个测试用例

mysql> select * from test ;
Empty set (0.00 sec)

mysql> delimiter //
mysql> create trigger test_is before insert on test
    -> for each row 
    -> begin
    ->   declare last_id int; 
    ->   if new.parent_id is null then
    ->     SELECT auto_increment into last_id
    ->     FROM INFORMATION_SCHEMA.TABLES WHERE table_name = 'test'
    ->     and TABLE_SCHEMA = 'test';
    ->     set new.parent_id = last_id ;
    ->    end if ;
    -> end ;//
Query OK, 0 rows affected (0.12 sec)

mysql> 
mysql> delimiter ;

mysql> insert into test (val) values ('aa');
Query OK, 1 row affected (0.10 sec)

mysql> insert into test (val) values ('bb');
Query OK, 1 row affected (0.04 sec)

mysql> select * from test ;
+---------+-----------+------+
| post_id | parent_id | val  |
+---------+-----------+------+
|       1 |         1 | aa   |
|       2 |         2 | bb   |
+---------+-----------+------+
2 rows in set (0.00 sec)