本文是对慕课网上"搞定SSM开发"路径的系列课程的总结,详细的项目文档和课程总结放在github上了.点击查看

JDBC写法

//sql:
String sql = "select * from user";
//加载驱动:
Class.forName("com.mysql.jdbc.Driver");
//根据参数创建连接
Connection conn = DriverManager.getConnection(url,username,password);
//创建PreparedStatement
PreparedStatement statement = conn.prepareStatement(sql);
//执行sql,并使用resultSet接收结果
ResultSet rs = statement.executeQuery();
//将rs里的所有值取出来
try{
while(rs.next()){
String ... = rs.getString(1)/rs.getString("userName"); //从结果中根据列名或者列的序号取值.
}
}catch(SqlException ex){ }finally{
//必须要手动释放连接
conn.close();
}
//

以上即是一个简单的jdbc查询数据库的写法.

有什么问题呢?

第一是sql的写法,如果sql过长,参数过多,拼接起来很麻烦,不直观,并且sql很难查看;

第二是Connectione的创建和销毁需要手动控制,而这些应该是业务无关代码.

Mybatis主要概念

ORM框架是一种数据操作的框架,常见的比如JDBC,Hibernate,当然,Mybatis也是其中的一种.

相比于JDBC,Mybatis的优势在于能将Sql集中配置;并且能和Spring集成;将connection交给Spring托管,不需要开发者自己操作;同时也能方便进行AOP的开发.

而和hibernate对比,Mybatis则比较容易学,没有hibernate那么高的门槛.

如何配置Mybatis

1.配置Mybatis的配置文件Configuration.xml

2. 读取xml,创建sqlsession
        //通过配置文件获取数据库连接信息
Reader reader = Resources.getResourceAsReader("com/chentao/MicroMessage/config/mybatis-config.xml"); //通过配置信息构建一个SqlSessionFactory
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader); //通过sqlsessionfactory打开session
SqlSession sqlSession = sessionFactory.openSession(); return sqlSession;
3.配置与Sql相关的XML文件
3.1 定义namespace       --namespace定义了xml文件的域,和mybatis接口相匹配,也是为了标志在xml文件中定义的属性等
3.2 定义resultMap,用来简单接受返回对象(当然也可以不用定义,返回时)mybatis使用约定来返回对象)
3.3 在xml中定义sql,通过id对应方法名称,在java中调用
4.在Configuration.xml中将第三步配置的文件通过mapper属性引入文内存中读取
5.在Java中使用接口来调用sql写就的业务
4.关于代码中参数的使用,可以传入一个map,可以传入对象,也可以传入多个对象,在(需要接口中通过注解定义在sql中使用的参数名)
5.关于一对多配置的使用:
5.1 在resultMap中引入其他的resultMap
5.2 在sql中使用join这样的方式可以查出一对多的对象,
5.3 如果在返回结果中字段名称相同,则需要使用As指定别名,并在resultMap的属性中体现出来.

概念深入了解(加强版)

接口式编程

通过namespace的包名和相应接口的包名与类名进行匹配,可以通过调用接口的方法直接使用sql的逻辑.

mybatis实现这一特性的方法是动态代理.

分页:

根据每页的条数,和需要查询的页数可以加载整个页面的数据;

简单逻辑是从数据库拿到总条数,然后计算出总页数,然后通过数据查询出第n到m条数据,使用limit关键字(mysql中)即可以拿到需要查询的数据.

Mybatis拦截器

实现:

1:实现mybatis的Inteceptor接口

在实现类上使用注解:Intercepts来定义需要拦截哪种类型的方法.

实现plugin方法和intercept方法;

2:在plugin中根据注解和传进来的对象确定是否拦截该对象.

3:在intercept方法中确定是否拦截对应方法,并拿到其中参数,包括sql,增加自己的逻辑.

4:在intercept方法中,使用invocaiton.proceed来调用原来的逻辑.

通过拦截器实现分页是比较常见的场景.

Mybatis篇总结的更多相关文章

  1. Spring Boot 2.x 多数据源配置之 MyBatis 篇

    场景假设:现有电商业务,商品和库存分别放在不同的库 配置数据库连接 app: datasource: first: driver-class-name: com.mysql.cj.jdbc.Drive ...

  2. JavaORM框架之Mybatis篇(Ibatis)

    欢迎查看Java开发之上帝之眼系列教程,如果您正在为Java后端庞大的体系所困扰,如果您正在为各种繁出不穷的技术和各种框架所迷茫,那么本系列文章将带您窥探Java庞大的体系.本系列教程希望您能站在上帝 ...

  3. 【Java面试】Mybatis篇

    1.MyBatis编程步骤是什么样的? ① 创建SqlSessionFactory ② 通过SqlSessionFactory创建SqlSession ③ 通过sqlsession执行数据库操作 ④  ...

  4. Java面试题(Mybatis篇)

    Mybatis 125.mybatis 中 #{}和 ${}的区别是什么? #{}是预编译处理,${}是字符串替换: Mybatis在处理#{}时,会将sql中的#{}替换为?号,调用Prepared ...

  5. java 面试题 mybatis 篇

    1. 一级缓存和二级缓存? 一级缓存策略: 二级缓存策略: 2. 缓存回收策略 LRU –  最近最少使用的:移除最长时间不被使用的对象. FIFO –  先进先出:按对象进入缓存的顺序来移除它们. ...

  6. JAVA常用知识点及面试题总结

    1. String.StringBuffer.StringBuilder三者区别? (1)三者在执行速率上的比较: String<StringBuffer<StringBuilder 原因 ...

  7. JDK源码及其他框架源码解析随笔地址导航

    置顶一篇文章,主要是整理一下写过的JDK中各个类的源码及其他框架源码解析的文章,方便自己随时阅读也方便网友朋友们阅读与指正 基础篇 从为什么String=String谈到StringBuilder和S ...

  8. 成为一名Java架构师的必修课

    一.热门框架源码学习 设计模式篇 Spring5源码解读篇 Mybatis篇 SpringBoot2篇 二. 微服务架构 架构设计篇 BAT互联网架构这些年的演进分析 国内外常见分布式系统架构状况介绍 ...

  9. GitHub标星125k!阿里技术官用3个月总结出的24万字Java面试笔记

    最近收到一位粉丝的回馈! 这位粉丝已经成功入职阿里了小编很是羡慕啊! 今天就把这份30w字Java面试笔记给大家分享出来,说来也巧这份资料也是由一位阿里技术官整理出来的这算不算是"搬起石头砸 ...

随机推荐

  1. 在VirtualBox 虚拟机中安装CentOS7 64位实验基础系统

    1.将CentOS-7-x86_64-Minimal ISO加载入虚拟机,选择安装CentOS 7 2.启动欢迎画面,保持默认,选择 继续 3.安装参数设置 3-1.设置时区以便同步时间,将时区更改为 ...

  2. NodeMCU Builder, yet another NodeMCU IDE

    最近几天研究基于NodeMCU的Wi-Fi小车,突然之间想要写一个专门开发NodeMCU Lua代码的工具自己用,由于官方已经有了NodeMCU Studio,所以我的就叫NodeMCU Builde ...

  3. CS窗体程序数据列表分页

    以前,觉得winform程序分页很无趣,也没实际意义,直到近期的项目实践中让我认识到原来winform数据列表分页也是非常有必要的,因为由于数据量过大的情况,当窗体在初始加载数据的时候如果不做条件的限 ...

  4. ThinkPHP中处理模板引擎的volist标签

    Volist标签主要用于在模板中循环输出数据集或者多维数组 必须得属性有:name属性,要输出的数据模板变量,id是循环变量. 其他属性参见开发手册. 通常模型的select方法返回的结果是一个二维数 ...

  5. springMVC+commons-fileupload上传文件大小限制异常

    异常信息: 严重: Servlet.service() for servlet [suibian] in context with path [/SpringMvcDemo3] threw excep ...

  6. 中文编程语言之Z语言初尝试: ZLOGO 4

    原文: https://zhuanlan.zhihu.com/p/31505895. 作者为本人. @TKT2016 开发的Z语言(ZLOGO是它的一个部分)是本人至今看到的唯一一个仍活跃开发的开源且 ...

  7. ElasticSearch 学习记录之集群分片内部原理

    分片内部原理 分片是如何工作的 为什么ES搜索是近实时性的 为什么CRUD 操作也是实时性 ES 是怎么保证更新被持久化时断电也不丢失数据 为什么删除文档不会立即释放空间 refresh, flush ...

  8. 解决failed to push some refs to git

    Administrator@PC-20150110FGWU /K/cocos2d/yc (master) $ git push -u origin master To git@github.com:y ...

  9. 记一次高并发场景下.net监控程序数据上报的性能调优

    最近在和小伙伴们做充电与通信程序的架构迁移.迁移前的架构是,通信程序负责接收来自充电集控设备的数据实时数据,通过Thrift调用后端的充电服务,充电服务收到响应后放到进程的Queue中,然后在管理线程 ...

  10. EFCore2.0 Code First基本使用

    前言 在网上找EFCore Code First相关的文章,很多都是基于core 1.0版本的,觉得有必要自己实践下2.0.所以,撸起袖子干吧!~ 1.新建控制台项目(这里就不放图了) 2.打开程序包 ...