V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
lhx2008
V2EX  ›  Java

用 Spring 拉取的 Mybatis 的 Mapper,除了用 @Autowired,还有用什么方法可以拿到?

  •  
  •   lhx2008 ·
    xenv · 2018-01-03 22:43:22 +08:00 · 4529 次点击
    这是一个创建于 2567 天前的主题,其中的信息可能已经有所发展或是发生改变。
    我想做到根据 String 自动获取到 Mapper,
    但是好像 capableBeanFactory.autowireBean 和 capableBeanFactory.getBean 都拿不到,我搜索了好久也没啥结果
    现在比较折中的方法只能把所有 Mapper 都 Autowired 进来,再用反射 get 那个 mapper,有点蛋疼
    22 条回复    2018-01-06 08:15:11 +08:00
    lhx2008
        1
    lhx2008  
    OP
       2018-01-03 22:57:14 +08:00
    突然发现用注入一个 sqlSessionFactory 用 openSession().getMapper()就可以了,但是不知道有没啥副作用
    aristotll
        2
    aristotll  
       2018-01-03 22:59:29 +08:00
    @lhx2008 那样你就要 close 自己那个 open 开的 session 了吧
    lhx2008
        3
    lhx2008  
    OP
       2018-01-03 23:05:23 +08:00
    @aristotll 对呀,@Autowired 的 seesion 应该是 spring 管理的,自己弄一个不知道 Spring 会不会自动帮我关
    lonenol
        4
    lonenol  
       2018-01-03 23:13:42 +08:00
    试试这个:
    sqlSessionFactory.configuration.mapperRegistry.mappers
    lhx2008
        5
    lhx2008  
    OP
       2018-01-03 23:18:10 +08:00
    @lonenol 这个好像返回的是 interface,不是 mybatis 动态代理之后的实体类
    public Collection<Class<?>> getMappers()
    18583826786
        6
    18583826786  
       2018-01-03 23:26:31 +08:00 via Android
    额,不一直都是注入 sqlSessionFactoty,然后得到 mapper 吗? spring 有事务控制可以自己关闭 session,这里需要配置
    x18960
        7
    x18960  
       2018-01-03 23:28:03 +08:00 via iPhone
    只知道 jdk 的, 同楼主观望其他方法
    zjp
        8
    zjp  
       2018-01-03 23:31:00 +08:00
    Mapper 可以直接注入啊… mybatis 会动态代理。如楼上所说需要配置事务控制。简单场景用到反射可以肯定是用错了。
    lhx2008
        9
    lhx2008  
    OP
       2018-01-03 23:53:59 +08:00 via Android
    @zjp 问题是我现在不知道是那个 mapper,要运行的时候传参进来才能确定,所以在 mapper 上面自动注入是不行的
    lhx2008
        10
    lhx2008  
    OP
       2018-01-03 23:54:44 +08:00 via Android
    @18583826786 如果是正常用法就是直接注入到 xxxmaper 上面,不用 getmapper 啊
    lhx2008
        11
    lhx2008  
    OP
       2018-01-03 23:55:59 +08:00 via Android
    我想是不是要重新自己写一个切面来自动关闭 session 会好一点?如果自己用 getMapper 函数的话。
    lhx2008
        12
    lhx2008  
    OP
       2018-01-03 23:56:57 +08:00 via Android
    @zjp 反射还挺常用吧,特别是抽象重复方法的时候
    zjp
        13
    zjp  
       2018-01-04 00:25:35 +08:00 via Android
    @lhx2008 抱歉才看清楚题目描述…注入 sqlSessionFactoty 是需要手动关闭 session,生命周期已经脱离 Spring 管理
    bxb100
        14
    bxb100  
       2018-01-04 09:29:49 +08:00 via Android   ❤️ 1
    有个抽象类叫做 sqlsessiondaosupport 其中有个方法可以获得 spring 管理的 sqlsession 然后你可以 getmapper
    bxb100
        15
    bxb100  
       2018-01-04 09:37:03 +08:00 via Android
    或者直接用 sqlsessiontemplate 拿
    lhx2008
        16
    lhx2008  
    OP
       2018-01-04 11:12:42 +08:00 via Android
    @bxb100 谢谢,我回去试试
    Sypher
        17
    Sypher  
       2018-01-04 11:44:28 +08:00
    也就是说,楼主想要拿( Spring 管理下的) Mapper 去搞事情。#14 楼这种方法适合你
    lonenol
        18
    lonenol  
       2018-01-04 13:23:57 +08:00
    @lonenol 这个好像返回的是 interface,不是 mybatis 动态代理之后的实体类
    public Collection<Class<?>> getMappers()

    然后再按类型获取一下 bean 应该就可以了吧
    palmers
        19
    palmers  
       2018-01-04 13:31:54 +08:00   ❤️ 1
    统一 @bxb100 童鞋的做法 类似这样:
    ```java
    public class BaseService<T, M> extends SqlSessionDaoSupport {
    /**
    * model T 对应的 Mapper 类 -- 用的时候传进来
    */
    private Class<M> mapperClass;

    @Override
    public M getMapper() throws DataAccessException {
    return getSqlSession().getMapper(mapperClass);
    }

    ............
    ```
    nita22
        20
    nita22  
       2018-01-04 20:31:02 +08:00   ❤️ 1
    注入 sqlsessiontemplate,然后可以从 sqlsessiontemplate 里面 getMapper
    lhx2008
        21
    lhx2008  
    OP
       2018-01-04 23:37:32 +08:00 via Android
    @palmers 就是我想要的效果哈哈,不过我还是用了 sqlsessiontemplate 比较自由一点,我还想把关联查询在 service 层统一封装了(基于 jpa 的注解),所以要一个自由 getMapper 的函数
    lhx2008
        22
    lhx2008  
    OP
       2018-01-06 08:15:11 +08:00 via Android
    @palmers 昨天弄了才知道,实际上你这个代码是跑不了的,泛型被擦掉了。我是自己又包装了一个工厂函数把 mapper interface 传进去拿到 entity
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5693 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 03:02 · PVG 11:02 · LAX 19:02 · JFK 22:02
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.