`

MyBatis 入门到精通(一) 了解MyBatis获取SqlSession

 
阅读更多

MyBatis是什么?

MyBatis是一款一流的支持自定义SQL、存储过程和高级映射的持久化框架。MyBatis几乎消除了所有的JDBC代码,也基本不需要手工去设置参数和获取检索结果。MyBatis能够使用简单的XML格式或者注解进行来配置,能够映射基本数据元素、Map接口和POJOs(普通java对象)到数据库中的记录。

 

简介

 

每个MyBatis应用程序主要都是使用SqlSessionFactory实例的,一个SqlSessionFactory实例可以通过SqlSessionFactoryBuilder获得。SqlSessionFactoryBuilder可以从一个xml配置文件或者一个预定义的配置类的实例获得。
 
 
用xml文件构建SqlSessionFactory实例是非常简单的事情。推荐在这个配置中使用类路径资源(classpath resource),但你可以使用任何Reader实例,包括用文件路径或file://开头的url创建的实例。MyBatis有一个实用类----Resources,它有很多方法,可以方便地从类路径及其它位置加载资源。
 

MyBatis工作流程

(1)加载配置并初始化
触发条件:加载配置文件
配置来源于两个地方,一处是配置文件,一处是Java代码的注解,将SQL的配置信息加载成为一个个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。
(2)接收调用请求
触发条件:调用Mybatis提供的API
传入参数:为SQL的ID和传入参数对象
处理过程:将请求传递给下层的请求处理层进行处理。
(3)处理操作请求 触发条件:API接口层传递请求过来
传入参数:为SQL的ID和传入参数对象
处理过程:
(A)根据SQL的ID查找对应的MappedStatement对象。
(B)根据传入参数对象解析MappedStatement对象,得到最终要执行的SQL和执行传入参数。
(C)获取数据库连接,根据得到的最终SQL语句和执行传入参数到数据库执行,并得到执行结果。
(D)根据MappedStatement对象中的结果映射配置对得到的执行结果进行转换处理,并得到最终的处理结果。
(E)释放连接资源。
(4)返回处理结果将最终的处理结果返回。
 
 

功能架构

 
我们把Mybatis的功能架构分为三层:

1、API接口层:

 
提供给外部使用的接口API,开发人员通过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。

2、数据处理层:

 
负责具体的SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目的是根据调用的请求完成一次数据库操作。

3、基础支撑层:

 
负责最基础的功能支撑,包括连接管理、事务管理、配置加载和缓存处理,这些都是共用的东西,将他们抽取出来作为最基础的组件。为上层的数据处理层提供最基础的支撑。  
 

从XML中构建SqlSessionFactory

[java] view plaincopy
  1. String resource = "com/accp/mybatis/data/Configuration.xml";    
  2. Reader reader = Resources.getResourceAsReader(resource);    
  3. sqlMapper = new SqlSessionFactoryBuilder().build(reader);    
 

MyBatis主配置文件

MyBatis配置文件中大标签configuration下子标签包括:

configuration

|--- properties

|--- settings

|--- typeAliases

|--- typeHandlers

|--- objectFactory

|--- plugins

|--- environments

|--- |--- environment

|--- |--- |--- transactionManager

|--- |--- |__ dataSource

|__ mappers

XML <configuration>配置文件包含对MyBatis系统的核心设置,包含获取数据库连接实例的数据源和决定事务范围和控制的事务管理器。
 
[html] view plaincopy
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE configuration  
  3. PUBLIC "-//mybatis.org//DTD Config 3.0//EN"  
  4. "http://mybatis.org/dtd/mybatis-3-config.dtd">  
  5. <configuration>  
  6.   
  7.     <!--在下面的datasource中可以使用占位符来引用属性文件中的值-->  
  8.     <properties resource="properties/datasource.properties" />  
  9.   
  10.     <settings>  
  11.         <setting name="cacheEnabled" value="true" />  
  12.         <setting name="lazyLoadingEnabled" value="true" />  
  13.         <setting name="multipleResultSetsEnabled" value="true" />  
  14.         <setting name="useColumnLabel" value="true" />  
  15.         <setting name="useGeneratedKeys" value="false" />  
  16.         <setting name="defaultExecutorType" value="SIMPLE" />  
  17.         <setting name="defaultStatementTimeout" value="25000" />  
  18.     </settings>  
  19.       
  20.     <!-- 配置别名 类型别名是Java 类型的简称。它仅仅只是关联到XML 配置,简写冗长的JAVA 类名。-->  
  21.     <typeAliases>  
  22.         <typeAlias type="com.accp.mybatis.model.Blog" alias="Blog"/>  
  23.     </typeAliases>  
  24.     <!-- 使用这个配置,"Blog"就能在任何地方代替"com.accp.mybatis.model.Blog"被使用。-->  
  25.       
  26.     <!--  
  27.     java 中一些简单类型的别名  
  28.         别名  映射的类型   
  29.         _byte  byte   
  30.         _long  long   
  31.         _short  short   
  32.         _int   int    
  33.         _integer   int    
  34.         _double  double   
  35.         _float   float    
  36.         _boolean  boolean   
  37.         string  String   
  38.         byte  Byte   
  39.         long  Long   
  40.         short  Short   
  41.         int   Integer   
  42.         integer   Integer   
  43.         double  Double   
  44.         float   Float    
  45.         boolean  Boolean   
  46.         date  Date   
  47.         decimal  BigDecimal   
  48.         bigdecimal  BigDecimal   
  49.         object  Object   
  50.         map  Map   
  51.         hashmap  HashMap   
  52.         list  List    
  53.         arraylist  ArrayList   
  54.         collection  Collection   
  55.         iterator  Iterator  
  56.     -->  
  57.       
  58.   
  59.     <!-- 每个数据库(environment)对应一个SqlSessionFactory 实例-->  
  60.     <environments default="accp">  
  61.     <!--   
  62.         environments对于一个应用可能连接多个数据库,那就需要配置不同的环境来连接不同的数据库,  
  63.         每一个SqlSessionFactory对应一个environments也可以设置不同的环境应用于开发或测试的环境如果环境被忽略,  
  64.         那么默认环境将会被加载,也就是default="development"的作用了  
  65.     -->  
  66.         <environment id="accp">  
  67.             <transactionManager type="JDBC" />  
  68.             <!--   
  69.                 transactionManager设置事物的管理类型是 type=”[JDBC|MANAGED]”  
  70.                 JDBC使用datasource的连接来管理事物范围。  
  71.                 MANAGED自己不进行事物的提交和回滚,依靠容器来管理事物,设置closeConnection为false,取消自动关闭连接   
  72.             -->  
  73.             <dataSource type="POOLED">  
  74.             <!--  
  75.                 dataSource设置数据源[UNPOOLED|POOLED|JNDI]  
  76.                 POOLED:每次被请求时简单打开和关闭连接  
  77.                 POOLED:JDBC 连接对象的数据源连接池的实现,用来避免创建新的连接实例时必要的初始连接和认证时间。  
  78.                 poolMaximumActiveConnections –  在任意时间存在的活动(也就是正在使用)连接的数量。默认值:10   
  79.                 poolMaximumIdleConnections –  任意时间存在的空闲连接数。  
  80.                 oolMaximumCheckoutTime –  在被强制返回之前,池中连接被检查的时间。默认值:20000 毫秒(也就是 20 秒)  
  81.                 poolTimeToWait – 这是给连接池一个打印日志状态机会的低层次设置,还有重新尝试获得连接,这些情况下往往需要很长时间(为了避免连接池没有配置时静默失败)。 默认值:20000 毫秒(也就是 20 秒)  
  82.                 poolPingQuery –  发送到数据的侦测查询,用来验证连接是否正常工作,并且准备接受请求。默认是“NO PING QUERY SET”,这会引起许多数据库驱动连接由一个错误信 息而导致失败。   
  83.                 poolPingEnabled  –  这是开启或禁用侦测查询。如果开启,你必须用一个合法的SQL语句(最好是很快速的)设置 poolPingQuery 属性。默认值:false。  
  84.                 poolPingConnectionsNotUsedFor  –  这是用来配置 poolPingQuery 多次时间被用一次。这可以被设置匹配标准的数据库连接超时时间,来避免不必要的侦测。默认值:0 (也就是所有连接每一时刻都被侦测-但仅仅当 poolPingEnabled 为 true 时适用)。    
  85.                 JNDI –  这个数据源的实现是为了使用如 Spring 或应用服务器这类的容器,容器可以集中或在外部配置数据源,然后放置一个 JNDI 上下文的引用。  
  86.                 initial_context  –  这个属性用来从初始上下文中寻找环境(也就是initialContext.lookup(init ial——context))。这是个可选属性,如果被忽略,那么data_source 属性将 会直接以 init ialContext 为背景再次寻找。   
  87.                 data_source  –  这是引用数据源实例位置的上下文的路径。它会以由 init ial_context查询返回的环境为背景来查找,如果 init ial_context 没有返回结果时,直接以初始上下 文为环境来查找。  
  88.             -->  
  89.                 <property name="driver" value="${driver}" />  
  90.                 <property name="url" value="${url}" />  
  91.                 <property name="username" value="${username}" />  
  92.                 <property name="password" value="${password}" />  
  93.                 <property name="driver.encoding" value="${encoding}" />  
  94.             </dataSource>  
  95.         </environment>  
  96.     </environments>  
  97.   
  98.     <!--mappers是告诉MyBatis 去哪寻找映射SQL 的语句。可以使用类路径中的资源引用,或者使用字符,输入确切的URL 引用。-->  
  99.     <mappers>  
  100.         <mapper resource="com/accp/mybatis/data/BlogMapper.xml" />  
  101.     </mappers>  
  102. </configuration>  

 

从SqlSessionFactory中获取SqlSession

通过以下代码获得SqlSession实例。
[java] view plaincopy
  1. SqlSession session = sqlMapper.openSession();  
MyBatis包和sql脚本  mysql的
分享到:
评论

相关推荐

    SpringBoot+MyBatis+SqlSession

    该项目应用Springboot框架,MyBatis持久层与Sqlsession映射进行数据查询

    mybatis获取SqlSession源代码流程

    mybatis获取SqlSession源代码流程

    获取Java的MyBatis框架项目中的SqlSession的方法

    SqlSession中包括已经映射好的SQL语句,这样对象实例就可以直接拿过来用了,那么这里就来讲解获取Java的MyBatis框架项目中的SqlSession的方法

    MybatisHandBook:MyBatis从入门到精通原始码-源码通

    Mybatis演示 一,Mybatis怎么跑起来...使用时通过SqlSessionFactory工厂对象获取一个SqlSession。 通过SqlSession的selectList方法查找到CountryMapper.xml中id =“ selectAll”的方法,执行SQL查询。 MyBatis灵活使用

    mybatis-3.2.5.jar及mybatis-spring-1.2.2.jar

    这个类库也提供一个简单的方式来注入 MyBatis 数据映射器和 SqlSession 到业务层的 bean 中。 而且它也会处理事务, 翻译 MyBatis 的异常到 Spring 的 DataAccessException 异常(数据访问异常,译者注)中。最终,它并 ...

    mybatis中的sqlsession--executor实现.zip

    mybatis中的sqlsession--executor实现 mybatis中的sqlsession--executor实现

    mybatis-spring-1.2.3

    这个类库也提供一个简单的方式来注入 MyBatis 数据映射器和 SqlSession 到业务层的 bean 中。 而且它也会处理事务, 翻译 MyBatis 的异常到 Spring 的 DataAccessException 异常(数据访问异常,译者注)中。最终,它并 ...

    springmybatis

    mybatis实战教程mybatis in action之一开发环境搭建 mybatis实战教程mybatis in action之二以接口的方式编程 mybatis实战教程mybatis in action之三实现数据的增删改查 mybatis实战教程mybatis in action之四实现...

    mybatis-3.1.1-bundle

    这个类库也提供一个简单的方式来注入 MyBatis 数据映射器和 SqlSession 到业务层的 bean 中。 而且它也会处理事务, 翻译 MyBatis 的异常到 Spring 的 DataAccessException 异常(数据访问异常,译者注)中。最终,它并 ...

    MyBatis执行SQL并将结果映射成Java对象.docx

    5. Executor执行器要处理的SQL信息是封装到一个底层对象MappedStatement中 该对象包括SQL语句 输入参数映射信息 输出结果映射信息 其中输入参数和输出结果的映射类型包括HashMap集合对象 POJO对象类型

    新MyBatis教程高手带你练手,玩框架轻松(3.15G)

    MyBatis-009-复习第一个例子.avi MyBatis-010-开发常见问题.avi MyBatis-011-三种处理方式.avi MyBatis-012-配置日志.avi MyBatis-013-SqlSessionFactory和SqlSession对象介绍.avi MyBatis-014-工具类使用.avi ...

    【Spring整合Mybatis配置及测试代码】

    这个类库也提供一个简单的方式来注入 MyBatis 数据映射器和 SqlSession 到业务层的 bean 中。 而且它也会处理事务, 翻译 MyBatis 的异常到 Spring 的 DataAccessException 异常(数据访问异常,译者注)中。最终,它并 ...

    Spring+MyBatis

    这个类库也提供一个简单的方式来注入 MyBatis 数据映射器和 SqlSession 到业务层的 bean 中。 而且它也会处理事务, 翻译 MyBatis 的异常到 Spring 的 DataAccessException 异常(数据访问异常,译者注)中。最终,它并 ...

    mybatis-spring-1.2.2.jar

    这个类库也提供一个简单的方式来注入 MyBatis 数据映射器和 SqlSession 到业务层的 bean 中。 而且它也会处理事务, 翻译 MyBatis 的异常到 Spring 的 DataAccessException 异常(数据访问异常,译者注)中。最终,它并 ...

    MyBatis3 用户指南

    MyBatis是一款一流的支持自定义SQL、存储过程和高级映射的持久化框架。MyBatis几乎消除了所有的JDBC代码,也基本不需要手工去设置参数和获取检索结果。MyBatis能够使用简单的XML格式或者注解进行来配置,能够映射...

    spring-mybatis

    这个类库也提供一个简单的方式来注入 MyBatis 数据映射器和 SqlSession 到业务层的 bean 中。 而且它也会处理事务, 翻译 MyBatis 的异常到 Spring 的 DataAccessException 异常(数据访问异常,译者注)中。最终,它并 ...

    05第一天-mybatis-mybatis的使用_MyBatis的jar包导入_SqlSession对象的创建_mybatis.xml文件的创建和配置.mp4

    MyBatis的前身就是iBatis , MyBatis使用XML描述符或注释将对象与存储过程或SQL语句耦合,将关系数据库与面向对象应用程序结合使用变得更加容易。支持定制化SQL、存储过程以及高级映射。

    深入浅出MyBatis技术原理与实战

    第 6 章: 介绍 MyBatis 的解析和运行原理, 我们将了解到 SqlSession 的构建方法, 以 及其四大对象是如何工作的。 第 7 章: 在第 6 章的基础上着重介绍 MyBatis 的插件, 这里我们将学习插件的设计原 理, 以及...

    day01_eesy_03mybatis_dao.zip

    不要忘记在映射配置中告知mybatis要封装到哪个实体类中 配置的方法:指定实体类的全限定类名 mybatis基于注解的入门案例: 把IUserDao.xml移除,在dao接口的方法上使用@Select注解,并且指定SQL语句 同时...

    mybatis-3-mybatis-3.5.13.zip

    MyBatis作为一个流行的持久化框架,其源码是开放的,允许开发者深入了解框架内部的实现细节。MyBatis源码体系庞大,涵盖了各种功能和模块,下面将简要描述MyBatis源码的主要组成部分以及核心工作原理。 1. 核心模块...

Global site tag (gtag.js) - Google Analytics