`
东天里的冬天
  • 浏览: 33046 次
  • 性别: Icon_minigender_1
文章分类
社区版块
存档分类
最新评论

spring整合mybatis(原始dao和mapper代理两种方式)

 
阅读更多

一.原始Dao方式

1.引入jar包(maven文件和下面的Mapper代理方式一样)

2.applicationContext.xml

<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans 
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.2.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.2.xsd">
 
<!-- 加载配置文件 -->
<context:property-placeholder location="config/jdbc.properties"/>
 
<!-- 数据库连接池 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${driver}"/>
<property name="url" value="${jdbcUrl}"/>
<property name="username" value="${user}"/>
<property name="password" value="${password}"/>
<property name="maxActive" value="10"/>
<property name="maxIdle" value="5"/>
</bean>         
<!-- mapper配置 -->
<!-- 让spring管理sqlsessionfactory 使用mybatis和spring整合包中的 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 数据库连接池 -->
<property name="dataSource"ref="dataSource" />
 
<!-- 加载mybatis的全局配置文件 -->
<property name="configLocation" value="config/mybatis/sqlSessionConfig.xml" />
</bean>
 
<!-- 配置dao -->
<bean id="userDao" class="gwd.ssm.dao.UserDaoImp">
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
</beans>


3.sqlSessionConfig.xml:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<mappers>
<mapper resource="gwd/ssm/po/user.xml"/>
</mappers>
</configuration>


4.User.xml(和User.java放一起)

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="test">
<select id="findUserById" parameterType="int" resultType="gwd.ssm.po.User">
select * from users where id=#{value}
</select>
</mapper>


5.UserDao.java:

package gwd.ssm.dao;
import gwd.ssm.po.User;
public interface UserDao {
public User findUserById(int id);
}
 

UserDaoImp.java:

package gwd.ssm.dao;
import gwd.ssm.po.User;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.support.SqlSessionDaoSupport;
 
public class UserDaoImp extends SqlSessionDaoSupport implements UserDao {
 
public User findUserById(int id) {
// TODO Auto-generated method stub
SqlSession sqlSession=this.getSqlSession();//sqlSessionFactory方法中有set方法
User user=sqlSession.selectOne("test.findUserById",id);
return user;
}
}

6.Test

public class UserMapperTest {

private ApplicationContext applicationContext;

@Before

public void setUp(){

applicationContext=new FileSystemXmlApplicationContext("config/spring/applicationContext.xml");

}

@Test

public void testFindUserById() {

UserMapper userMapper=(UserMapper)applicationContext.getBean("userMapper");//userMapper和UserMapper对应

User user=userMapper.findUserById(2);

System.out.println(user);

}

}


二:Mapper代理方式

1.pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>PetTest</groupId>
  <artifactId>pet-commonTest</artifactId>
  <packaging>war</packaging>
  <version>0.0.1-SNAPSHOT</version>
  <name>pet-commonTest Maven Webapp</name>
  <url>http://maven.apache.org</url>
  <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <spring.version>4.2.0.RELEASE</spring.version>
      <jackson-core.version>2.6.1</jackson-core.version>
      <!-- log4j日志文件管理包版本 -->
		<slf4j.version>1.7.7</slf4j.version>
		<log4j.version>1.2.17</log4j.version>
  </properties>

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.12</version>
      <scope>test</scope>
    </dependency>

    <!-- servlet -->
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.1.0</version>
    </dependency>

    <!-- spring -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-core</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-tx</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>${spring.version}</version>
    </dependency>
   
    <!-- mysql -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.36</version>
    </dependency>

    <!-- JSTL标签类 -->
		<dependency>
			<groupId>jstl</groupId>
			<artifactId>jstl</artifactId>
			<version>1.2</version>
		</dependency>
		<!-- 日志文件管理包 -->
		<!-- log start -->
		<dependency>
			<groupId>log4j</groupId>
			<artifactId>log4j</artifactId>
			<version>${log4j.version}</version>
		</dependency>
		<!-- 格式化对象,方便输出日志 -->
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-api</artifactId>
			<version>${slf4j.version}</version>
		</dependency>
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-log4j12</artifactId>
			<version>${slf4j.version}</version>
		</dependency>

    <!-- mybatis -->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.3.0</version>
    </dependency>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis-spring</artifactId>
        <version>1.2.3</version>
    </dependency>
    
	  <dependency>
	    <groupId>commons-dbcp</groupId>
	    <artifactId>commons-dbcp</artifactId>
	    <version>1.4</version>
	</dependency>
  </dependencies>
  <build>
    <finalName>pethome</finalName>
    <resources>  
      <!-- maven项目中src源代码下的xml等资源文件编译进classes文件夹,
      	注意:如果没有这个,它会自动搜索resources下是否有mapper.xml文件,
      	如果没有就会报org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.pet.mapper.PetMapper.selectByPrimaryKey-->
      <resource>  
        <directory>src/main/java</directory>  
        <includes>  
          <include>**/*.xml</include>  
        </includes>  
      </resource>
      
      <!--将resources目录下的配置文件编译进classes文件  -->  
      <resource>
			<directory>src/main/resources</directory>
	  </resource>
    </resources>  
  </build> 
</project>

2.引入配置文件

(1)PetMapper.java

package com.pet.mapper;

import java.util.List;
import com.pet.bean.Pet;
public interface PetMapper {
    public Pet selectByPrimaryKey(Integer id);
    public List<Pet> getAll();
}

(2)PetMapper.xml(自动生成)

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.pet.mapper.PetMapper" >
  <resultMap id="BaseResultMap" type="com.pet.bean.Pet" >
    <id column="ID" property="id" jdbcType="INTEGER" />
    <result column="PETNAME" property="petname" jdbcType="VARCHAR" />
    <result column="AGE" property="age" jdbcType="INTEGER" />
    <result column="STATUS" property="status" jdbcType="VARCHAR" />
    <result column="MED_HISTORY" property="medHistory" jdbcType="VARCHAR" />
    <result column="FEATHERS" property="feathers" jdbcType="VARCHAR" />
    <result column="VACCINATION" property="vaccination" jdbcType="VARCHAR" />
  </resultMap>
  <sql id="Base_Column_List" >
    ID, PETNAME, AGE, STATUS, MED_HISTORY, FEATHERS, VACCINATION
  </sql>
  <select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Integer" >
    select 
    <include refid="Base_Column_List" />
    from pet
    where ID = #{id,jdbcType=INTEGER}
  </select>
  <select id="getAll" resultMap="BaseResultMap">
  	select * from Pet
  </select>
  <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer" >
    delete from pet
    where ID = #{id,jdbcType=INTEGER}
  </delete>
  <insert id="insert" parameterType="com.pet.bean.Pet" >
    insert into pet (ID, PETNAME, AGE, 
      STATUS, MED_HISTORY, FEATHERS, 
      VACCINATION)
    values (#{id,jdbcType=INTEGER}, #{petname,jdbcType=VARCHAR}, #{age,jdbcType=INTEGER}, 
      #{status,jdbcType=VARCHAR}, #{medHistory,jdbcType=VARCHAR}, #{feathers,jdbcType=VARCHAR}, 
      #{VACCINATION,jdbcType=VARCHAR})
  </insert>
  <insert id="insertSelective" parameterType="com.pet.bean.Pet" >
    insert into pet
    <trim prefix="(" suffix=")" suffixOverrides="," >
      <if test="id != null" >
        ID,
      </if>
      <if test="petname != null" >
        PETNAME,
      </if>
      <if test="age != null" >
        AGE,
      </if>
      <if test="status != null" >
        STATUS,
      </if>
      <if test="medHistory != null" >
        MED_HISTORY,
      </if>
      <if test="feathers != null" >
        FEATHERS,
      </if>
      <if test="vaccination != null" >
        VACCINATION,
      </if>
    </trim>
    <trim prefix="values (" suffix=")" suffixOverrides="," >
      <if test="id != null" >
        #{id,jdbcType=INTEGER},
      </if>
      <if test="petname != null" >
        #{petname,jdbcType=VARCHAR},
      </if>
      <if test="age != null" >
        #{age,jdbcType=INTEGER},
      </if>
      <if test="status != null" >
        #{status,jdbcType=VARCHAR},
      </if>
      <if test="medHistory != null" >
        #{medHistory,jdbcType=VARCHAR},
      </if>
      <if test="feathers != null" >
        #{feathers,jdbcType=VARCHAR},
      </if>
      <if test="vaccination != null" >
        #{vaccination,jdbcType=VARCHAR},
      </if>
    </trim>
  </insert>
  <update id="updateByPrimaryKeySelective" parameterType="com.pet.bean.Pet" >
    update pet
    <set >
      <if test="petname != null" >
        PETNAME = #{petname,jdbcType=VARCHAR},
      </if>
      <if test="age != null" >
        AGE = #{age,jdbcType=INTEGER},
      </if>
      <if test="status != null" >
        STATUS = #{status,jdbcType=VARCHAR},
      </if>
      <if test="medHistory != null" >
        MED_HISTORY = #{medHistory,jdbcType=VARCHAR},
      </if>
      <if test="feathers != null" >
        FEATHERS = #{feathers,jdbcType=VARCHAR},
      </if>
      <if test="vaccination != null" >
        VACCINATION = #{vaccination,jdbcType=VARCHAR},
      </if>
    </set>
    where ID = #{id,jdbcType=INTEGER}
  </update>
  <update id="updateByPrimaryKey" parameterType="com.pet.bean.Pet" >
    update pet
    set PETNAME = #{petname,jdbcType=VARCHAR},
      AGE = #{age,jdbcType=INTEGER},
      STATUS = #{status,jdbcType=VARCHAR},
      MED_HISTORY = #{medHistory,jdbcType=VARCHAR},
      FEATHERS = #{feathers,jdbcType=VARCHAR},
      vaccination = #{vaccination,jdbcType=VARCHAR}
    where ID = #{id,jdbcType=INTEGER}
  </update>
</mapper>

(3)spring-mybatis.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" xmlns:p="http://www.springframework.org/schema/p"  
        xmlns:context="http://www.springframework.org/schema/context"  
        xmlns:mvc="http://www.springframework.org/schema/mvc"  
        xsi:schemaLocation="http://www.springframework.org/schema/beans   
        http://www.springframework.org/schema/beans/spring-beans-3.1.xsd    
        http://www.springframework.org/schema/context    
        http://www.springframework.org/schema/context/spring-context-3.1.xsd    
        http://www.springframework.org/schema/mvc    
        http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">  
        <!-- 自动扫描 -->  
        <context:component-scan base-package="com.pet">
        	<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" />
        </context:component-scan>  
        <!-- 引入配置文件 -->  
        <bean id="propertyConfigurer"  
            class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">  
            <property name="location" value="classpath:jdbc.properties" />  
        </bean>  
      
        <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"  
            destroy-method="close">  
            <property name="driverClassName" value="${db.driverClassName}" />  
            <property name="url" value="${db.url}" />  
            <property name="username" value="${db.username}" />  
            <property name="password" value="${db.password}" />  
        </bean>  
      
        
        <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
            <property name="dataSource" ref="dataSource" />  
            <!-- 自动扫描mapping.xml文件 -->  
            <property name="mapperLocations" value="classpath*:com/pet/mapper/*.xml"></property> 
            <--如果PetMapper.java文件和PetMapper.xml文件在同一目录就用上面的自动扫描即可,不需要下面的这个configLocation来配置目录。
              如果不在同一目录,则上面的mapperlocation不要,使用下面的configlocation配置相应目录
            -->
          <property name="configLocation" value="classpath:mybatis-config.xml"></property>
</bean> <!-- Mapper扫描包--> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.pet.mapper" /> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property> </bean> <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> <!-- 通知 --> </beans>


(4)mybatis-config.xml(根据此项更改spring-mybatis.xml)

注意:当*Mapper.xml和对应的*Mapper.java接口在同一个目录下面的时候,此时这个配置文件可以省略

如果不在同一目录,这里需要在mapper里面配上其目录


<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <mappers>
        <mapper resource="*Mapper.xml的目录"/>
    </mappers>
</configuration>


(5)junit测试

@Test
    public void findUserByIdTest2(){
        ApplicationContext ctx = new ClassPathXmlApplicationContext("spring-mybatis.xml");
        PetMapper petMapper = (PetMapper) ctx.getBean("petMapper");//petMapper和PetMapper对应
        List<Pet> pet = petMapper.getAll();
        System.out.println(pet);
    }



分享到:
评论

相关推荐

    spring和mybatis整合(mapper代理自动扫描方式实现)

    本文将详细介绍如何将Spring和MyBatis进行整合,并采用Mapper代理自动扫描的方式实现,同时还会提及到JUnit测试。 首先,我们需要在项目中引入Spring和MyBatis的相关依赖。通常,我们会使用Maven或Gradle作为构建...

    Spring整合Mybatis与SpringBoot整合Mybatis原理分析

    **Spring整合Mybatis原理分析** 在Java Web开发中,Spring框架以其强大的依赖注入和面向切面编程能力,成为了事实上的核心框架。Mybatis则是一个轻量级的持久层框架,它简化了数据库操作,提供了直观的SQL映射。将...

    Spring+myBatis 整合两种方法,一种是dao 整合,一种是mapper接口代理

    本教程将详细介绍如何将Spring与MyBatis进行整合,包括两种不同的方法:DAO整合和Mapper接口代理。 首先,我们需要搭建基本的项目环境。项目结构通常包括`.classpath`、`.project`等IDE配置文件,`src`源代码目录,...

    spring_mybatis 整合jar包

    在与Spring整合后,可以通过Spring的ApplicationContext来管理SqlSessionFactory和Mapper接口,实现事务的统一管理和DAO的自动注入。 在压缩包子文件的文件名称列表中,虽然只列出了"lib",但我们可以推测,这个...

    spring和mybatis整合(原始dao方式实现

    - 在Spring中,原始DAO方式指的是不使用MyBatis的Mapper接口,而是直接通过SqlSession进行数据库操作。这需要我们在DAO实现类中注入SqlSessionFactory,然后创建SqlSession实例,调用其`openSession()`、`selectOne...

    spring整合mybatis的jar_spring+mybatis_

    在Java开发领域,Spring框架和MyBatis是两个非常重要的组件。Spring是一个全面的企业级应用框架,提供了依赖注入、AOP(面向切面编程)、事务管理等功能,而MyBatis则是一个优秀的持久层框架,它简化了SQL操作,将...

    Mybatis整合通用Dao,Mybatis整合通用Mapper,MyBatis3.x整合通用 Mapper3.5.x

    本文将深入探讨如何将MyBatis与通用Dao(Data Access Object)和通用Mapper进行整合,以提高开发效率和代码复用性。我们将以"Mybatis整合通用Dao,Mybatis整合通用Mapper,MyBatis3.x整合通用Mapper3.5.x"为主题,...

    spring整合mybatis简单项目

    在本项目中,“Spring整合Mybatis简单项目”旨在教授初学者如何将两个流行的Java框架——Spring和Mybatis结合,以实现一个简单的影视资源管理系统。这个系统可能会包括资源的增删改查、分类管理等功能,帮助用户高效...

    spring整合mybatis.docx

    Spring 整合 MyBatis 是将 Spring 框架与 MyBatis 持久层框架结合使用,以便...这种整合方式使得开发人员可以充分利用Spring的IoC和AOP特性,同时享受MyBatis提供的灵活的SQL操作,极大地提高了开发效率和代码质量。

    Spring4--Spring4整合mybatis3

    总结,"Spring4--Spring4整合mybatis3"涉及到的核心知识点包括Spring的IoC和AOP,Mybatis的动态SQL和映射机制,以及整合过程中的配置、事务管理、Mapper接口设计和测试等。通过这种方式,我们可以构建出一个高效、可...

    ssm框架spring+mybatis+mvc

    SSM框架是由Spring、MyBatis和Spring MVC三个组件组成的Java Web开发框架。这个框架的集成使得开发者在处理业务逻辑、持久化操作以及控制层交互时有了强大的支持。接下来,我们将详细探讨这三个组件以及如何利用它们...

    spring和mybatis整合配置

    在IT行业中,Spring和MyBatis是两个非常重要的框架,它们分别是Java开发中的依赖注入容器和持久层框架。本文将详细介绍如何将这两个框架整合在一起,以便实现高效且灵活的Web应用开发。 首先,Spring框架是Java企业...

    Spring整合MyBatis_jar包.rar

    Spring整合MyBatis是Java开发中常见的数据访问技术组合,它允许我们利用Spring的IoC(Inversion of Control,控制反转)和AOP(Aspect Oriented Programming,面向切面编程)特性来管理MyBatis的SQL映射和数据访问。...

    Spring整合Mybatis.zip

    总的来说,“Spring整合Mybatis.zip”中的内容涵盖了Spring和MyBatis集成的全过程,对于学习和掌握这两种框架的协同工作具有很高的参考价值。通过这个资源,开发者可以学习到如何构建一个完整的、基于Spring和...

    spring4.3 mybatis3.4 整合

    这个项目不仅涵盖了Spring的核心组件,如IoC(Inversion of Control)容器和AOP(Aspect-Oriented Programming)代理,还结合了MyBatis的简单易用的数据访问层,以及Maven的项目构建和依赖管理功能。 Spring 4.3是...

    mybatis-generator工具springboot的项目生成mybatis的dao与mapper

    MyBatis Generator(MBG)是一个强大的代码生成器,它能够自动生成MyBatis的DAO层、Mapper XML文件以及对应的实体类,极大地提高了开发效率。本项目是将MBG集成到SpringBoot应用中的实例,使用Java 1.8进行开发。 ...

    Mybatis的Mapper方式整合elasticsearch的DSL调用,基于接口和代理生成bean注入的方式进行调用

    本篇文章将详细介绍如何将Mybatis的Mapper方式与Elasticsearch的DSL(Domain Specific Language)查询相结合,以及如何通过CGlib实现动态代理来优化这一过程。 首先,让我们理解什么是Mybatis的Mapper方式。Mybatis...

    spring和mybatis整合所需的jar包

    在整合Spring和MyBatis的过程中,我们需要一系列特定的jar包来确保这两个框架能够无缝对接。这些jar包通常包括以下几个关键部分: 1. **Spring框架相关jar包**: - spring-context:提供容器的核心功能,包括Bean...

    spring整合mybatis的demo

    学习这个项目,你可以深入理解Spring、SpringMVC和MyBatis的整合方式,以及如何构建一个基于它们的Web应用。此外,它还涵盖了手动管理依赖项的实践,这对于了解传统项目结构和构建过程很有价值。

    Spring-SpringMVC-Mybatis整合所有jar包

    在Java Web开发中,Spring、SpringMVC和Mybatis是三个非常重要的框架,它们的整合可以构建出高效、灵活的企业级应用。这个压缩包“Spring-SpringMVC-Mybatis整合所有jar包”包含了这三个框架整合所需的全部依赖,...

Global site tag (gtag.js) - Google Analytics