备注:ibatis 迁入google code 更名为Mybatis

官方文档:http://mybatis.org/mybatis-3/

比较好的教程推荐:http://www.blogjava.net/davidjefiny/archive/2013/12/22/Mybatis.html

Mybaits介绍

Mybatis是一个持久层(ORM)框架,把实体类和POJO之间建立了映射关系,是半自动的ORM实现。

Mybatis 优点:

【1】基于SQL语法,简单易学

【2】能了解底层的组装过程

【3】SQL语句的封装在XML配置文件,便于统一管理和维护,降低了程序的耦合度

【4】程序调试方便

Mybaits基本要素:

【1】configuration.xml 全局配置文件

【2】mapper.xml 核心映射文件

【3】SqlSession 接口

基础配置文件configuration.xml

configuration.xml是系统的核心配置文件,包含数据源和事务管理等设置和属性信息,Xml文档结构如下:

configuration 配置

properties 可以配置在Java属性配置文件中

settings 修改Mybatis在运行时的行为方式

typeAliases 为Java类型命名一个较短的名字

TypeHandlers 类型处理器

objectFactory 对象工厂

plugins 插件

environments 环境

environment 环境变量

transactionManager 事务控制器

dataSource 数据源

mappers 映射器

事务管理:

Mybatis支持两种事务管理类型:

JDBC->利用JDBC的提交和回滚功能,利用连接的数据源来管理事务的作用域。

MANAGED-> 这个类型什么都不做,不提交、不回滚 、不关闭连接。而是让窗口来管理事务的全部生命周期(比如Spring或者J2EE服务器)。

数据源:

数据源有三种:UNPOOLED   POOLED    JNDI

UNPOOLED   这个数据源实现在每次请求的时候简单的打开和关闭一个连接。虽说有点慢,但是一些不需要性能和立即响应的应用来说,是一种选择。

POOLED   数据源缓存JDBC连接独享用于避免每次都要打开连接和生成连接对象需要的验证时间。对于高并发Web,一般采用这种方法。

JNDI   这种数据源是为了和Spring或者应用服务一起使用,可以在外部也可以内部配置这个数据源,然后在JNDI上下文中引用它。

SQL映射文件:

【1】相对路径:

<mappers>
<mapper resource=""org/mybatis/builder/UserManager.xml></mapper>
</mappers>

【2】全路径:

 <mappers>
<mapper url="file:///var/sqlmaps/AuthorMapper.xml"></mapper>
</mappers>

SQL映射文件:

SQL映射文件结构:

cache   ---   配置命名空间的缓存。

cache-ref    ----  从其他命名空间引用缓存配置。

resultMap   ---  最复杂  最给力的元素 用来描述如何从结果集中加载对象

sql  ---  重用的SQL 块,可以被其他语句引用。

insert  update  delete  select

Insert

主键策略:如果表中有自动增长得主键,可以设置 useGeneratedKeys = "true"  keyProperty="主键"

动态SQL:

Mybatis强大功能之一就是动态SQL能力

if

choose(when  otherwise)

trim(where    set )

foreach

SQL映射文件:

SQL  这个元素定义一个可以复用的SQL语句片段,供其他语句调用。

比如:

 <sql id="userColumns">id,username,passwd</sql>
 <select id="selectUser" parameterType="int" resultType="hashmap">

 select <include refid="userColumns"/> from _table where id=#{id}

 </select>

动态SQL:

缓存---cache:缓存技术是一种“以空间换时间”的设计理念,利用内存空间资源来提高数据检索速度的有效手段之一。

Mybaits 默认情况是没有开启缓存的,除了局部的session缓存。需要开启二级缓存,需要在SQL映射文件添加一行

<cache />

比如:<cache eviction = "FIFO" flushInverval = "6000" size = "512" readOnly = ""true>

SqlSessionFactoryBuilder:一旦创建,SqlSessionFactory 就会在应用程序中始终存在。所以没有理由去销毁和再创建,一个应用程序也不建议多次创建SqlSessionFactory。所以作用域做好事Application。可以有很多实现方式:最好就是单例模式或者静态单例模式。但是这种并不被赞成和好用的,反而使用Google Guice 或则Spring来进行依赖反射会更好。允许生成管理器SqlSessionFactory的单例生命周期。

SqlSession 生命周期:

SQLSession  每个线程都有自己的SqlSession实例,SqlSession实例是不能被共享,也不是线程安全的。最好使用Request作用域或者方法体作用域。如果使用Web框架,应该让SqlSession更随HTTP请求的相似作用域。也就是说,在收到一个HTTP请求过后,打开SqlSession,等返回一个回应后,立马关掉Sqlsession。关闭SqlSession非常重要的,,下面是标准的方式关闭:

SqlSession session = sqlSessionFactory.openSession();

try{

//TODO:

}

finally{ session.close(); }

SqlSesson接口:

SqlSession获取方式:

 Reader reader = Resources.getResourceAsReader("configuration.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
SqlSession sqlSession = sqlSessionFactory.openSession();

SqlSession的使用:

调用insert update selectList selectOne delete 等方法执行增删改查等操作。

提取SQL的方法:

 Configuration configuration = sqlSession.getConfiguration();
MappedStatement mStatement = configuration.getMappedStatement(sqlid);
BoundSql boundSql = mStatement.getBoundSql(Param);
String sql = boundSql.getSql();

可以用于自定义打印日志

分页方法:

最新文章

  1. NC凭证接口(Java发送流和处理返回结果)
  2. UVa11549计算器谜题[floyd判圈]
  3. 编译android源码官方教程(3)下载代码
  4. CSS深入理解之line-height
  5. html 元素添加 class
  6. (转载)MS SQL Server 未公开的加密函数有哪些?
  7. AxisFault另外一个问题
  8. python高级编程(第12章:优化学习)2
  9. sql中在查询语句中加判断,控制输出的内容
  10. springmvc中使用response的out.print问题
  11. Api 和 Spi
  12. 详述JavaScript数组
  13. mysql-5.7.17.msi安装
  14. [CSDN_Markdown]使用LaTeX基本数学公式
  15. 日常报错记录2: MyBatis:DEBUG [main] - Logging initialized using &#39;class org.apache.ibatis.logging.slf4j.Slf4jImpl&#39; adapter.------------ Cause: java.lang.NoSuchMethodException: com.offcn.dao.ShopDao.&lt;init&gt;()
  16. 测试覆盖率工具EclEmma安装与使用
  17. js实现颜色渐变
  18. RabbitMQ--windows10环境下的RabbitMQ安装步骤(转)
  19. linux驱动开发第二步 驱动模块传参(module_param函数使用)
  20. 【设计模式】—— 职责链模式ChainOfResponsibility

热门文章

  1. RelativeSource={RelativeSource TemplatedParent}
  2. GIT和SVN比较
  3. ubuntu16.04下安装配置深度学习环境(Ubuntu 16.04/16.10+ cuda7.5/8+cudnn4/5+caffe)
  4. 11-THREE.JS 相机始终朝向某个物体
  5. 【Prism】MEF版HelloWorld
  6. 仿QQ撒花特效--第三方开源--FllowerAnimation
  7. Git_学习_09_Commit message 和 Change log 编写指南
  8. Rational Rose 2003 下载、破解及安装方法(图文)
  9. kong插件官方文档翻译
  10. RabbitMQ 权限分离&amp;HA操作文档