记录一下,免得以后忘记
这里就直接贴上代码了,注解很详细
xml代码:
<insert id="insertEquipment" parameterType="EquipmentInfo">
<!--
parameterType是实体类对象,不是数据类型
将insert插入的数据的主键返回到EquipmentInfo对象中;
select last_insert_id():得到刚刚添加进去记录的主键值,必须自增主键;
selectKey 会将 SELECT LAST_INSERT_ID()的结果放入到传入的model的主键里面,
keyProperty 对应的model中的主键的属性名,这里是 EquipmentInfo 中的equipmentId,因为它跟数据库的主键对应
order AFTER 表示 SELECT LAST_INSERT_ID() 在insert执行之后执行,多用与自增主键,相对于insert语句
BEFORE 表示 SELECT LAST_INSERT_ID() 在insert执行之前执行,这样的话就拿不到主键了,
这种适合那种主键不是自增的类型
resultType 主键数据类型
-->
insert into equipment_info(equipment_num) values (#{equipmentNum})
<selectKey keyProperty="equipmentId" order="AFTER" resultType="int">
select LAST_INSERT_ID()
</selectKey>
</insert>
mapper代码:
public int insertEquipment(EquipmentInfo equipmentInfo);
这里的maper中返回的是添加成功后,数据库的影响行数,不是主键id,须注意
int equipmentId = new EquipmentInfo().getEquipmentId();
主键id需要通过get方法获取
注意事项:
1、parameterType传入的是实体类对象,不能是数据类型(本人改为实体类型,就能获取主键了,不知道是否必须是实体类,暂未弄明白,须继续学习)。
2、对应的mapper文件中,参数不能用@Param()注解
3、对应表必须主键自增