Chinaunix首页 | 论坛 | 博客
  • 博客访问: 494766
  • 博文数量: 99
  • 博客积分: 3621
  • 博客等级: 中校
  • 技术积分: 1089
  • 用 户 组: 普通用户
  • 注册时间: 2010-06-22 16:29
文章存档

2012年(21)

2011年(28)

2010年(50)

分类: Mysql/postgreSQL

2010-08-23 10:41:36

要求:某个表里有多个字段,都是需要自动增长的,但是表内只允许一个自增字段,其他字段如何实现自动增长。
 
实现方式一:
1:insert A(name,mark)values('job',last_insert_id()+1);
手册上对LAST_INSERT_ID()的说明如下:
 
  • LAST_INSERT_ID() LAST_INSERT_ID(expr)
  • 自动返回最后一个INSERT UPDATE 问询为 AUTO_INCREMENT列设置的第一个 发生的值。

    mysql> SELECT LAST_INSERT_ID();

            -> 195

    产生的ID 每次连接后保存在服务器中。这意味着函数向一个给定客户端返回的值是该客户端产生对影响AUTO_INCREMENT列的最新语句第一个 AUTO_INCREMENT值的。这个值不能被其它客户端影响,即使它们产生它们自己的 AUTO_INCREMENT值。这个行为保证了你能够找回自己的 ID 而不用担心其它客户端的活动,而且不需要加锁或处理。

    假如你使用一个非“magic”值来更新某一行的AUTO_INCREMENT 列,则LAST_INSERT_ID() 的值不会变化(换言之, 一个不是 NULL也不是 0的值)

    重点: 假如你使用单INSERT语句插入多个行,  LAST_INSERT_ID() 返回插入的第一行产生的值。其原因是这使依靠其它服务器复制同样的 INSERT语句变得简单。

    重点有在

    1:每个连接保存自己的LAST_INSERT_ID值。

    2:一次插入多条,只当一次插入,LAST_INSERT_ID只改变一次。

    实现方式二:

    用触发器来维护多个自增字段。如下

     

    drop trigger if exists trig1;
    CREATE DEFINER=`cpc`@`localhost` TRIGGER `test`.`trig1` BEFORE INSERT ON test.a FOR EACH ROW
    BEGIN
        set new.bb=(select if(isnull(aa),1,aa+1) from (select max(aa) as aa from a) tmp);
    END;


    用触发器能解决用LAST_INSERT_ID一次插入多条记录,LAST_INSERT_ID值只改变一次的问题。并且不存在并发操作的问题。
    阅读(5177) | 评论(1) | 转发(0) |
    给主人留下些什么吧!~~

    chinaunix网友2010-08-25 08:24:48

    Download More than 1000 free IT eBooks: http://free-ebooks.appspot.com