MYSQL--如何维护多个自增字段
时间:2010-08-23 来源:909413335
- 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; |
用触发器能解决用LAST_INSERT_ID一次插入多条记录,LAST_INSERT_ID值只改变一次的问题。并且不存在并发操作的问题。