目录


SqlSession 是线程不安全的

SqlSession线程不安全 的;

对于它,我们建议在方法体内部使用;这样,即使多个线程同时访问了,每个线程都占用一片自己的内存,因此 ,sqlsession 对象就在不同的内存区域内,因此,就可以避免掉线程冲突的问题 ;


原始 dao 开发方法

原始 dao 层开发,需要我们写 接口实现类

  1. 接口

    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 ; }
  2. 实现类

    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;
    }
    }

  3. 总结

    1、上面的实现类代码中,可以看出,代码中存在着大量的模板代码,我们重复的写着这些代码;

    2、硬编码问题,我们把 statementid 硬编码到了代码中 ;

    3、参数是 object 类型,导致传任何类型的数据进去,都不会报错,即使传的数据类型根本不是映射关系中要求的类型,也不会得到报错,导致编译期间不会提示错误,直到运行期才能知道错哪了 ;


Mapper 代理方法

程序员只需要写出 mapper 接口(相当于 dao 接口)即可,无须写出实现类 ;

mapper 的开发规范:

  1. mapper.xmlnamespace 等于 mapper 接口地址

    <mapper namespace="xin.ijava.dao.UserMapper">
  2. mapper.java 接口中的方法名和 mapper.xml 中的 statementid 一致 ;

  3. mapper.java 接口中的方法输入参数类型和 mapper.xml 中的 statementparameterType 指定的类型一致 ;
  4. mapper.java 接口中的方法返回值类型和 mapper.xml 中的 statementresultType 指定的类型一致 ;

以上操作完成以后,就可以利用 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中,selectOneselectList ;

代理对象,是根据接口的返回值来,判断调用哪一个的 ,假如接口的方法,返回单个 pojo 对象,则调用 selectOne,返回集合类型,则调用 selectList

(五)mybatis开发dao层的更多相关文章

  1. MyBatis开发Dao层的两种方式(原始Dao层开发)

    本文将介绍使用框架mybatis开发原始Dao层来对一个对数据库进行增删改查的案例. Mapper动态代理开发Dao层请阅读我的下一篇博客:MyBatis开发Dao层的两种方式(Mapper动态代理方 ...

  2. MyBatis开发Dao层的两种方式(Mapper动态代理方式)

    MyBatis开发原始Dao层请阅读我的上一篇博客:MyBatis开发Dao层的两种方式(原始Dao层开发) 接上一篇博客继续介绍MyBatis开发Dao层的第二种方式:Mapper动态代理方式 Ma ...

  3. 基于Mybatis的Dao层的开发

    基于Mybatis的Dao层开发 SqlSessionFactoryBuilder用于创建SqlSessionFacoty,SqlSessionFacoty一旦创建完成就不需要SqlSessionFa ...

  4. mybatis 学习笔记(三):mapper 代理开发 dao 层

    mybatis 学习笔记(三):mapper 代理开发 dao 层 优势 通过使用mapper 代理,我们可以不需要去编写具体的实现类(使用 getMapper() 方法自动生成),只需编写接口即可, ...

  5. 基于Mybatis的Dao层开发

    转自:https://www.cnblogs.com/rodge-run/p/6528398.html 基于Mybatis的Dao层开发 SqlSessionFactoryBuilder用于创建 Sq ...

  6. mybatis开发dao的方式

    mybatis基于传统dao的开发方式 第一步:开发接口 public interface UserDao { public User getUserById(int id) throws Excep ...

  7. MyBatis学习--mybatis开发dao的方法

    简介 使用Mybatis开发Dao,通常有两个方法,即原始Dao开发方法和Mapper接口开发方法. 主要概念介绍: MyBatis中进行Dao开发时候有几个重要的类,它们是SqlSessionFac ...

  8. 四 mybatis开发dao的方法

    mybatis开发dao的方法 1.1     SqlSession使用范围 1.1.1     SqlSessionFactoryBuilder //以流的方式读取总的配置文件 Reader rea ...

  9. MyBatis开发Dao的原始Dao开发和Mapper动态代理开发

    目录 咳咳...初学者看文字(Mapper接口开发四个规范)属实有点费劲,博主我就废了点劲做了如下图,方便理解: 原始Dao开发方式 1. 编写映射文件 3.编写Dao实现类 4.编写Dao测试 Ma ...

随机推荐

  1. c++ 实现等待5s

    #include <stdio.h> /* puts, printf */ #include <time.h> /* time_t, struct tm, time, loca ...

  2. 两大主流开源分布式存储的对比:GlusterFS vs. Ceph

    两大主流开源分布式存储的对比:GlusterFS vs. Ceph 存储世界最近发生了很大变化.十年前,光纤通道SAN管理器是企业存储的绝对标准,但现在的存储必须足够敏捷,才能适应在新的基础架构即服务 ...

  3. springboot+mybatis+druid+sqlite/mysql/oracle

    搭建springboot+mybatis+druid+sqlite/mysql/oracle附带测试 1.版本 springboot2.1.6 jdk1.8 2.最简springboot环境 http ...

  4. List的子类特点

    List的子类特点:  ArrayList:        底层数据结构是数组,查询快,增删慢        线程不安全,效率高  Vector:     底层数据结构是数组,查询快,增删慢     ...

  5. 重读APUE(4)-fcntl和ioctl的区别

    fcntl(File Control)-文件控制 ioctl(In/Out Control)-I/O控制 1. fcntl作用于文件,提供对文件的基础控制:ioctl作用于文件和设备对象,一般用来向设 ...

  6. ArcGIS超级工具SPTOOLS-数据处理篇

    1. 数据处理 1.1  两个图层按重叠度赋属性 两个面层按重合度赋属性,下图把依据赋数据属性图层,按重合度,赋值给目标.,重合度设置为负值,取面积最大的. 1.2  分区域消除 按区域字段值相同的, ...

  7. 在windows平台下搭建Django项目虚拟环境

    参考文档:https://www.cnblogs.com/lovele-/p/8719126.html  https://blog.csdn.net/lwcaiCSDN/article/details ...

  8. 008-log-slf4j+log4j

    一.slf4j+log4j 1.1.POM依赖 <!-- 日志 门面 --> <dependency> <groupId>org.slf4j</groupId ...

  9. set serveroutput on

    使用set serveroutput on 命令设置环境变量serveroutput为打开状态,从而使得pl/sql程序能够在SQL*plus中输出结果 使用函数dbms_output.put_lin ...

  10. Qt编写自定义控件25-自定义QCustomPlot

    一.前言 上次在写大屏数据可视化电子看板系统时候,提到过改造QCustomPlot来实现柱状分组图.横向柱状图.横向分组图.鼠标悬停提示等.这次单独列出来描述,有很多人疑问为啥不用QChart,或者e ...