`

myBatis系列之五:与Spring3集成

阅读更多

        前面讲到纯粹用mybatis 连接数据库,然后 进行增删改查,以及多表联合查询的的例子,但实际项目中,通常会用 spring 这个沾合剂来管理 datasource 等。充分利用spring 基于接口的编程,以及aop ,ioc 带来的方便。用spring 来管理 mybatis 与管理hibernate 有很多类似的地方。今天的重点就是数据源管理以及 bean的配置。

        Spring作为基础框架,可以集成后端框架,如Hibernate,MyBatis等。 

        前面介绍单独使用MyBatis的,大致逻辑是:

sqlSessionFactory <- configuration file (包括数据库连接配置) 
IXxxMapper <- sqlSession <- sqlSessionFactory 
                  <- mapper interface <- mapper xml 

        得到IxxMapper后,就可以调用其方法进行数据交互了。 

        和Spring集成时,上面的这些对象需要作为bean来管理: 

dataSource bean <- 数据库连接配置 
sqlSessionFactory bean <- dataSource 
                                   <- configuration file 
userMapper bean <- sqlSessionFactory 
                          <- mapper interface 

一.工程结构图



二.在类路径下创建beans-da.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

  <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"><!-- 数据库连接bean -->
  	<property name="driverClassName" value="com.mysql.jdbc.Driver" />
	<property name="url" value="jdbc:mysql://10.60.222.65:3306/test?characterEncoding=utf8" />
	<property name="username" value="test" />
	<property name="password" value="test" />
  </bean>
  
  <!-- sqlSessionFactory bean -->
  <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  	<property name="dataSource" ref="dataSource" /><!-- 数据源 -->
	<property name="configLocation" value="classpath:Configuration.xml" /><!-- 配置文件 -->
  </bean>
  
  <bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean"><!-- user映射bean-->
	<property name="sqlSessionFactory" ref="sqlSessionFactory" />
  	<property name="mapperInterface" value="com.bijian.study.dao.IUserMapper" /><!-- 映射接口 -->
  </bean>
</beans>

 

三.applicationContext.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
 xmlns:p="http://www.springframework.org/schema/p"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xmlns:context="http://www.springframework.org/schema/context"
 xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
 http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">

  <context:property-placeholder location="classpath:/database.properties" /><!-- 数据库配置文件 -->

  <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
  	p:driverClassName="${driverClassName}"
	p:url="${url}"
	p:username="${user_name}"
	p:password="${password}" /><!-- 数据源配置 -->
  
  <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><!-- sqlSessionFactory对象 -->
  	<property name="dataSource" ref="dataSource" /><!-- 数据源 -->
	<property name="configLocation" value="classpath:Configuration.xml" /><!-- myBatis配置文件 -->
	<!--<property name="mapperLocations" value="classpath*:com/bijian/study/model/*.xml" />--><!-- 可以在Configuration.xml或此处配置映射文件,但其中不能有相同id的parameterMap, resultMap或sql等 -->
  </bean>
  
  <bean id="mapperConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer"><!-- 扫描指定包以获取映射器 -->
  	<property name="basePackage" value="com.bijian.study.dao" />
  </bean>
</beans>

 

四.测试类

package com.bijian.study.test;

import java.util.List;

import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.bijian.study.dao.IUserMapper;
import com.bijian.study.model.Article;
import com.bijian.study.model.User;

public class SpringIntegrationTest {
    
    private static final Logger log = LoggerFactory.getLogger(SpringIntegrationTest.class);
    
    private static ApplicationContext ctx;
    
    static {
        ctx = new ClassPathXmlApplicationContext("beans-da.xml");
    }

    @Test
    public void queryTest() {

        IUserMapper mapper = (IUserMapper)ctx.getBean("userMapper");
        User user = mapper.getUserById(1);
        log.info("Name: {}, address: {}", user.getName(), user.getAddress());
        
        //得到文章列表测试
        log.info("得到用户id为1的所有文章列表");
        List<Article> articles = mapper.getArticlesByUserId(1);
        
        for(Article article:articles){
            log.info(article.getContent() + "--" + article.getTitle() + "--" + article.getUser().getName());
        }
    }
}

 

文章来源:http://czj4451.iteye.com/blog/1986780

  • 大小: 24.5 KB
分享到:
评论

相关推荐

    myBatis系列之六:与SpringMVC集成

    myBatis-Spring是myBatis与Spring集成的关键,它提供了一组便捷的工具和API,使得myBatis可以无缝地融入Spring应用中。myBatis-Spring的核心在于SqlSessionFactoryBean和SqlSessionTemplate,它们分别用于创建...

    外卖点餐系统,后端:springboot+mybatis+mybatis-plus 前端:vue+elmen

    Spring Boot支持多种数据库,包括MySQL、PostgreSQL等,可以方便地与数据库进行集成。 MyBatis是一个Java持久层框架,可将SQL语句与Java对象进行映射,简化了数据库操作。MyBatis提供了简单易用的API,可以将复杂的...

    mybatis学习总结:mybatis和spring, spring boot的集成

    这篇“mybatis学习总结”着重探讨了MyBatis如何与Spring和Spring Boot进行集成,这对于构建高效、可维护的企业级应用至关重要。 首先,MyBatis与Spring的集成主要通过Spring的IoC(Inversion of Control)容器来...

    myBatis系列之七:事务管理

    2. **自动事务管理**:MyBatis可以与Spring框架集成,利用Spring的声明式事务管理。在这种模式下,只需要在XML配置或注解中声明事务的边界,MyBatis会自动管理事务的开始、提交和回滚。这简化了代码,并减少了出错的...

    spring3和mybatis3的初始探索

    标题 "spring3和mybatis3的初始探索" 涉及到的是两个非常重要的Java开发框架——Spring和MyBatis的集成与应用。Spring是一个全面的后端开发框架,提供了依赖注入、AOP(面向切面编程)、MVC(模型-视图-控制器)等...

    Java项目框架-SpringMVC+Spring+Mybatis集成开发环境

    SpringMVC+Spring+Mybatis集成开发环境SpringMVC+Spring+Mybatis集成开发环境SpringMVC+Spring+Mybatis集成开发环境SpringMVC+Spring+Mybatis集成开发环境SpringMVC+Spring+Mybatis集成开发环境SpringMVC+Spring+...

    Spring集成Mybatis所需所有jar

    - `mybatis-spring`: 这是 Spring 和 MyBatis 的整合模块,提供了将 MyBatis 无缝集成到 Spring 应用中的功能。 3. **数据库驱动**:为了连接特定的数据库,还需要相应的 JDBC 驱动 jar 文件,如: - `mysql-...

    spring_mybatis 整合jar包

    这些库分别提供了Spring的上下文、bean管理、数据库事务控制以及与MyBatis的集成接口。 在标签中提到了"MyBatis",这是关键的关键词,意味着这个整合主要针对MyBatis的使用。MyBatis允许开发者编写XML或注解形式的...

    Spring集成Mybatis所需jar包

    在Java开发领域,Spring...以上就是Spring集成Mybatis所需的jar包及集成过程中的关键配置和步骤。正确配置这些组件,可以让我们在享受Spring的便利性的同时,充分利用MyBatis的灵活性和高效性,实现高质量的Java应用。

    mybatis3+spring+springMVC4整合jar包.rar

    标题 "mybatis3+spring+springMVC4整合jar包.rar" 描述的是一个整合了MyBatis 3、Spring 4 和 Spring MVC 4 的项目压缩包。这个压缩包通常用于快速搭建一个基于Java的Web开发环境,尤其是用于处理数据库操作和前端...

    Spring、Mybatis、Springboot常用面试试题及答案.rar

    - **事务管理**:与Spring结合时,Mybatis可以利用Spring的事务管理。 3. **Spring Boot框架**: - **起步依赖(Starter)**:Spring Boot通过起步依赖简化了添加依赖的过程。 - **自动配置(Auto Configuration...

    mybatis-spring集成

    下面将详细阐述MyBatis-Spring集成的关键知识点,以及如何在实际项目中实现XML配置和增删改查功能。 1. **MyBatis-Spring的作用**: MyBatis-Spring是两个框架之间的粘合剂,它提供了将MyBatis的SqlSession和...

    spring mvc与mybatis的集成

    集成 Spring MVC 和 MyBatis 的主要步骤包括以下几个方面: 1. **环境准备**:首先,确保项目中引入了 Spring MVC、MyBatis 相关的依赖库,如 spring-webmvc、spring-jdbc、mybatis、mybatis-spring 等。这些依赖...

    springmvc+mybatis+spring注解

    标题 "springmvc+mybatis+spring注解" 描述了一个集成框架,该框架结合了Spring MVC、MyBatis和Spring的注解特性,用于构建Web应用程序。这个框架使用Maven作为构建工具,使得项目的依赖管理和构建过程更加简洁高效...

    mybatis,mybatis-spring

    MyBatis和MyBatis-Spring是两个在Java开发中常用的框架,主要用于简化数据库操作和实现Spring框架的无缝集成。MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射,避免了几乎所有的JDBC代码和...

    SpringMVC+Spring+Mybatis集成开发环境

    在IT行业中,SpringMVC、Spring和Mybatis是三大核心框架,它们的集成使用是Java Web开发中的常见实践。这个集成开发环境旨在提供一个高效、灵活的开发平台,以实现业务逻辑与数据访问的分离,提高代码的可维护性和可...

    Spring-SpringMVC-Mybatis整合所有jar包

    5. **Spring与Mybatis的整合**:通过Mybatis的SqlSessionFactoryBean和SqlSessionTemplate,将Mybatis的SqlSession管理纳入Spring的管理,实现事务的一致性。 6. **测试与运行**:通过单元测试确保各个组件正常工作...

    spring-mybatis集成jar包以及文档

    在 "spring-mybatis集成jar包" 中,`mybatis-spring-1.2.0.jar` 文件是关键,它是 Spring 和 MyBatis 整合的桥梁,包含了连接两者所需的类和接口。这个版本的 jar 包支持 Spring 3.x 至 4.x,MyBatis 3.x 版本,确保...

Global site tag (gtag.js) - Google Analytics