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

从SqlSessionFactory中获取SqlSession

通过以下代码获得SqlSession实例。
[java] view plaincopy
  1. SqlSession session = sqlMapper.openSession();
MyBatis包和sql脚本  mysql的
Download:http://download.csdn.net/detail/rootsuper/5024937

MyBatis 入门到精通(一) 了解MyBatis获取SqlSession相关推荐

  1. 41.从入门到精通:格式化日期 获取某月日历 Time 模块 日历(Calendar)模块 其他相关模块和函数

    41.从入门到精通:格式化日期 获取某月日历 Time 模块 日历(Calendar)模块 其他相关模块和函数 格式化日期 获取某月日历 Time 模块 日历(Calendar)模块 其他相关模块和函 ...

  2. MyBatis从入门到精通(1):MyBatis入门

    作为一个自学Java的自动化专业211大学本科生,在学习和实践过程中"趟了不少雷",所以有志于建立一个适合同样有热情学习Java技术的参考"排雷手册". 最近在 ...

  3. MyBatis从入门到精通(三):MyBatis XML方式的基本用法之多表查询

    最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. 多表查询 上篇博客中,我们示例的 ...

  4. MyBatis从入门到精通(九):MyBatis高级结果映射之一对一映射

    最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解MyBatis中实现查 ...

  5. MyBatis从入门到精通(二):MyBatis XML方式的基本用法之Select

    最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. 明确需求 书中提到的需求是一个基 ...

  6. mybatis实战教程(mybatis in action),mybatis入门到精通

     目录(?) [-] mybatis实战教程mybatis in action之一开发环境搭建 mybatis实战教程mybatis in action之二以接口的方式编程 mybatis实战教程 ...

  7. MyBatis入门到精通——Mybatis入门篇

    目录 一.什么是 MyBatis? 二.入门案例 (1)创建maven项目 (2)引入依赖包 (3)创建数据库执行sql脚本 三.入门程序源码 (1)User.java (2)UserMapper.j ...

  8. MyBatis从入门到精通(一):MyBatis入门

    最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. MyBatis简介 ​ 2001 ...

  9. MyBatis 入门到精通(二) SQL语句映射XML文件

    MyBatis 真正强大之处就在这些映射语句,也就是它的魔力所在.对于它的强大功能,SQL 映射文件的配置却非常简单. 如果您比较SQL 映射文件配置与JDBC 代码,您很快可以发现,使用SQL 映射 ...

最新文章

  1. C#生成pdf的源代码
  2. 博途上载hmi程序_西门子HMI触摸屏(精智面板)恢复出厂设置方法
  3. redis分布式缓存(二)
  4. python使用pip安装包_12.2.1 使用pip安装Python包
  5. MyEclipse 2017 CI 10 发布(附下载)
  6. size_t,__T,_T,TEXT,_TEXT等一些特殊宏的理解
  7. 华为2017.7.26机试
  8. html5里面怎么引入字体
  9. java 进度条实现原理_java进度条功能的实现原理是什么?实例展示
  10. liunx破解root密码精简版
  11. Markdown文档常用字体及颜色设置
  12. C语言结构体(Struct)——摘自C语言学习网
  13. 推荐 10 个好用的 JavaScript 代码压缩工具
  14. 超简单! 一个标签搞定跑马灯,纯css制作跑马灯效果
  15. 17、Java基础---接口
  16. Sen2Cor+SNAP处理Sentinel数据
  17. 番外篇15:libevent简单理解(附libevent官方代码解析,和跨平台服务器、客户端链接代码)
  18. webpack 极简教程(前端自动化构建)
  19. [ecshop 资料 ] 通联支付 wap 手机端 开发帮助中心 手机支付网关 帮助中心
  20. 你对未来计算机的展望,未来计算机发展的展望

热门文章

  1. python登录交换机执行命令_利用Python脚本登录交换机实现自动配置备份的方法
  2. San 3.7.3 发布,百度开源的 MVVM 组件框架
  3. python dic字典使用
  4. 泛型与容器连载(一)泛型的基本概念和原理
  5. 作业6--第3、4、5天进度
  6. c++ 模板参数做容器参数迭代器报错 vectorT::const_iterator,typename const报错
  7. 免费资源下载:暗色色系的超棒搜索框和下拉菜单UI欣赏
  8. 素数之年,IT运维其实可以很简单
  9. Windows Server 2003 SP2 RIS 配置问题
  10. Linux 命令(109)—— ping 命令