Mybatis3.2.1使用例二:Mapper方式集成Spring、注解提供SQL

Spring提供了非常出色的依赖注入功能,Mybatis也少不了要与它进行集成;不过Spring并没有提供相应的集成方式,而是由Mybatis提供了mybatis-spring-x.x.x.jar的包来提供集成能力。


Mybatis也提供了注解的能力,使得更少配置成为可能。下面的例子大概描述了使用注解来提供SQL(该方式不需要使用配置文件来配置SQL):

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

package com.mybatis.demo2;

public class User {
	/** 用户ID */
	private int id;

	/** 用户名称 */
	private String name;

	/** 用户密码 */
	private String password;

	public int getId() {
		return id;
	}

	public void setId(int id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}
}
(2) Mapper接口类:com/mybatis/demo2/UserMapper.java

(只需提供接口方法,应用中mybatis会使用动态反射的方式提供查询的实际逻辑;该Mapper中还进行了Select的注解,提供所使用的SQL语句,这种方式可省掉配置文件的配置)

package com.mybatis.demo2;

import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;


public interface UserMapper {
	// 使用注解来指示所使用的SQL语句,省掉配置文件
	@Select("SELECT * FROM users where name=#{name}")
	public User findByName(@Param("name") String name);
}
(3) 数据源properties文件:com/mybatis/demo2/mysql.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/bookstore
username=root
password=123456
(4) Spring的配置文件:com/mybatis/demo2/applicationContext.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 class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
		<property name="locations" value="classpath:com/mybatis/demo2/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" />
	</bean>
	
	<!--创建数据映射器Mapper,属性mapperInterface的value必须为接口类-->
	<bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
		<property name="mapperInterface" value="com.mybatis.demo2.UserMapper" />
		<property name="sqlSessionFactory" ref="sqlSessionFactory" />
	</bean>
	
	<!-- 数据访问DAO,在DAO中使用Mapper来查数据 -->
	<bean id="userDao" class="com.mybatis.demo2.UserDaoImpl">
		<property name="userMapper" ref="userMapper"/>
	</bean>
</beans>
(5) DAO接口:com/mybatis/demo2/UserDao.java

(该接口不是必须有,但在WEB环境中最好能把它接口化使得依赖更小;当然本例并不是WEB环境中使用的,但除了测试类外都可以直接移植到WEB中)

package com.mybatis.demo2;

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

(通过Spring注入的方式获取到Mapper,然后使用Mapper进行数据库操作)

package com.mybatis.demo2;

public class UserDaoImpl implements UserDao {
	/** 该映射器需要与applicationContext.xml中配置的bean属性一致,并且要用对应的getter/setter */
	private UserMapper userMapper;
	
	@Override
	public User getUserByName(String name) {
		return getUserMapper().findByName(name);
	}

	public UserMapper getUserMapper() {
		return userMapper;
	}

	public void setUserMapper(UserMapper userMapper) {
		this.userMapper = userMapper;
	}	
}
(7) 测试类:com/mybatis/demo2/UserManagerPrgm.java
package com.mybatis.demo2;

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

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

从上面可看到Mybatis的配置文件和Mapper的配置文件都没有出现,配置文件只有Spring的配置文件和数据库源的配置文件。所使用的SQL语句是通过注解的方式提供的,这样就不需要配置文件;不过这样看起来虽然简洁,但当SQL语句多了,都散落在不同的类中,是否还这么方便呢?这个就得看场合和个人喜好了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值