Mybatis如何通过泛型来动态调整返回参数

简介: Mybatis如何通过泛型来动态调整返回参数

在我们使用Mybatis的时候,会设置一个resultType类型,这个类型一般指定为java.util.Map,如此的话,我们就可以使用List,Map来接收返回结果了。

现在想要的效果其实就是想要在service层分别用两种不同的类型的进行接收同一个SQL的参数。

就比如如下的代码中一样的。

List<ADemo> list1 = demoDao.findDemo();
Long total = demoDao.findDemo();

这里我们就来看一下具体的实现吧。

知识点

首先想要的解决方式就是泛型,只有泛型才能指定不同的类型之间的转换。

这里我们要说的是如何给方法加入泛型,以满足返回值类型不同的情况。

方法加泛型,自然就是用来修饰了,如下代码。

<T> T findDemo();

上面的代码就可以使用任何返回类型来接收了。

但是很重要的一点,当resultType=java.util.Map的时候,这样写的时候是会报错的。

所以我们就改写了一种的方式。

<T> List<T> findDemo();

这样,我们换了一种方式,如上代码所示,果然,很完美的运行了,随着泛型不同的方式注入,如下代码:

List<ADemo> list1 = demoDao.findDemo();
List<Map<String,Long>> list2 = demoDao.findDemo();

如果想要取到之前的Long值,就可以使用list2.get(0).get('total')进行获取对应的long值了。

如此虽然没有全部实现想要的效果,但是也在允许范围之内解决了这个问题。

目录
相关文章
|
21天前
|
SQL Java 关系型数据库
Mybatis多表关联查询与动态SQL(下)
Mybatis多表关联查询与动态SQL
37 0
|
21天前
|
SQL Java 数据库连接
Mybatis多表关联查询与动态SQL(上)
Mybatis多表关联查询与动态SQL
19 0
|
1天前
|
SQL XML Java
Mybatis进阶——动态SQL(1)
Mybatis进阶——动态SQL(1)
13 3
|
8天前
|
SQL XML Java
|
13天前
|
SQL XML Java
MyBatis的强大特性--动态SQL
MyBatis的强大特性--动态SQL
28 2
|
21天前
|
SQL Java 数据库连接
【JavaEE】懒人的福音-MyBatis框架—复杂的操作-动态SQL(下)
【JavaEE】懒人的福音-MyBatis框架—复杂的操作-动态
14 0
|
21天前
|
SQL Java 数据库连接
【JavaEE】懒人的福音-MyBatis框架—复杂的操作-动态SQL(上)
【JavaEE】懒人的福音-MyBatis框架—复杂的操作-动态SQL
13 0
|
21天前
|
SQL Java 数据库连接
mybatis动态sql
mybatis动态sql
|
21天前
|
SQL Java 数据库连接
MyBatis #与$的区别以及动态SQL
MyBatis #与$的区别以及动态SQL
17 0
|
21天前
|
XML Java 数据库连接
MyBatis 解决上篇的参数绑定问题以及XML方式交互
MyBatis 解决上篇的参数绑定问题以及XML方式交互
17 0