在service层进行插入操作时,需要调用mapper的insertSelective(Bean bean);
在mapper.xml中,会调用相应的sql配置,并且会返回一个int值,这个值是数据库中受该操作影响的数据行数。
<insert id="insertSelective" parameterType="com.xianer.model.Goods" >
。。。
</insert>
一般如果数据库表设置主键自增长,插入数据时一般不会插入主键值。如果在插入数据的同时还想获得该条数据自动生成的主键该怎么办呢。
这个时候就通过useGeneratedKeys="true" keyProperty="id" 来实现,id是你修改数据的表的主键字段,将这两个属性添加到mapper.xml对于的sql配置中。
<insert id="insertSelective" parameterType="com.xianer.model.Goods" useGeneratedKeys="true" keyProperty="id">
。。。
</insert>
接下来在service中通过
//Bean 是需要插入数据的表的实体类
public int insert(Bean bean){
mapper.insertSelective(bean);
return bean.getId(); //xml中添加useGeneratedKeys="true" keyProperty="id" 两个属性,执
//行完xml中的响应sql配置后,该bean对象id属性已被自动赋值,直接获取就可以
}