mybatis入门截图二
--------------------
线程不安全问题
首先明白什么是线程不安全:
举例:struts2中,每个action中都定义了model模型对象(action类中是全局对象的存在 数据域属性) 用于封装前端页面提交过来的数据 所以就造成了struts2是非线程安全的,
即struts2不能使用单例模式,而只能使用多例模式,因为:当进行多线程并发请求的时候 多个线程会共用一个成员变量的值(例如两个用户请求action时 他们的数据就会有问题)
所以为了解决这个问题 struts2自然就成了多例模式的存在(注解方式配置action时 @Scope(prototype))
所以这句话就可以解释了
----------------------------------------
问题的引出:使用原始的方式开发dao
实现类:
package org.mybatis.dao; import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.po.User; public class UserDaoImpl implements UserDao { //通过构造注入SqlSessionFactory
private SqlSessionFactory sqlSessionFacory;
public UserDaoImpl(){ }
public UserDaoImpl(SqlSessionFactory sqlSessionFacory){
this.sqlSessionFacory=sqlSessionFacory;
} //问题1:因为sqlSession是非线程安全的 所以不能把sqlSession创建成全局变量 而只能写在每个方法体内 这就造成了问题2的产生 //问题2:这里面把sqlSession在每个方法中都进行了一次创建 以及事务提交 SQLSession关闭 出现大量重复代码 唯独不
//同的就是 执行的语句不同 //3.解决问题2的方法 就是使用代理模式 在执行真正的增删改查之前 先执行这些公共的代码 执行增删改查之后 执行公共代码 @Override
public void deleteUser(int id) throws Exception {
// TODO Auto-generated method stub
SqlSession sqlSession=this.sqlSessionFacory.openSession();
sqlSession.delete("test.deleteUser",id);
sqlSession.commit();
sqlSession.close();
}
@Override
public User findUserById(int id) throws Exception {
// TODO Auto-generated method stub
SqlSession sqlSession=this.sqlSessionFacory.openSession();
User user=sqlSession.selectOne("test.findUserById",id);//调用的是user.xml中写好的sql语句
//sqlSession.commit(); 没有做数据的变更 此代码不写
sqlSession.close();
return user;
} @Override
public void insertUser(User user) throws Exception {
// TODO Auto-generated method stub
SqlSession sqlSession=this.sqlSessionFacory.openSession();
sqlSession.insert("test.insertUser",user);
sqlSession.commit();
sqlSession.close();
} }
测试代码:
package org.mybatis.dao; 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 org.mybatis.po.User; public class UserDaoImplTest {
private SqlSessionFactory sqlSessionFactory; //这个代码是在测试方法之前执行的代码
@Before
public void setUp() throws Exception {
String resource="SqlMapConfig.xml";
//得到配置文件流
InputStream resourceAsStream = Resources.getResourceAsStream(resource);
//创建回话工厂
this.sqlSessionFactory=new SqlSessionFactoryBuilder().build(resourceAsStream);
} @Test
public void testFindUserById() throws Exception {
UserDao userDao=new UserDaoImpl(sqlSessionFactory);
User user=userDao.findUserById(1);
System.out.println(user);
} }
问题的解决:使用代理模式
测试下面配置的方法
创建接口类 接口中的方法 需要和上面的id一样
namespace需要写成接口类的地址
在mybatis核心配置文件中引入sql语句文件
测试类:
package org.mybatis.mapper; 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 org.mybatis.dao.UserDao;
import org.mybatis.dao.UserDaoImpl;
import org.mybatis.po.User; public class UserMapperTest { private SqlSessionFactory sqlSessionFactory; @Before
public void setUp() throws Exception {
//
String resource="SqlMapConfig.xml"; InputStream input=Resources.getResourceAsStream(resource);
sqlSessionFactory=new SqlSessionFactoryBuilder().build(input);
}
@Test
public void testFindUserById() throws Exception {
// UserDao userDao=new UserDaoImpl(sqlSessionFactory);
// User user=userDao.findUserById(1);
// System.out.println(user);
SqlSession sqlSession=sqlSessionFactory.openSession();
//得到代理对象
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
//通过代理对象 调用UserMapper类中的方法
User user=mapper.findUserById(1);
System.out.println(user);
} }
开发思路:开发mapper.xml(UserMapper.xml) 开发mapper接口(UserMapper.java)(不需要实现类 因为sql代码在配置文件中已经创建了) 在核心配置文件中引入mapper.xml
然后就可以在测试类中通过代理对象
(
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
)
调用mapper接口中的方法
User user=mapper.findUserById(1);
--------------------------------------------
全局配置文件中属性:
------------------------------
1.properties:
------------------------------------
---------------------------------------
---------------------------------
-------------------------------------
使用代理方式的前提下(1.配置文件中的namespace=对应接口类的全路径 2.接口类中的方法名=配置文件中statement对象【sql标签对象】的id值) mapper.xml和对应的接口类mapper.java在同一目录下 (接口类名称和xml配置文件名称一样) 加载该类所在的包即可
-------------------------------------------------------
mybatis入门截图二的更多相关文章
- mybatis入门系列二之输入与输出参数
mybatis入门系列二之详解输入与输出参数 基础知识 mybatis规定mapp.xml中每一个SQL语句形式上只能有一个@parameterType和一个@resultType 1. 返回 ...
- mybatis入门基础(二)----原始dao的开发和mapper代理开发
承接上一篇 mybatis入门基础(一) 看过上一篇的朋友,肯定可以看出,里面的MybatisService中存在大量的重复代码,看起来不是很清楚,但第一次那样写,是为了解mybatis的执行步骤,先 ...
- MyBatis入门(二)---一对一,一对多
一.创建数据库表 1.1.创建数据表同时插入数据 /* SQLyog Enterprise v12.09 (64 bit) MySQL - 5.6.27-log : Database - mybati ...
- mybatis入门介绍二
相信看过我的上一篇博客的同学都已经对mybatis有一个初步的认识了.这篇博客主要是对mybatis的mapper代理做一下简单的介绍,希望能够帮助大家共同学习. 我的上一篇博客:mybatis入门介 ...
- MyBatis入门(二)接口式编程
在 MyBatis入门(一) 的基础之上编写接口 将接口和Mapper文件进行绑定,会为接口创建一个代理对象,代理对象去执行增删改查 (1)编写接口 public interface EmpDao ...
- MyBatis入门(二)—— 输入映射和输出映射、动态sql、关联查询
一.输入映射和输出映射 1. parameterType(输入类型) 1.1 传递简单类型 <select id="getUserById" parameterType=&q ...
- Mybatis入门(二)------增删改查
Mybatis增删改查基本操作 一.XML实现方式 1.mapper.xml的配置 <?xml version="1.0" encoding="UTF-8" ...
- mybatis入门截图四(订单商品数据模型-懒加载-缓存)
<!-- 延迟加载的resultMap --> <resultMap type="cn.itcast.mybatis.po.Orders" id="Or ...
- mybatis入门截图四(订单商品数据模型 一对一,一对多,多对多)
--------------------------------- 一对一查询 查询订单信息,关联查询创建订单的用户信息 1.高级映射-一对一查询-使用resultType 2.高级映射-一对一查询- ...
随机推荐
- java开发环境配置(win8 64位)
自己配置java环境时是自己上网找资料装的,,有讲的好的也有讲的不是很清晰的,,自己也入了几个坑..所以在这里自己整理了下win8配置JDK的教程. 下载JDK 首先我们需要下载java开发工具包JD ...
- luogu2429 制杖题
题目大意 求不大于 m 的. 质因数集与给定有n个元素的质数集有交集的自然数之和. 数据范围 1 2 3 n*m<=10^7 4 5 n<=2,m<=10^9 6 7 n<=2 ...
- Adding a model
https://docs.asp.net/en/latest/tutorials/first-mvc-app/adding-model.html Adding data model classes I ...
- computed与methods的异同
在vue.js中,有methods和computed两种方式来动态当作方法来用的 如下: 两种方式在这种情况下的结果是一样的 写法上的区别是computed计算属性的方式在用属性时不用加(),而met ...
- Mac osx下成功安装tensorflow
安装tensorflow有多种方式:Pip, Docker, Virtualenv, Anaconda 或 源码编译的方法安装. 我是在pip下成功安装tensorflow,以下只介绍在pip下安装( ...
- lua单链表实现
List = {} --创建一个节点 function List.new(val) return {pnext = nil, value = val} end --往一个节点后添加一个节点 funct ...
- hibernate dao 公共方法
package com.dao.impl; import java.lang.reflect.ParameterizedType; import java.util.Collection; impor ...
- WCF与 Web Service的区别是什么?各自的优点在哪里呢?
这是很多.NET开发人员容易搞错的问题.面试的时候也经常遇到,初学者也很难分快速弄明白 Web service: .net技术中其实就指ASP.NET Web Service,用的时间比较长,微软其实 ...
- Cocos2d-x-3.6学习笔记第一天
系统环境: win7,python2.7 开发工具:vs2013 cocos版本:cocos2d-x-3.6 暂无模拟手机的环境 新建我的第一个cocos2d项目 1.打开cmd,cd到cocos2d ...
- 3D集合图元:最小边界框/包围盒(boundingbox)
对于2D边界框的应用时比较广泛地,它为一个简单匹配建立了很小的计算规则,3D模型的boundingbox则比较困难,计算代价较大.对于PCL库的使用则降低了计算难度,三维数值化降低了建模过程,可以使用 ...