Mybatis3.2.1使用例四:SqlSession方式集成Spring、不使用DAO辅助类

Mybatis提供的Mapper方式给人第一印象是很迷惑:提供了一个接口类却找不到实现类。实际上该接口主要是提供了方法名和参数列表,Mapper的相关代理类把这些信息提取出来之后,这个接口也就没什么用了,因而也就不需要什么实现,它最后仍然是使用SqlSession进行操 作。从SqlSession的方法来看,我们可以直接提供方法名和参数信息就可以省略掉这个Mapper,特别是在使用DAO(也有接口)时,DAO的接 口基本与Mapper一样,有点多余的感觉。(注:SqlSession提供的方法只支持传入一个方法名和一个参数,而Mapper提供的接口则可以给多个参数,参数的使用后面再介绍)

下面是直接使用SqlSession的例子:

(1) 承载数据的User bean:com/mybatis/demo4/User.java

package com.mybatis.demo4;

public class User {

        /** 用户ID */
        private intid;

        /** 用户名称 */
        privateString name;

        /** 用户密码 */
        privateString password;

        public intgetId() {
               returnid;
        }

        public voidsetId(int id) {
               this.id= id;
        }

        publicString getName() {
               return name;
        }

        public voidsetName(String name) {
               this.name= name;
        }

        publicString getPassword() {
               returnpassword;
        }

        public voidsetPassword(String password) {
               this.password= password;
        }
}

(2) 数据源properties文件:com/mybatis/demo4/mysql.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/bookstore
username=root
password=123456

(3) Spring的配置文件:com/mybatis/demo4/applicationContext.xml

(此时把Mapper的配置信息去掉,取而代之的是SqlSession的配置)

<?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 class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
		<property name="locations" value="classpath:com/mybatis/demo4/mysql.properties"/>
	</bean>
	
	<!-- 数据源 -->
	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
		destroy-method="close">
		<property name="driverClassName" value="${driver}" />
		<property name="url" value="${url}" />
		<property name="username" value="${username}" />
		<property name="password" value="${password}" />
	</bean>
	
	<!-- 创建SqlSessionFactory,需指定数据源,property名称必须为dataSource -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" ref="dataSource" />
		<property  name="configLocation"  value="classpath:com/mybatis/demo4/mybatis_config.xml"/>
	</bean>
	
	<!-- 使用SqlSession的形式,不需要再使用Mapper -->
	<!--创建数据映射器Mapper,属性mapperInterface的value必须为接口类-->
	<!-- <bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
		<property name="mapperInterface" value="com.mybatis.demo4.UserMapper" />
		<property name="sqlSessionFactory" ref="sqlSessionFactory" />
	</bean> -->
	
	<!-- 使用SqlSession形式 -->
	<bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
		<constructor-arg ref="sqlSessionFactory" />
	</bean>
	
	<!-- 数据访问DAO,在DAO中使用sqlSession来查数据,在DAO中自定义属性名对应的setter方法 -->
	<bean id="userDao" class="com.mybatis.demo4.UserDaoImpl">
		<property name="sqlSession" ref="sqlSession"/>
	</bean>
</beans>
(4) Mybatis配置文件:com/mybatis/demo4/mybatis_config.xml(与Spring集成后,该配置文件很多属性不能用了,比如setting、environment等,主要是使用typeAliases和mappers)

<?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>
	<typeAliases>
		<typeAlias alias="User" type="com.mybatis.demo4.User" />
	</typeAliases>
	
	<mappers>
		<mapper resource="com/mybatis/demo4/UserMappers.xml" />
	</mappers>
</configuration>

(5) Mapper配置文件:com/mybatis/demo3/UserMappers.xml

(提供SQL的详细配置,其中select/insert/update/delete语句的id都必须与Mapper的方法名称相同)

<?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,且值为Mapper的类路径;直接使用SqlSession时可配可不配 -->
<mapper namespace="com.mybatis.demo4.UserMapper">
	<resultMap id="userMap" type="User">
		<id property="id" column="id" />
		<result property="name" column="name" />
		<result property="password" column="password" />
	</resultMap>
	
	<select id="findByName" parameterType="String" resultMap="userMap">
		select * from users where name=#{name}
	</select>
</mapper>  
(6) DAO接口:com/mybatis/demo4/UserDao.java
package com.mybatis.demo4;

public interface UserDao {
	public User getUserByName(String name);
}
(7) DAO实现类:com/mybatis/demo2/UserDaoImpl.java
package com.mybatis.demo4;

import org.mybatis.spring.SqlSessionTemplate;

public class UserDaoImpl implements UserDao {
	/**
	 * 自定义SqlSession变量和相关的getter/setter,在applicationContext.xml中可灵活配置DAO的属性名称
	 */
	public SqlSessionTemplate sqlSession;
	
	@Override
	public User getUserByName(String name) {
		return getSqlSession().selectOne("com.mybatis.demo4.UserMapper.findByName", name);
	}

	public SqlSessionTemplate getSqlSession() {
		return sqlSession;
	}

	public void setSqlSession(SqlSessionTemplate sqlSession) {
		this.sqlSession = sqlSession;
	}
}
(8) 测试类:com/mybatis/demo2/UserManagerPrgm.java
package com.mybatis.demo4;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class UserManagerPrgm {
	public static void main(String[] args) {
		String configLocation = "com/mybatis/demo4/applicationContext.xml";
		ApplicationContext context = new ClassPathXmlApplicationContext(configLocation);
		UserDao dao = (UserDao)context.getBean("userDao");
		User user = dao.getUserByName("Joe");
		System.out.println(user);
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值