(五)mybatis开发dao层
目录
SqlSession 是线程不安全的
SqlSession
是 线程不安全
的;
对于它,我们建议在方法体内部使用;这样,即使多个线程同时访问了,每个线程都占用一片自己的内存,因此 ,sqlsession
对象就在不同的内存区域内,因此,就可以避免掉线程冲突的问题 ;
原始 dao 开发方法
原始 dao
层开发,需要我们写 接口
和 实现类
;
接口
package xin.ijava.dao; import xin.ijava.pojo.User; /**
* @author An
*/
public interface UserDao { /**
* 添加用户
* @param user 封装好的用户信息
* @throws Exception
*/
public void insertUser(User user) throws Exception ; /**
* 删除用户 根据 id
* @param id 用户 id
* @throws Exception
*/
public void deleteUserById(int id ) throws Exception ; /**
* 更新用户
* @param user 封装新信息的用户对象
* @throws Exception
*/
public void updateUser(User user) throws Exception ; /**
* 查找用户
* @param id 用户id
* @return 用户对象
* @throws Exception
*/
public User findUserById(int id) throws Exception ; }
实现类
package xin.ijava.dao; import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import xin.ijava.pojo.User; /**
* @author An
*/
public class UserDaoImpl implements UserDao{ /**
* 注入sqlSessionFactory 工厂
*/
private SqlSessionFactory factory ; public UserDaoImpl(SqlSessionFactory factory){
this.factory = factory ;
} @Override
public void insertUser(User user) throws Exception {
SqlSession sqlSession = factory.openSession() ;
sqlSession.insert("test.insertUser",user) ;
sqlSession.close();
} @Override
public void deleteUserById(int id) throws Exception {
SqlSession sqlSession = factory.openSession() ;
sqlSession.delete("test.deleteUserById",id) ;
sqlSession.close();
} @Override
public void updateUser(User user) throws Exception {
SqlSession sqlSession = factory.openSession() ;
sqlSession.update("test.updateUserById",user) ;
sqlSession.close();
} @Override
public User findUserById(int id) throws Exception {
SqlSession sqlSession = factory.openSession() ;
User user = sqlSession.selectOne("test.findUserById",id) ;
sqlSession.close();
return user;
}
}
总结
1、上面的实现类代码中,可以看出,代码中存在着大量的模板代码,我们重复的写着这些代码;
2、
硬编码问题
,我们把statement
的id
硬编码到了代码中 ;3、参数是
object
类型,导致传任何类型的数据进去,都不会报错,即使传的数据类型根本不是映射关系中要求的类型,也不会得到报错,导致编译期间不会提示错误,直到运行期才能知道错哪了 ;
Mapper 代理方法
程序员只需要写出 mapper
接口(相当于 dao
接口)即可,无须写出实现类 ;
mapper
的开发规范:
在
mapper.xml
中namespace
等于mapper
接口地址<mapper namespace="xin.ijava.dao.UserMapper">
mapper.java
接口中的方法名和mapper.xml
中的statement
的id
一致 ;mapper.java
接口中的方法输入参数类型和mapper.xml
中的statement
的parameterType
指定的类型一致 ;mapper.java
接口中的方法返回值类型和mapper.xml
中的statement
的resultType
指定的类型一致 ;
以上操作完成以后,就可以利用 mybatis
生成代理对象 ;
@Test
public void test2() throws Exception {
SqlSession sqlSession = factory.openSession() ;
// 获取代理对象,参数写上类的全路径名
UserMapper userMapper = sqlSession.getMapper(xin.ijava.dao.UserMapper.class) ;
// 利用代理对象,操作
User user = userMapper.findUserById(1) ;
System.out.println(user);
}
关于代理对象
代理对象是怎么知道具体调用什么方法的呢?
在构建代理对象的时候,会去查询 xxxMapper,xml
映射关系,根据标签名,就可以知道是调用什么方法了;标签名有: <select> 、<delete> 、<update> 、<insert>
;
根据接口方法名字,也就是 标签的 id
值,查询标签的名字,从而知道调用什么方法 ;
其中 select
方法,有点不同;因为有2中,selectOne
、selectList
;
代理对象,是根据接口的返回值来,判断调用哪一个的 ,假如接口的方法,返回单个 pojo
对象,则调用 selectOne
,返回集合类型,则调用 selectList
;
(五)mybatis开发dao层的更多相关文章
- MyBatis开发Dao层的两种方式(原始Dao层开发)
本文将介绍使用框架mybatis开发原始Dao层来对一个对数据库进行增删改查的案例. Mapper动态代理开发Dao层请阅读我的下一篇博客:MyBatis开发Dao层的两种方式(Mapper动态代理方 ...
- MyBatis开发Dao层的两种方式(Mapper动态代理方式)
MyBatis开发原始Dao层请阅读我的上一篇博客:MyBatis开发Dao层的两种方式(原始Dao层开发) 接上一篇博客继续介绍MyBatis开发Dao层的第二种方式:Mapper动态代理方式 Ma ...
- 基于Mybatis的Dao层的开发
基于Mybatis的Dao层开发 SqlSessionFactoryBuilder用于创建SqlSessionFacoty,SqlSessionFacoty一旦创建完成就不需要SqlSessionFa ...
- mybatis 学习笔记(三):mapper 代理开发 dao 层
mybatis 学习笔记(三):mapper 代理开发 dao 层 优势 通过使用mapper 代理,我们可以不需要去编写具体的实现类(使用 getMapper() 方法自动生成),只需编写接口即可, ...
- 基于Mybatis的Dao层开发
转自:https://www.cnblogs.com/rodge-run/p/6528398.html 基于Mybatis的Dao层开发 SqlSessionFactoryBuilder用于创建 Sq ...
- mybatis开发dao的方式
mybatis基于传统dao的开发方式 第一步:开发接口 public interface UserDao { public User getUserById(int id) throws Excep ...
- MyBatis学习--mybatis开发dao的方法
简介 使用Mybatis开发Dao,通常有两个方法,即原始Dao开发方法和Mapper接口开发方法. 主要概念介绍: MyBatis中进行Dao开发时候有几个重要的类,它们是SqlSessionFac ...
- 四 mybatis开发dao的方法
mybatis开发dao的方法 1.1 SqlSession使用范围 1.1.1 SqlSessionFactoryBuilder //以流的方式读取总的配置文件 Reader rea ...
- MyBatis开发Dao的原始Dao开发和Mapper动态代理开发
目录 咳咳...初学者看文字(Mapper接口开发四个规范)属实有点费劲,博主我就废了点劲做了如下图,方便理解: 原始Dao开发方式 1. 编写映射文件 3.编写Dao实现类 4.编写Dao测试 Ma ...
随机推荐
- jumpserver官方手动安装
测试环境 CPU: 64位双核处理器 内存: 4G DDR3 数据库:mysql 版本大于等于 5.6 mariadb 版本大于等于 5.5.6 环境 系统: CentOS 7 IP: 192.168 ...
- devstack 使用openstack命令报错 The request you have made requires authentication. (HTTP 401) Missing value auth-url required for auth plugin password
关联错误: The request you have made requires authentication. (HTTP 401) (Request-ID: req-88ad2cba-0f2d-4 ...
- reGeorg(不需要外网ip的代理)
reGeorg _____ ______ __|___ |__ ______ _____ _____ ______ | | | ___|| ___| || ___|/ \| | | ___| | \ ...
- OpenResty之ngx_lua模块的加密接口
原文: ngx_Lua模块中的加密api接口 ngx.crc32_short digest = ngx.crc32_short(str) 该方法主要是计算给定字符串 str 的循环校验码(Cyclic ...
- ZT:阿里合伙人发文:十年磨一剑,自研数据库终拿世界第一
按:真正做技术的,就该这样. 以下为全文转载 (观察者网讯) 10月24日,阿里巴巴合伙人.高德总裁刘振飞在阿里云开发者社区发文,回忆从2009年启动“去IOE”工程到2019年OceanBase拿下 ...
- 二、navicat连接本地数据库以及远程数据库
本地连接 1.打开navicat 2.连接 最后点击确定就连接成功了: 远程数据库 和上面一样.....
- 15 Flutter BottomNavigationBar自定义底部导航条 以及实现页面切换 以及模块化
效果: /** * Flutter BottomNavigationBar 自定义底部导航条.以及实现页面切换: * BottomNavigationBar是底部导航条,可以让我们定义底部Tab ...
- LODOP设置纸张无效问题
有的打印机不支持自定义纸张,或不支持当前设置的纸张尺寸,会造成纸张尺寸和代码里设置的尺寸不一致的情况.现象:1.代码一样,纸张语句设置正确,有的打印机纸张正常,有的打印机不正常.2.代码一样,纸张语句 ...
- LODOP直接导出图片不弹框
之前有博文测试了导出图片的图片长度关系,是直接弹窗的选择保存路径的方式:Lodop导出图片,导出单页内容的图片最近测试下不弹窗保存图片是否可以,样例是保存的excel,测试了下图片,图片也是可以的,该 ...
- Centos7 系统更改apache默认网站目录(解决You don't have permission to access / on this server问题)
当我们在Centos7中配置好Apache时,发现apache默认解析目录是在 /var/www/html,也就是说当访问服务器 IP 或者本地 localhost 时, 默认定位到这个目录里的 in ...