美文网首页
查出获得自增产生的ID值

查出获得自增产生的ID值

作者: 笨比乔治 | 来源:发表于2020-12-04 11:07 被阅读0次
  <!--通过mybatis框架提供的selectKey标签获得自增产生的ID值-->
        <selectKey resultType="java.lang.Integer" order="AFTER" keyProperty="id">
            select LAST_INSERT_ID()
        </selectKey>

如果设置为 before,那么它会首先选择主键,设置 keyProperty 然后执行插入语句。如果设置为after,那么先执行插入语句,然后是 selectKey 元素-这和如 Oracle 数据库相似,可以在插入语句中嵌入序列调用。
keyProperty="id" 查出来后的值,通过id输出,但是id必须与类中的属性一致。

image.png

MySQL的LAST_INSERT_ID的注意事项:

查询和插入所使用的Connection对象必须是同一个才可以,否则返回值是不可预料的。
mysql> SELECT LAST_INSERT_ID();
        -> 100

使用这函数向一个给定Connection对象返回的值是该Connection对象产生对影响AUTO_INCREMENT列的最新语句第一个AUTO_INCREMENT值的。
这个值不能被其它Connection对象的影响,即它们产生它们自己的AUTO_INCREMENT值。
2.LAST_INSERT_ID 是与table无关的,如果向表a插入数据后,
再向表b插入数据,LAST_INSERT_ID返回表b中的Id值。
第三、 假如你使用一条INSERT语句插入多个行,  LAST_INSERT_ID() 只返回插入的第一行数据时产生的值。其原因是这使依靠其它服务器复制同样的 INSERT语句变得简单。

mysql> INSERT INTO t VALUES

    -> (NULL, ‘Mary'), (NULL, ‘Jane'), (NULL, ‘Lisa');

mysql> SELECT * FROM t;

| id | name |

+—-+——+

|  1 | Bob  |

|  2 | Mary |

|  3 | Jane |

|  4 | Lisa |

mysql> SELECT LAST_INSERT_ID();  //这就是我要说明的关键问题。

| LAST_INSERT_ID() |

|                2 |

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

相关文章

网友评论

      本文标题:查出获得自增产生的ID值

      本文链接:https://www.haomeiwen.com/subject/atfvpktx.html