文档章节

mybatis使用mapper代理开发和注意点

 小小小施爷
发布于 2017/09/08 11:35
字数 663
阅读 4
收藏 1

使用mapper代理开发的规范

输入图片说明

总结:

输入图片说明

给出一个实际开发的案例 :

maven文件

<dependencies>
  	<dependency>
  		<groupId>org.mybatis</groupId>
  		<artifactId>mybatis</artifactId>
  		<version>3.2.7</version>
  	</dependency>
  	<dependency>
  		<groupId>commons-logging</groupId>
  		<artifactId>commons-logging</artifactId>
  		<version>1.2</version>
  	</dependency>
  	<dependency>
  		<groupId>junit</groupId>
  		<artifactId>junit</artifactId>
  		<version>4.12</version>
  	</dependency>
  	<dependency>
  		<groupId>mysql</groupId>
  		<artifactId>mysql-connector-java</artifactId>
  		<version>5.1.43</version>
  	</dependency>
  	<dependency>  
            <groupId>log4j</groupId>  
            <artifactId>log4j</artifactId>  
            <version>1.2.17</version>  
      </dependency> 
      <!-- 引入dbcp连接池 -->
      <dependency>
	    <groupId>commons-dbcp</groupId>
	    <artifactId>commons-dbcp</artifactId>
		    
	    <version>1.2</version>
	  </dependency>
      <dependency>
      	<groupId>cglib</groupId>
      	<artifactId>cglib</artifactId>
      	<version>3.1</version>
      </dependency>
      <dependency>
      	<groupId>org.apache.logging.log4j</groupId>
      	<artifactId>log4j-api</artifactId>
      	<version>2.8</version>
      </dependency>
      <dependency>
      	<groupId>org.apache.logging.log4j</groupId>
      	<artifactId>log4j-core</artifactId>
      	<version>2.8</version>
      </dependency>
      <dependency>
      	<groupId>org.slf4j</groupId>
      	<artifactId>slf4j-log4j12</artifactId>
      	<version>1.7.7</version>
      </dependency>
      <dependency>
      	<groupId>asm</groupId>
      	<artifactId>asm</artifactId>
      	<version>3.3</version>
      </dependency>
      <dependency>
		    <groupId>org.mybatis</groupId>
		    <artifactId>mybatis-ehcache</artifactId>
		    <version>1.0.0</version>
		</dependency>
  </dependencies>

mybatis全局配置文件 sqlMapConfig.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> 
	<!-- 1  加载配置文件 -->
	<properties  resource="db.properties"></properties>
	
	<!-- 2 对连接池 和 事物的配置 (这里必须粘贴之前的 自己写的一模一样都报错) -->
	<environments default="development">  
        <environment id="development">  
        <!-- 使用jdbc事物管理,事物控制由mybatis管理 -->
            <transactionManager type="JDBC" />  
            <!-- 数据库连接池 -->
            <dataSource type="POOLED">  
                <property name="driver" value="${jdbc.driver}" />  
                <property name="url" value="${jdbc.url}" />  
                <property name="username" value="${jdbc.uername}" />  
                <property name="password" value="${jdbc.password}" />  
            </dataSource>  
        </environment>  
    </environments> 
	
	<!-- 3  在sqlMapconfig中加载我们的配置文件 -->
	<mappers>
		<mapper resource="com/shi/mapper/UserMapper.xml"/>
	</mappers>
	
</configuration>

UserMapper.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">

<!--namespace:必须是和mapper.java的相对路径  -->
<mapper namespace="com.shi.mapper.UserMapper">
	<select id="selectUserById" parameterType="Integer" resultType="com.shi.pojo.User">
		select * from User WHERE id=#{id}
	</select>

</mapper>

UserMapper.java文件

package com.shi.mapper;

import com.shi.pojo.User;

public interface UserMapper {
	
	/**
	 * 操作user的mapper的接口
	 * @param id
	 * @return
	 * @throws Exception
	 */
	public User selectUserById(Integer id)throws Exception;

}

测试文件 test.java

package com.shi.mapper;

import static org.junit.Assert.*;

import java.io.InputStream;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test;

import com.shi.pojo.User;

public class UserMapperTest {
	
	private SqlSessionFactory sqlSessionFactory;
	
	/**
	 * 在测试之前 我们要得到 会话工厂
	 * @throws Exception
	 */
	@Before
	public void setUp() throws Exception{
		//1  先得到配置文件
		InputStream inputStream=Resources.getResourceAsStream("sqlMapConfig.xml");
		
		//2  根据配置文件呢 创建我们的会话工厂
		sqlSessionFactory=new SqlSessionFactoryBuilder().build(inputStream);
	}
	

	@Test
	public void testSelectUserById() throws Exception {
		//3  打开一个会话
		SqlSession sqlSession=sqlSessionFactory.openSession();
		//4  创建UserMapper接口的实现类,mybatis自动生成代理对象,自动生成其实现类
		UserMapper userMapper=sqlSession.getMapper(UserMapper.class);
		//5  调用方法 执行
		User user=userMapper.selectUserById(2);
		//6 关闭会话
		sqlSession.close();
		System.out.println(user);
		
	}

}

pojo对象 User.java

package com.shi.pojo;

public class User {
	private Integer id;
	private String username;
	private String birthday;
	private String sex;
	private String address;
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getUsername() {
		return username;
	}
	public void setUsername(String username) {
		this.username = username;
	}
	public String getBirthday() {
		return birthday;
	}
	public void setBirthday(String birthday) {
		this.birthday = birthday;
	}
	public String getSex() {
		return sex;
	}
	public void setSex(String sex) {
		this.sex = sex;
	}
	public String getAddress() {
		return address;
	}
	public void setAddress(String address) {
		this.address = address;
	}
	@Override
	public String toString() {
		return "User [id=" + id + ", username=" + username + ", birthday=" + birthday + ", sex=" + sex + ", address="
				+ address + "]";
	}
	
}

© 著作权归作者所有

共有 人打赏支持
粉丝 5
博文 145
码字总数 102480
作品 0
合肥
私信 提问
【MyBatis框架】Mybatis开发dao方法第二部分

下面来继续讨论mybatis开发Dao的方法 我们前面使用原始的Dao开发方法,发现了许多弊端,我们下面使用mapper代理来写Dao方法。 1.mapper代理方法(程序员只需要mapper接口(相当 于dao接口))...

Mysoft
2015/09/17
37
0
JavaEE Spring+Mybatis整合

1. MyBatis整合Spring所需的jar包如下: Spring的jar包 Mybatis的jar包 Mybatis-Spring整合包,即mybatis-spring-1.3.2.jar MySql的数据库驱动jar包 数据库连接池的jar包 2.整合思路 MyBati...

凌浩雨
2018/04/16
0
0
Mybatis 入门案例 2 ---- mapper 代理的方式

我们只需要编写DAO接口和mapper.xml文件即可,DAO接口实现对象由mybatis自动生成代理对象。 如: 一、为什么不使用原始的DAO方式开发呢? 1、dao的实现类中存在重复代码,整个mybatis操作的过...

故新
2017/11/07
0
0
IDEA中使用maven整合mybatis与spring

整合思路 需要spring通过方式管理SqlSessionFactory. spring和mybatis整合生成代理对象,使用SqlSessionFactory创建SqlSession.(Sping和mybati整合自动完成). 持久层的mapper都需要有spring进...

中柠檬
2016/11/18
42
0
Mybatis应用学习(2)——配置文件编写

Mybatis的配置文件SqlMapConfig.xml 1.1 主要标签 properties(定义属性):用来定义一些固定属性值,以key-value形式存在 MyBatis 将按照下面的顺序来加载属性:在 properties 元素体内定义...

江左煤郎
2018/11/24
0
0

没有更多内容

加载失败,请刷新页面

加载更多

20个使用 Java CompletableFuture的例子

https://colobu.com/2018/03/12/20-Examples-of-Using-Java%E2%80%99s-CompletableFuture/

lemos
18分钟前
0
0
Apache 流框架 Flink,Spark Streaming,Storm对比分析

1.Flink架构及特性分析 Flink是个相当早的项目,开始于2008年,但只在最近才得到注意。Flink是原生的流处理系统,提供high level的API。Flink也提供 API来像Spark一样进行批处理,但两者处理...

hblt-j
22分钟前
0
0
什么是公网IP、内网IP和NAT转换?

搞网络通信应用开发的程序员,可能会经常听到外网IP(即互联网IP地址)和内网IP(即局域网IP地址),但他们的区别是什么? 1、引言 搞网络通信应用开发的程序员,可能会经常听到外网IP(即互联网I...

linuxprobe16
28分钟前
0
0
Spring Cloud搭建微服务架构----流量回放

前言 系统微服务化后,传统的自测/测试方式都变得比较困难: 依赖的服务可能不稳定。 服务无法提供期望的响应数据。 缺少场景构造标准。 随着整体业务越来越复杂,微服务依赖的越来越多,测试...

春哥大魔王的博客
50分钟前
3
0
记一次springboot模块配置问题导致读取Apollo配置中心配置文件始终错误的问题

现在正在做的一个项目采用的是微服务,主框架是spring cloud,配置中心用的是携程的Apollo。 项目下有多个服务,在测试服务器上启动用户服务的时候发现在eureka中心另一个服务被启动了,尝试...

zcqshine
51分钟前
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部