mybatis之接口方法多参数的三种实现方式

本文通过示例展示了在MyBatis中使用不同方式处理多参数插入的方法,包括直接传参、使用注解和Map传参的方式,并提供了具体的XML配置及Java代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 关键代码举例:

DaoMapper.xml

 1     <!-- 传入多个参数时,自动转换为map形式 -->
 2     <insert id="insertByColumns" useGeneratedKeys="true" keyProperty="id">
 3         insert into user (id, name, age) values (NULL ,#{param1}, #{param2})
 4     </insert>
 5     <insert id="insertByZhuJie" useGeneratedKeys="true" keyProperty="id">
 6         insert into user (id, name, age) values (NULL ,#{name}, #{age})
 7     </insert>
 8     <insert id="insertByMap" useGeneratedKeys="true" keyProperty="id">
 9         insert into user (id, name, age) values (NULL ,#{name}, #{age})
10     </insert>

 

UserDao.java

1     // 插入数据;多参数三种方式:默认Map、使用Map传参和使用注解别名
2     public int insertByColumns(String name, int age);
3     public int insertByZhuJie(@Param("name") String name, @Param("age") int age);
4     public int insertByMap(Map map);

 

TestDao.java

 1     //   多参数插入数据的三种方式
 2     @Test
 3     public void testInsertByColumns() {
 4         UserDao userDao = session.getMapper(UserDao.class);
 5         String name = "insertByColumns";
 6         int age = 33;
 7 //        int n = userDao.insertByColumns(name, age);
 8 //        int n = userDao.insertByZhuJie(name, age);
 9 
10         Map map = new HashMap();
11         map.put("name", name);
12         map.put("age", age);
13         int n = userDao.insertByMap(map);
14 
15         session.commit();
16         System.out.println("插入数据name:" + name);
17         System.out.println(n);
18     }

 

转载于:https://www.cnblogs.com/gongxr/p/8288233.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值