文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>MYSQL--如何维护多个自增字段

MYSQL--如何维护多个自增字段

时间:2010-08-23  来源:909413335

要求:某个表里有多个字段,都是需要自动增长的,但是表内只允许一个自增字段,其他字段如何实现自动增长。   实现方式一: 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值只改变一次的问题。并且不存在并发操作的问题。
相关阅读 更多 +
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载