mybatis獲取insert之後資料庫自動生成的id
阿新 • • 發佈:2019-02-11
需求:使用MyBatis往MySQL資料庫中插入一條記錄後,需要返回該條記錄的自增主鍵值。
方法:在mapper中指定keyProperty屬性,示例如下:
- <insertid="insertAndGetId"useGeneratedKeys="true"keyProperty="userId"parameterType="com.chenzhou.mybatis.User">
- insert into user(userName,password,comment)
-
values(#{userName},#{password},#{comment})
- </insert>
如上所示,我們在insert中指定了keyProperty="userId",其中userId代表插入的User物件的主鍵屬性。
- publicclass User {
- privateint userId;
- private String userName;
- private String password;
- private String comment;
- //setter and getter
- }
UserDao.java
-
publicinterface UserDao {
- publicint insertAndGetId(User user);
- }
測試:
- User user = new User();
- user.setUserName("chenzhou");
- user.setPassword("xxxx");
- user.setComment("測試插入資料返回主鍵功能");
- System.out.println("插入前主鍵為:"+user.getUserId());
- userDao.insertAndGetId(user);//插入操作
-
System.out.println("插入後主鍵為:"