zoukankan      html  css  js  c++  java
  • mybatis基本流程及原理

    MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的
    JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口
    和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。
     
    搭建Mybatis
    1.添加驱动包(mysql.jar和mybatis的jar包)
    <dependency> 
        <groupId>org.mybatis</groupId> 
        <artifactId>mybatis</artifactId> 
        <version>3.4.6</version> 
    </dependency> 
    <dependency> 
        <groupId>mysql</groupId> 
        <artifactId>mysql-connector-java</artifactId>     <version>5.1.40</version> 
    </dependency>
    2.添加配置文件:src/mybatis-confifig.xml
    连接数据库的配置文件的作用:
    (1).指定连接数据库的url,username,password,driver
    (2).由框架自动获取连接
    (3).指定了事务的管理对象
    配置文件中default要和id值相同,default表示默认访问环境,
    但是也可以自己指定使用哪个id数据源,代码如下:
    SqlSession session= new SqlSessionFactoryBuilder().build(r,"a2").openSession();

    mybatis-confifig.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> 
    <environments default="development"> 
        <environment id="development"> 
        <transactionManager type="JDBC"/>
        <dataSource type="POOLED"> 
        <property name="driver" value="com.mysql.jdbc.Driver"/>             
      <property name="url" value="jdbc:mysql://localhost:3306/dbName"/> <property name="username" value="root"/> <property name="password" value="123456"/> </dataSource> </environment> </environments> <!-- 指定maper文件的路径(maven项目从resources源文件夹下找资源)--> <mappers> <mapper resource="包名/mapper文件名"/> </mappers> </configuration>
    3.创建实体类和接口类
    4.添加mapper文件
    注:在mapper文件中保存sql语句
    <mapper namespace="接口的完整路径"> 
        <insert id="方法名" parameterType="参数类型"> //sql 
        </insert> 
        <select id="方法名" resultType="查询后的返回值类型">
         //sql语句---注:sql语句没有分号 
        </select> 
    </mapper>
    5.修改mybatis的配置文件,让该配置文件知道mapper文件的存在
    6.获得SqlSession,通过该对象进行数据的操作
    //1.加载配置文件 
    Reader r=Resources.getResourceAsReader("mybatis-config.xml");
     //2.创建SqlSessionFactoryBuilder对象 
    SqlSessionFactoryBuilder builder= new SqlSessionFactoryBuilder(); //3.得到session工厂
     SqlSessionFactory factory=builder.build(r); 
    //4.得到session 
    SqlSession session= factory.openSession(); 
    //5.调取sql语句,insert("方法的完整路径"),路径=namespace+id 
    int rs=session.insert("dao.EmpDao.insertEmp",e);
     session.commit();

    基本原理

    mybatis基本流程

    1.mybatis全局配置文件配置数据源、事务等,配置映射文件(配置sql语句)mapper.xml
    2.SqlSessionFactory(会话工厂),根据配置文件创建工厂,作用:产生sqlsession
    3.sqlsession会话,是面向用户的接口,作用:操作数据库(发出sql的增删查改)
    4.executor执行器,是基本的执行器、缓存执行器的接口
    5.mapper statement底层封装对象,作用:对数据库存储封装,包括sql语句,

    sql输入映射参数、输出结果类型如hashmap、基本数据类型、pojo,sql输出映射参数、输出结果类型如hashmap、基本数据类型、pojo
    6.mysql数据库层

     

    其中sqlSessionFactory 一般使用单例模式,SqlSesion包含属性,所以线程不安全,所以SqlSessiony一般作为方法的局部变量。

    Mybatis中有一级缓存和二级缓存,默认情况下一级缓存是开启的,而且是不能关闭的。一级缓存
    是指 SqlSession 级别的缓存,当在同一个 SqlSession 中进行相同的 SQL 语句查询时,第二次以
    后的查询不会从数据库查询,而是直接从缓存中获取,一级缓存最多缓存 1024 条 SQL。二级缓存
    是指可以跨 SqlSession 的缓存。是 mapper 级别的缓存,对于 mapper 级别的缓存不同的
    sqlsession 是可以共享的。

      1. Mybatis 的一级缓存原理 ( sqlsession 级别 )
        第一次发出一个查询 sql,sql 查询结果写入 sqlsession 的一级缓存中,缓存使用的数据结构是一
        个 map。
        key:MapperID+offset+limit+Sql+所有的入参
        value:用户信息
        同一个 sqlsession 再次发出相同的 sql,就从缓存中取出数据。如果两次中间出现 commit 操作
        (修改、添加、删除),本 sqlsession 中的一级缓存区域全部清空,下次再去缓存中查询不到所
        以要从数据库查询,从数据库查询到再写入缓存。
      2. 二级缓存原理 ( mapper 基本 )
        二级缓存的范围是 mapper 级别(mapper同一个命名空间),mapper 以命名空间为单位创建缓
        存数据结构,结构是 map。mybatis 的二级缓存是通过 CacheExecutor 实现的。CacheExecutor
        其实是 Executor 的代理对象。所有的查询操作,在 CacheExecutor 中都会先匹配缓存中是否存
        在,不存在则查询数据库。
        key:MapperID+offset+limit+Sql+所有的入参
        具体使用需要配置:
      3. Mybatis 全局配置中启用二级缓存配置
      4. 在对应的 Mapper.xml 中配置 cache 节点
      5. 在对应的 select 查询节点中添加 useCache=true
  • 相关阅读:
    std::bind常见的坑
    valgrind使用指南
    Makefile (1) gcc基础
    准备篇(三)Makefile
    win10激活
    C语言结构体篇 结构体
    C语言字符篇(五)内存函数
    C语言字符篇(四)字符串查找函数
    C语言字符篇(三)字符串比较函数
    C语言字符篇(二)字符串处理函数
  • 原文地址:https://www.cnblogs.com/misaki-workshop/p/13882218.html
Copyright © 2011-2022 走看看