软件编程
位置:首页>> 软件编程>> java编程>> MyBatis插入数据返回主键的介绍

MyBatis插入数据返回主键的介绍

作者:Haozz_1994  发布时间:2023-10-26 03:15:21 

标签:mybatis,插入数据,返回主键

Service层:


public int addUser(UserDomian user){
 int i = userMapper.insert(user);
}

xml:


<insert id="insert" parameterType="....UserDomain">
 insert into t_user(user_name,password)
 values
 (#{userName},#{password})
</insert>

这样userMapper的insert方法成功插入之后返回值为影响行数,也就是1。而且插入之后userDomain实体类的userId为null。

我们都知道在MyBatis中,xml的insert语句中将useGeneratedKeys指定为true,那么返回之后就会得到新增的主键值,具体写法如下:


<insert id="insert" parameterType="....UserDomain" useGeneratedKeys="true" keyProperty="userId">
 insert into t_user(user_name,password)values(#{userName},#{password})
</insert>

前提条件是对应的mysql表中id必须是自增的,并且对应的UserDomain实体类中有get、set方法,而且只适用于与mySql数据库,Oracle数据库不支持。

但是这样设置之后,在service层打断点,插入成功之后UserDomain确实和之前不一样,他的userId不再是null了,而是具体的主键id值,但是usetMapper的insert方法的返回值依然是1,也就是插入的影响行数。

也就是说,这样设置,mapper接口返回值依然是成功插入的记录数,但不同的是主键值已经赋值到领域模型实体的id中了。

来源:https://blog.csdn.net/hz_940611/article/details/80773139

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com