Mysql函数Last_insert_id()的真正含义

本文详细介绍了MySQL LAST_INSERT_ID()函数的工作原理,包括它如何自动返回最近INSERT或UPDATE操作中AUTO_INCREMENT列的值,以及它如何在单个客户端会话中保持独立于其他客户端。通过示例演示了函数在不同场景下的应用,如插入单行和多行数据。
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语句变得简单。

例如:

mysql> USE test;
Database changed
mysql> CREATE TABLE t (
    ->   id INT AUTO_INCREMENT NOT NULL PRIMARY KEY,
    ->   name VARCHAR(10) NOT NULL
    -> );
Query OK, 0 rows affected (0.09 sec)

mysql> INSERT INTO t VALUES (NULL, 'Bob');
Query OK, 1 row affected (0.01 sec)

mysql> SELECT * FROM t;
+----+------+
| id | name |
+----+------+
|  1 | Bob  |
+----+------+
1 row in set (0.01 sec)

mysql> SELECT LAST_INSERT_ID();
+------------------+
| LAST_INSERT_ID() |
+------------------+
|                1 |
+------------------+
1 row in set (0.00 sec)

mysql> INSERT INTO t VALUES
    -> (NULL, 'Mary'), (NULL, 'Jane'), (NULL, 'Lisa');
Query OK, 3 rows affected (0.00 sec)
Records: 3  Duplicates: 0  Warnings: 0

mysql> SELECT * FROM t;
+----+------+
| id | name |
+----+------+
|  1 | Bob  |
|  2 | Mary |
|  3 | Jane |
|  4 | Lisa |
+----+------+
4 rows in set (0.01 sec)

mysql> SELECT LAST_INSERT_ID();  //这就是我要说明的关键问题。
+------------------+
| LAST_INSERT_ID() |
+------------------+
|                2 |
+------------------+
1 row in set (0.00 sec)

虽然第二个问询将3 个新行插入 t, 对这些行的第一行产生的 ID 为 2, 这也是 LAST_INSERT_ID()返回的值。

假如你使用 INSERT IGNORE而记录被忽略,则AUTO_INCREMENT 计数器不会增量,而 LAST_INSERT_ID() 返回0, 这反映出没有插入任何记录。

<think>好的,用户想了解MySQLlast_insert_id()函数的用法和相关问题。首先,我需要回顾一下这个函数的基本定义和常见用途。last_insert_id()用于获取最后一次插入操作生成的自增ID,这在插入数据后需要获取新记录的ID时非常有用,尤其是在处理关联表时。 接下来,我应该考虑用户可能的实际应用场景。比如,用户可能在插入一条记录后,需要立即使用这个ID来更新其他表,或者在日志记录中使用。这时候正确获取最后一个自增ID就显得很重要了。 然后,我需要确认函数的行为细节。例如,当一次插入多行数据时,last_insert_id()会返回第一个插入行的ID,而不是最后一个。这一点用户可能会忽略,需要特别说明。同时,如果插入操作没有生成任何自增ID(比如表没有自增列),函数会返回0,这也需要提到。 还要考虑不同连接中的行为。每个连接都有自己的last_insert_id()值,互不影响。这对于多线程或并发操作的环境很重要,用户需要知道这个函数是连接特定的。 接下来,示例部分很重要。用户可能需要具体的SQL语句来理解如何使用这个函数。比如,插入数据后立即查询last_insert_id(),或者在同一个连接中连续插入时的情况。另外,多行插入的例子也能帮助用户理解返回值的规则。 此外,用户可能遇到的问题包括函数返回0的情况,或者在不同连接中获取不到预期的ID。这时候需要解释可能的原因,比如没有自增列、插入失败,或者是在不同的连接中查询。 还需要提到事务的影响,如果在事务中插入但未提交,last_insert_id()是否会受到影响?根据MySQL的文档,即使在事务中,只要插入操作执行了,last_insert_id()就会更新,即使事务回滚,这个值可能不会被重置,这一点需要注意。 最后,生成相关的问题可以帮助用户进一步探索。比如,函数在多行插入时的行为、并发情况下的处理、与事务的交互,以及常见错误排查。这些扩展问题能引导用户更全面地理解和应用这个函数。 总结起来,回答需要覆盖基本用法、行为细节、示例演示、注意事项以及相关问题,确保用户能够正确使用last_insert_id()并避免常见错误。</think>### MySQLLAST_INSERT_ID()函数详解 #### 一、基本特性 1. **功能定义**:`LAST_INSERT_ID()`用于获取当前会话中**最近一次成功插入**的自增列(AUTO_INCREMENT)值 2. **作用范围**:返回值仅在当前数据库连接中有效,不同客户端的连接互不影响[^3] 3. **返回值特性**: - 单行插入返回新生成的自增ID - 多行插入返回**第一个插入行的ID**(例如批量插入5条记录时返回第一条的ID) - 未插入数据时返回0 #### 二、典型使用场景 ```sql -- 示例1:基本用法 CREATE TABLE users ( id INT AUTO_INCREMENT PRIMARY KEY, username VARCHAR(50) ); INSERT INTO users (username) VALUES ('john_doe'); SELECT LAST_INSERT_ID(); -- 返回新插入的id值 -- 示例2:多表关联插入 INSERT INTO orders (user_id, amount) VALUES (LAST_INSERT_ID(), 100.00); -- 使用
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值