mybatis+mysqlinsert 添加数据后返回数据主键id

mac2023-06-09  37

1.根据useGeneratedKeys获取返回值(部分数据库不支持)

修改mybatis xml

<insert id="insertUser" useGeneratedKeys="true" keyProperty="id" parameterType="com.entity.user"> insert into test (name) values (#{name}) </insert>

useGeneratedKeys="true" :设置是否使用JDBC的getGenereatedKeys方法获取主键并赋值到keyProperty设置的领域模型属性中。(适用于mysql、sqlserver数据库,oracle不能使用,使用selectkey子节点做)

keyProperty:赋值的对象的属性名称。

添加完成后,直接根据对象属性取值。

user u=new user(); u.setName("测试"); System.out.println(u.getId()+"取值前"); //0 int num = this.dao.getSqlSession().insert("insertUser",u); System.out.println(u.getId()+"取值后"); //15 上面xml的传入参数是map,selectKey会将结果放到入参数map中。用POJO的情况一样,但是有一点需要注意的是,keyProperty对应的字段在POJO中必须有相应的setter方法,setter的参数类型还要一致,否则会报错。 注意 (1)若传入参数为Map类型,需在传入前保证map内包含字段为id的属性,否则无法装填; (2)dao指定参数 (3)需将keyProperty属性 进行修改 如下: 实现类: HashMap<String, Object> map = new HashMap<>(); map.put("shopRenovationId",shopRenovationId); map.put("userId",userId); map.put("id",""); propDao.propMallShopRenovationGet(map); logger.info(">>>>>>返回主键为:" + map.get("id")); dao: void propMallShopRenovationGet(@Param("map") HashMap<String, Object> map); mapper: <insert id="propMallShopRenovationGet" useGeneratedKeys="true" keyProperty="map.id" parameterType="java.util.HashMap"> insert into shop_user_renovation ( shop_renovation_id, user_id, create_time )value( #{map.shopRenovationId}, #{map.userId}, unix_timestamp(now()) ) </insert>

2.根据selectkey获取

<insert id="insertUser" parameterType="com.entity.user"> insert into test (name) values (#{name}) <selectKey keyProperty="id" resultType="java.lang.Integer"> select LAST_INSERT_ID() as id </selectKey> </insert>

后台代码不变。

各个数据库获取方式不一样,本例根据mysql为例。其他请各自根据需要查询。

最新回复(0)