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

  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系统的核心设置,包含获取数据库连接实例的数据源和决定事务范围和控制的事务管理器。

  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实例。
  1. SqlSession session = sqlMapper.openSession();  

MyBatis包和sql脚本  mysql的
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis是一个非常流行的Java持久层框架,它可以帮助开发者简化数据库操作的过程。下面是一个MyBatis入门精通的学习路径: 1. 了解基本概念:开始学习MyBatis之前,你需要了解一些基本概念,比如什么是ORM(对象关系映射)以及为什么要使用持久层框架等。这将帮助你更好地理解MyBatis的工作原理和优势。 2. 安装和配置:为了使用MyBatis,你需要将其集成到你的项目中。首先,从MyBatis官方网站下载最新版本的MyBatis,并将其添加到你的项目依赖中。然后,配置MyBatis的主要组件,如SqlSessionFactory和SqlSession等。 3. 映射文件:MyBatis使用映射文件来定义数据库操作的SQL语句和参数映射规则。学习如何编写映射文件,并了解其常用标签和属性。 4. 数据库操作:学习如何使用MyBatis进行常见的数据库操作,如插入、更新、删除和查询等。掌握MyBatis提供的各种SQL标签和动态SQL功能,以实现更灵活的查询条件和结果映射。 5. 事务管理:了解MyBatis的事务管理机制,并学习如何在MyBatis中配置和使用事务。掌握事务的隔离级别和传播行为,以确保数据库操作的一致性和完整性。 6. 高级特性:深入学习MyBatis的高级特性,如缓存机制、插件扩展和动态SQL等。了解如何使用缓存提高查询性能,如何编写自定义插件增强MyBatis的功能,以及如何使用动态SQL实现更复杂的查询逻辑。 7. 最佳实践:学习MyBatis的最佳实践和优化技巧,以提升代码质量和性能。了解如何设计和组织Mapper接口和映射文件,如何处理复杂的查询需求,以及如何优化数据库操作的性能。 以上是一个初步的学习路径,你可以根据自己的需求和实际情况进行深入学习和实践。同时,还建议阅读官方文档和参考资料,以获得更全面和深入的理解。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值