Mybatis3.2.1使用例二:Mapper方式集成Spring、注解提供SQL
来源:互联网 发布:编程入门书籍推荐 编辑:程序博客网 时间:2024/06/06 00:55
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.Driverurl=jdbc:mysql://127.0.0.1:3306/bookstoreusername=rootpassword=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;@Overridepublic 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语句多了,都散落在不同的类中,是否还这么方便呢?这个就得看场合和个人喜好了。
- Mybatis3.2.1使用例二:Mapper方式集成Spring、注解提供SQL
- Mybatis3.2.1使用例三:Mapper方式集成Spring、配置文件提供SQL
- mybatis3中注解方式使用mapper
- Mybatis3.2.1使用例四:SqlSession方式集成Spring、不使用DAO辅助类
- Mybatis3.2.1使用例五:SqlSession方式集成Spring、使用DAO辅助类
- Mybatis3.2.1使用例一:不集成Spring
- spring+sprinmvc+mybatis基本整合(二)--基于spring注解mybais非注解非Mapper接口方式
- 二、Mybatis3入门之注解方式
- 我为什么放弃使用MyBatis3的Mapper注解
- spring mybatis mapper接口注解方式注入
- spring mybatis mapper接口注解方式注入
- spring mybatis mapper接口注解方式注入
- MyBatis3入门程序(03_使用Mapper接口方式)
- Spring注解方式集成Kafka(spring-kafka的使用)
- 关于spring与struts2使用Annotion注解方式的集成
- spring 和 redis的集成(使用注解方式)
- spring MVC集成Mybatis3
- Spring集成MyBatis (使用mapper映射器)
- 使用Audio Queue Services 播放和录制音频
- IPv4和ipv6
- 数组列表ArrayList中存储键值对的读取
- U盘安装Mac OS X 10.8.3 - OS X 10.9
- 栈的总结
- Mybatis3.2.1使用例二:Mapper方式集成Spring、注解提供SQL
- 提交App 教程
- 9周项目一
- wordpress使用pre标签来显示你的HTML
- POJ 1811 Prime Test
- Shell编程
- 源码剖析之sun.misc.Unsafe
- poj-3184-滚动数组dp
- Android技术框架概要