你是否在为获取不到Mybatis返回的主键而抓狂?
各种尝试都无效?? 那请往下看
Mybatis 配置文件 useGeneratedKeys 参数只针对 insert 语句生效,默认为 false。当设置为 true 时,表示如果插入的表以自增列为主键,则允许 JDBC 支持自动生成主键,并可将自动生成的主键返回。
用法:
<insert id="insertReturnKey" useGeneratedKeys="true" keyProperty="id" keyColumn="id" parameterType="com.xxxx.xxxx.vo.ProductImage">
insert into t_productimage(pid,type) values(#{pid},#{type})
</insert>
注意:
1.keyColumn=“id” 对应表中的自增主键字段
2.keyProperty=“id” 返回的主键映射到入参JavaBean指定的属性字段
3.返回的主键是赋值到入参JavaBean的属性值上!!!
返回的主键是赋值到入参JavaBean的属性值上!!!
返回的主键是赋值到入参JavaBean的属性值上!!!
4.获取返回的自增主键
Integer id = productImage.getId();
public Integer saveProductImage(ProductImage productImage) {
AssertUtil.isTrue(null==productImage.getPid(),"请指定商品id");
AssertUtil.isTrue(null==productMapper.selectByPrimaryKey(productImage.getPid()),"商品id不存在!");
Integer row = productImageMapper.insertReturnKey(productImage);
AssertUtil.isTrue(row<1,"商品图片信息保存失败!");
//获取插入数据返回的主键
Integer id = productImage.getId();
return id;
}