资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

Spring整合Mybatis-创新互联

Spring & Mybatis

spring与Mybatis整合
核心思想:将SqlSessionFactory和SqlSession交给spring来管理

成都创新互联公司基于分布式IDC数据中心构建的平台为众多户提供大邑服务器托管 四川大带宽租用 成都机柜租用 成都服务器租用。

步骤

  1. 创建包 ,创建表,实体类
  2. 导入jar包
    Spring整合Mybatis

  3. 编辑配置文件

    • spring配置文件

      • 引入外部数据源,数据库相关配置放在config.properties中

        一般出现location都要使用classpath

      • 使用连接池配置数据源,连接池用dbcp或者c3p0,不能同时配置,否则冲突
        在mybatis配置文件中不用再配置数据源相关信息
        使用的dbcp连接池:

        value的值是外部数据文件的key




        或者使用c3p0 连接池





      • 配置SqlSessionFactory,用于创建sqlSession,使用整合包的类SqlSessionFactoryBean,用于使spring能够提供SqlSessionFactory对象,需要指定配置文件路径以及扫描mapper.xml映射文件


        引入mybatis的配置文件

        扫描mapper.xml映射

      • 配置SqlSession,使用整合包的SqlSessionTemplate对象,使spring能够提供sqlsession对象

        由于SqlSessionTemplate中的sqlSessionFactory属性没有set方法,不能使用set注入依赖,有将SqlSessionFactory作为参数的构造方法,所以使用构造器注入

    • mybatis配置文件
      数据源与mapper.xml映射文件扫描已经在spring配置文件中,mybatis配置文件只需要进行一些setting设置和别名设置等.









  4. 编写mapper接口,并在spring配置文件添加mapperFactoryBean进行管理

    • 编写controller层的mapper接口
      public interface UserMapper {
      User queryUserById(@Param("id") Integer id);
      }
    • 配置spring文件,将mapper接×××给spring管理
      使用整合包的MapperFactoryBean类,mapperInterface属性值为接口路径,需要注入SqlSessionFactory依赖




      使用Mybatis时使用SqlSessionFactory创建SqlSession对象,通过sqlsession对象的getMapper()方法指定接口名获得mapper接口,所以这里要指定接口路径并依赖SqlSessionFactory.
  5. 创建service类,注入mapper依赖,并在spring配置文件中将其交由spring管理

    • service类:
      public class UserService {@Autowired
      br/>@Autowired
      public User queryUserById(Integer id){
      User user = userMapper.queryUserById(id);
      return user;
      }
      }

    • spring配置:

创新互联www.cdcxhl.cn,专业提供香港、美国云服务器,动态BGP最优骨干路由自动选择,持续稳定高效的网络助力业务部署。公司持有工信部办法的idc、isp许可证, 机房独有T级流量清洗系统配攻击溯源,准确进行流量调度,确保服务器高可用性。佳节活动现已开启,新人活动云服务器买多久送多久。


当前名称:Spring整合Mybatis-创新互联
网页地址:http://www.cdkjz.cn/article/dpeodd.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220