MyBatis架构图

三个对象: SqlSessionFactoryBuilder、SqlSessionFactory、SqlSession

SqlSessionFactoryBuilder:主要用来构建SqlSessionFactory,创建了之后就无需存在了,最好是方法范围。

这个类可以被实例化,使用和丢弃。一旦你创建了 SqlSessionFactory 后,这个类就不需 要存在了。因此 SqlSessionFactoryBuilder 实例的最佳范围是方法范围 (也就是本地方法变量)。你可以重用 SqlSessionFactoryBuilder 来创建多个 SqlSessionFactory 实例, 但是最好的方式是 不需要保持它一直存在来保证所有 XML 解析资源,因为还有更重要的事情要做。

SqlSessionFactory:开启会话,SqlSessionFactory.openSession。无需创建多次,使用单例。

一旦被创建,SqlSessionFactory 应该在你的应用执行期间都存在。没有理由来处理或重 新创建它。

使用 SqlSessionFactory 的最佳实践是在应用运行期间不要重复创建多次。 这样的 操作将被视为是
非常糟糕的。 因此 SqlSessionFactory 的最佳范围是应用范围。 有很多方法可 以做到, 最简单的
就是使用单例模式或者静态单例模式。

SqlSession:执行Sql,提交、关闭事务等。

每个线程都应该有它自己的 SqlSession 实例。SqlSession 的实例不能被共享,也是线程 不安全的。
因此最佳的范围是请求或方法范围。绝对不能将 SqlSession 实例的引用放在一个 类的静态字段甚至
是实例字段中。 也绝不能将 SqlSession 实例的引用放在任何类型的管理范 围中, 比如 Serlvet
架构中的 HttpSession。 如果你现在正用任意的 Web 框架, 要考虑 SqlSession 放在一个和 HTTP
请求对象相似的范围内。换句话说,基于收到的 HTTP 请求,你可以打开 了一个 SqlSession,然后返回
响应,就可以关闭它了。关闭 Session 很重要,你应该确保使 用 finally 块来关闭它。

Dao开发:

一:原始开发

daoimpl:

单元测试:

二: 动态代理

开发规则:遵守以下规则,提供UserMapper接口和方法,实现类由MyBatis生成,不用手动创建

  • 1.namespace必须是接口的全路径名
  • 2.接口的方法必须与sql一致
  • 3.接口的入参必须与parameterType一致
  • 4.接口的返回值必须与resultType类型一致

开发步骤:

创建接口及其方法     com.mybatis.mapper.UserMapper

创建映射文件           /MyBatis/config/mybatis/UserMapper.xml

在核心配置文件里面加载映射文件      /MyBatis/config/SqlMapConfig.xml

单元测试                    com.mybatis.test.UserMapperTest

package com.mybatis.test;

import static org.junit.Assert.*;

import java.util.Date;
import java.util.List; import org.apache.ibatis.session.SqlSession;
import org.junit.Test; import com.mybatis.mapper.UserMapper;
import com.mybatis.pojo.User;
import com.mybatis.utils.SqlSessionFactoryUtils; public class UserMapperTest { @Test
public void testGetUserById() {
SqlSession sqlSession = SqlSessionFactoryUtils.getSqlSessionFactory().openSession();
//获取接口的代理实现类
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
User user = userMapper.getUserById(33);
System.out.println(user);
sqlSession.close();
} @Test
public void testGetUserByUsername() {
SqlSession sqlSession = SqlSessionFactoryUtils.getSqlSessionFactory().openSession();
//获取接口的代理实现类
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
List<User> list = userMapper.getUserByUsername("张");
for (User user : list) {
System.out.println(user);
}
sqlSession.close();
} @Test
public void testInsertUser() {
SqlSession sqlSession = SqlSessionFactoryUtils.getSqlSessionFactory().openSession(true);
//获取接口的代理实现类
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
User user = new User();
user.setUsername("动态代理Dao测试");
user.setSex("1");
user.setBirthday(new Date());
user.setAddress("河南郑州");
userMapper.insertUser(user);
sqlSession.close();
} }

最新文章

  1. *HDU 2108 计算几何
  2. 【转】WPF 窗体淡入淡出动画
  3. maven 创建Hadoop程序
  4. MVC(Model(模型) View(视图) Controller(控制器))
  5. MySQL修改约束
  6. java学习笔记(3)——面向对象
  7. Beautyacticle
  8. cocos2d-x学习笔记
  9. IE浏览器设置
  10. Xcode 5 解决 The operation couldn’t be completed. (NSURLErrorDomain error -1012.) 问题
  11. 初探linux子系统集之led子系统(二)
  12. Huginn定时时间不准确或延后问题
  13. HDU 3085 Nightmare Ⅱ(噩梦 Ⅱ)
  14. 为爱好舞蹈的人们做的软件,细究数据结构,操作系统,磁盘原理,用java/c/c++写一个开源 MP3助手
  15. ASP.NET Core Http请求的处理流程
  16. Ubuntu安装最新版nodejs
  17. svn开发常用整理
  18. 编辑器之王:Emacs 和 Vim
  19. SQL Server,MySQL,Oracle三者的区别
  20. 搭建VueMint-ui框架

热门文章

  1. 《开课》---创业学习--训练营直播第一课--HHR
  2. 快速创建vue 项目
  3. ES5-Array的新增方法
  4. Cisco Packet Tracer 7.2
  5. Java学习资源 - J2SE
  6. 学习笔记(5)- ubuntu对话语料
  7. 关于cmd的命令行参数的问题
  8. 当在命令行中执行virtualenv venv时报此错误:&#39;utf-8&#39; codec can&#39;t decode byte 0xd5 in position 38: invalid continuation by
  9. JavaScript - map和parseInt的坑
  10. leetcode菜鸡斗智斗勇系列(6)--- 检查一个string里面有几个对称的字段