
1 lhx2008 OP 突然发现用注入一个 sqlSessionFactory 用 openSession().getMapper()就可以了,但是不知道有没啥副作用 |
4 lonenol Jan 3, 2018 试试这个: sqlSessionFactory.configuration.mapperRegistry.mappers |
5 lhx2008 OP @lonenol 这个好像返回的是 interface,不是 mybatis 动态代理之后的实体类 public Collection<Class<?>> getMappers() |
6 18583826786 Jan 3, 2018 via Android 额,不一直都是注入 sqlSessionFactoty,然后得到 mapper 吗? spring 有事务控制可以自己关闭 session,这里需要配置 |
7 x18960 Jan 3, 2018 via iPhone 只知道 jdk 的, 同楼主观望其他方法 |
8 zjp Jan 3, 2018 Mapper 可以直接注入啊… mybatis 会动态代理。如楼上所说需要配置事务控制。简单场景用到反射可以肯定是用错了。 |
10 lhx2008 OP @18583826786 如果是正常用法就是直接注入到 xxxmaper 上面,不用 getmapper 啊 |
11 lhx2008 OP 我想是不是要重新自己写一个切面来自动关闭 session 会好一点?如果自己用 getMapper 函数的话。 |
13 zjp Jan 4, 2018 via Android @lhx2008 抱歉才看清楚题目描述…注入 sqlSessionFactoty 是需要手动关闭 session,生命周期已经脱离 Spring 管理 |
14 bxb100 Jan 4, 2018 via Android 有个抽象类叫做 sqlsessiondaosupport 其中有个方法可以获得 spring 管理的 sqlsession 然后你可以 getmapper |
15 bxb100 Jan 4, 2018 via Android 或者直接用 sqlsessiontemplate 拿 |
17 Sypher Jan 4, 2018 也就是说,楼主想要拿( Spring 管理下的) Mapper 去搞事情。#14 楼这种方法适合你 |
18 lonenol Jan 4, 2018 @lonenol 这个好像返回的是 interface,不是 mybatis 动态代理之后的实体类 public Collection<Class<?>> getMappers() 然后再按类型获取一下 bean 应该就可以了吧 |
19 palmers Jan 4, 2018 |
20 nita22 Jan 4, 2018 注入 sqlsessiontemplate,然后可以从 sqlsessiontemplate 里面 getMapper |