jQuery火箭图标返回顶部代码

mybatis mysql 批量insert 返回主键

Mybatis在插入单条数据的时候有两种方式返回自增主键:    mybatis3.3.1支持批量插入后返回主键ID,

首先对于支持自增主键的数据库:useGenerateKeys和keyProperty。

不支持生成自增主键的数据库:<selectKey>。

这里主要说下批量插入数据时如何返回主键ID(注意要将mybatis升到3.3.1)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
public class UserInfo
{
    private int userId;
    private String userName;
    private StringuserPwd;
    public long getUserId() {
        return userId;
    }
    public void setUserId(long userId) {
        this.userId = userId;
    }
    public String getUserName() {
        return userName;
    }
    public void setUserName(String userName) {
        this.userName = userName;
    }
    public String getUserPwd() {
        return userPwd;
    }
    public void setUserPwd(String userPwd) {
        this.userPwd = userPwd;
    }
    
 
    
}

  

Dao 

1
public interface UserDao{  int insertTest(List<UserInfo> userInfo);}<br>

  

mapper

1
2
3
4
5
6
7
8
<insert id="insertTest" parameterType="java.util.List" useGeneratedKeys="true" keyProperty="userId">
   insert into t_sys_course (user_name,user_pwd)
   values
    <foreach collection="list" item="item" index="index" 
         separator=","> 
         (#{item.userName,jdbcType=VARCHAR},#{item.userPwd,jdbcType=VARCHAR}) 
     </foreach
 </insert>

serviceImpl

1
2
3
4
public  List<UserInfo> saveCheckin(List<UserInfo> userInfo) {
        userDao.insertCheckin(userInfo);
        return userInfo;
    }<br>//返回的对象List里面已经包含主键ID
posted @   小狮子001  阅读(28265)  评论(10编辑  收藏  举报
编辑推荐:
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
阅读排行:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
点击右上角即可分享
微信分享提示