MyBatis前身是ibatis,是一个数据持久层框架。封装优化了普通JDBC过程,
如数据库连接的创建、设置SQL语句参数、执行SQL语句、事务、结果映射以及资源释放等。
MyBatis是一个支持普通SQL查询、存储过程和高级映射的优秀持久层框架,
使用简单的XML或注解用于配置和原始映射,将POJO和数据库记录进行相互映射。 基础的JDBC操作为以下七个步骤:
(1)加载JDBC驱动
(2)建立并获取数据库连接
(3)创建JDBC Statement对象
(4)设置SQL语句的传入参数
(5)执行SQL语句并获得结果
(6)处理执行结果
(7)释放相关资源 数据库连接的创建、获取和释放代码是可以复用的,而且每一次操作都进行数据库连接的创建和关闭是没有必要的,
是浪费资源和影响性能的。使用数据库连接池能够很好的解决这些问题。由于可能会使用不同的连接池,比如采用DBCP的连接池,
或者采用容器本身的JNDI数据库连接池,所以可以通过DataSource进行解耦。 使用Spring容器进行管理的MyBatis数据库连接池配置代码如:
<bean id = "dataSource" class = "org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiName" value = "${DB_JNDI_NAME}"></property>
</bean> <bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="datasource" />
<property name="configLocation" value="classpath:/config/mybatisConfig.xml"/>
</bean> 基础的JDBC进行操作数据库时,是在Java类中拼装SQL语句进行执行。为了更简单易用以及更高的性能,
MyBatis也是采用手写SQL,而不是通过复杂的配置来自动生成SQL(这两种方式的持久化框架俗称“半自动化”和“全自动化”,MyBatis是“半自动化”的翘楚,
“全自动化”的代表则是hibernate。这两个持久化框架都非常流行,而且各有自己的长处,可以根据需求适当应用)。SQL放在Java类里会有很多麻烦,第一,可读性太差了,
分散在各个Java类里不利于维护和复用;第二,改动Java代码还要重新编译部署。所以需要有统一的文件来存放相关的SQL。 XML文件可以自定义标签,而且可以使用#{参数名}的占位符来标识参数,同时可以引入JSTL中的<if test=””></if>等这样的标签来设置动态SQL,所以MyBatis中一般定义***Mapper.xml文件来保存SQL。
在数据操作中,需要有真正的Java对象来承接外部调用。所以***Mapper.xml文件会有相对应的一个***Mapper.java接口文件,框架暴露这些Mapper对象来和服务层进行对接。 MyBatis通过约定及配置来衔接各个操作。Mapper.java类中的方法名和Mapper.xml中SQL语句的id定义成相同的进行映射;配置#{参数名}来匹配对应的参数。返回结果可能为POJO、Map、List等类型,所以我们需要定义清楚返回结果类型,
在SQL语句中需要定义resultMap属性值;执行的结果和返回的POJO对象的数据结构怎么映射,在Mapper.xml文件需要配置映射的POJO对象以及属性。 Mapper.xml、Mapper.java和POJO对象这三个文件是相辅相成的。业务开发中也一般只是需要新增这三个文件内容,数据库连接和事务配置这些构架好后是不太变动的。有工具根据表结构来生成这三个文件,用不用就再说了。 总体来说,MyBatis框架定义Mapper对象来承接外部的调用,框架本身封装了SqlSession、SqlSessionFactory来进行数据库连接;封装了StatementHandler、Executor来执行数据库操作;封装了ResultSetHandler来处理查询结果。
我们只需要架构好 SqlSessionFactory的建立方式以及事务管理,根据业务提供Mapper对象。Mybatis结合Spring容器管理是一个不错的选择。 MyBatis使用中几点经验 1、手动增量配置映射文件
当有工具生成Mapper等配置文件的时候,很多人就不愿意手动写了。其实MyBatis的生成工具不是特别有用,生成的方法几乎不可用,删删改改老半天还不如自己手写快。
而且需要新加或修改属性、方法时,也是没法使用生成的文件,因为需要保留好原有的一些属性和方法。手写映射文件时先定义出用到的字段,这样配置文件会简洁清晰,
同时结果映射时效率会更高。 2、Mapper层参数为Map时,由Service层负责重载
Mapper中存在着很多类似方法,可能是分别根据字段来查询记录,或者根据某几个字段来查询。由于不能重载以及为了减少冗余代码,参数一般设置成Map。
但参数设为Map会使代码含义模糊,所以需要在service层来实现重载,对外提供的Service是代码自解释的。可以根据具体的参数不同分别调用不同的service方法。 3、尽量少用if choose等语句
Mybatis的配置SQL时,尽量少用if choose 等标签,能用SQL实现判断的尽量用SQL来判断(CASE WHEN ,DECODE等),可提高查询性能以及便于维护。
不过if与choose判断分支是不可能完全去除的,但是推荐使用SQL原生的方式来解决一些动态问题,而不应该完全依赖Mybatis来完成动态分支的判断,因为判断分支过于复杂,而且难以维护。

  

MyBatis总结(1)的更多相关文章

  1. 【分享】标准springMVC+mybatis项目maven搭建最精简教程

    文章由来:公司有个实习同学需要做毕业设计,不会搭建环境,我就代劳了,顺便分享给刚入门的小伙伴,我是自学的JAVA,所以我懂的.... (大图直接观看显示很模糊,请在图片上点击右键然后在新窗口打开看) ...

  2. Java MyBatis 插入数据库返回主键

    最近在搞一个电商系统中由于业务需求,需要在插入一条产品信息后返回产品Id,刚开始遇到一些坑,这里做下笔记,以防今后忘记. 类似下面这段代码一样获取插入后的主键 User user = new User ...

  3. [原创]mybatis中整合ehcache缓存框架的使用

    mybatis整合ehcache缓存框架的使用 mybaits的二级缓存是mapper范围级别,除了在SqlMapConfig.xml设置二级缓存的总开关,还要在具体的mapper.xml中开启二级缓 ...

  4. 【SSM框架】Spring + Springmvc + Mybatis 基本框架搭建集成教程

    本文将讲解SSM框架的基本搭建集成,并有一个简单demo案例 说明:1.本文暂未使用maven集成,jar包需要手动导入. 2.本文为基础教程,大神切勿见笑. 3.如果对您学习有帮助,欢迎各种转载,注 ...

  5. mybatis plugins实现项目【全局】读写分离

    在之前的文章中讲述过数据库主从同步和通过注解来为部分方法切换数据源实现读写分离 注解实现读写分离: http://www.cnblogs.com/xiaochangwei/p/4961807.html ...

  6. MyBatis基础入门--知识点总结

    对原生态jdbc程序的问题总结 下面是一个传统的jdbc连接oracle数据库的标准代码: public static void main(String[] args) throws Exceptio ...

  7. Mybatis XML配置

    Mybatis常用带有禁用缓存的XML配置 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE ...

  8. MyBatis源码分析(一)开篇

    源码学习的好处不用多说,Mybatis源码量少.逻辑简单,将写个系列文章来学习. SqlSession Mybatis的使用入口位于org.apache.ibatis.session包中的SqlSes ...

  9. (整理)MyBatis入门教程(一)

    本文转载: http://www.cnblogs.com/hellokitty1/p/5216025.html#3591383 本人文笔不行,根据上面博客内容引导,自己整理了一些东西 首先给大家推荐几 ...

  10. MyBatis6:MyBatis集成Spring事物管理(下篇)

    前言 前一篇文章<MyBatis5:MyBatis集成Spring事物管理(上篇)>复习了MyBatis的基本使用以及使用Spring管理MyBatis的事物的做法,本文的目的是在这个的基 ...

随机推荐

  1. 我的Android进阶之旅------>Android关于TextWatcher的初步了解

    首先来看一下TextWatcher的源代码 package android.text; /** * When an object of a type is attached to an Editabl ...

  2. QT设置TextEdit颜色

    //设置textEdit颜色 QPalette palette= ui->receiveTextEdit->palette(); palette.setColor(QPalette::Ba ...

  3. value too great for base (error token is "08")

    shell 中,经常有定时任务, 这时候shell脚本中一般会对时间进行一些判断,或者相关逻辑的操作 这时候,如果你获取的小时或者分钟是08,09,如果要再对其进行运算符或者比较的话,就会报标题的错误 ...

  4. 改善程序与设计的55个具体做法 day4

    今天晚上回到小区门口,买了点冬枣,要结账的时候想起来,钥匙没带,落公司了! TNND,没办法再回趟公司,拿了钥匙,来回一个小时,汗~ 条款10:令operator=返回一个reference to * ...

  5. ARM NEON 64bit 查找表替换

    没啥效果,如果表的长度在 64个uint8_t之类,应该可以提高查表速度,否则还是C来的快 #ifdef HAVE_NEON_AARCH64 void table_lookup_AArch64_neo ...

  6. 转 Hadoop傻瓜化:Datameer大数据收入翻三番

      淘薛奎发布到 <数据极客> 06-28 16:04 随着分析正在成为企业IT的核心,昔日的BI- ETL-EDW分析范型已经完全落伍,不再适用.而力推“大数据傻瓜化”的Datameer ...

  7. shiro2

    mapper接口:根据用户id查询用户权限的菜单 service接口:根据用户id查询用户权限的菜单 获取用户权限范围的url 思路: 在用户认证时,认证通过,根据用户id从数据库获取用户权限范围的u ...

  8. 【leetcode】Word Break

    Given a string s and a dictionary of words dict, determine if s can be segmented into a space-separa ...

  9. CSS3响应式侧边菜单

    在线演示 本地下载

  10. 【Java】-BigInteger大数类的使用【超强Java大数模板 总结】

    Scanner cin = new Scanner(new BufferedInputStream(System.in)); 这样定义Scanner类的对象读入数据可能会快一些! 参考这个博客继续补充 ...