日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

spring源码之模拟mybatis第三方对象注入

發布時間:2024/1/18 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 spring源码之模拟mybatis第三方对象注入 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

有下面幾種方法

  • 注解(@Service)
  • XML方式
  • 注解(@Bean)
  • factoryBean
  • spring 容器api
  • 動態向容器注冊beanDefinition
  • 看到這幾種方式的時候,需要我們自己思考一下,在注冊這個對象之前,是需要自己手動生成的。
    那么使用注解Service和XML的方式肯定是不行的,因為這個只是把一個類交給了spring容器管理,并不是生成的對象交給他。所以前兩種方式不可行。
    第六種方式也是不行的,至于為什么不行,我們到后面再說。

    注解(@Bean)

    public class BatisConfig {@Beanpublic TMapper getTMapper(){TMapper tMapper = (TMapper) MySqlSession.getMapper(TMapper.class);return tMapper;}}@Testpublic void customBatis(){AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(BatisConfig.class);TMapper mapper = context.getBean(TMapper.class);mapper.queryMap("1");}//打印結果 假裝連接數據庫 假裝執行了查詢語句select * from t where id = ${id} 假裝返回了JSON串

    FactoryBean

    @Component public class MyFactoryBean implements FactoryBean {@Overridepublic Object getObject() throws Exception {System.out.println("實例化了Mapper");TMapper tMapper = (TMapper) MySqlSession.getMapper(TMapper.class);return tMapper;}@Overridepublic Class<?> getObjectType() {return TMapper.class;} }@Testpublic void customBatis(){AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext();context.scan("com.spring.batis");context.refresh();TMapper mapper = context.getBean(TMapper.class);mapper.queryMap("1");}//打印結果 假裝連接數據庫 假裝執行了查詢語句select * from t where id = ${id} 假裝返回了JSON串

    spring 容器api手動注入

    @Testpublic void customBatis(){AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext();TMapper tMapper = (TMapper) MySqlSession.getMapper(TMapper.class);context.getBeanFactory().registerSingleton("t", tMapper);context.refresh();TMapper mapper = context.getBean(TMapper.class);mapper.queryMap("1");} //打印結果 假裝連接數據庫 假裝執行了查詢語句select * from t where id = ${id} 假裝返回了JSON串

    總結

    以上是生活随笔為你收集整理的spring源码之模拟mybatis第三方对象注入的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。