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

Posted 星瑞的随笔

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mybatis之接口方法多参数的三种实现方式相关的知识,希望对你有一定的参考价值。

 关键代码举例:

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     }

 

以上是关于mybatis之接口方法多参数的三种实现方式的主要内容,如果未能解决你的问题,请参考以下文章

MyBatis教程之三—多参数的获取方式

Java——多线程高并发系列之创建多线程的三种方式(ThreadRunnableCallable)

Java——多线程高并发系列之创建多线程的三种方式(ThreadRunnableCallable)

MyBatis多参数处理问题

Java创建多线程的三种方法

27多线程(多线程的三种实现方式Thread线程类的常见方法线程安全问题)