SpringMVC,MyBatis学习笔记

《深入分析Java Web技术内幕》笔记

------------SpringMVC-----------

1.SpringMVC配置:在web.xml的<servlet>中配置DispatcherServlet,再在<init-parm>中配置name为contextConfigLocation的具体配置文件classpath:spring-
mvc.xml。
2.在spring-mvc.xml中配置:三个核心组件的bean配置。处理器适配:HandlerAdapter,处理核心类中的核心方法。映射处理器:HandlerMapping,根据请求的url地址进行解析。视图解析:ViewResolver,告诉spring容器视图层位置与视图层文件格式。
3.SpringMVC主要八个组件,除以上三个核心组件外,还有:MultipartResolver,ThemeResolver,HandlerExceptionResolver,LocalerResolver,RequestToViewNameTransLator。分别用于:文件上传,处理国际化,定义主题,出错处理,替换指定ViewName。
4.初始化8个组件的Bean对象保存在DispatcherServlet类中。
5.SpringMVC的Control主要由HandlerMapping和HandlerAdapters两个组件提供。
6.HandlerMapping负责映射用户的URL和对应的处理类,定义了一个根据URL必须返回一个由HandlrExecutionChain代表的处理链,需要在这个处理链中添加任意的HandlerAdapters实例来处理这个URL对应的请求。实际思路和Servlet规范中的Filter处理类似。
7.HandlerAdapter定义各种Handler。在SpringMVC把特别的URL对应到一个继承某个接口的Handler,然后SpringMVC调用这个接口定义的方法。(在Struts2中不继承接口,但通过反射调用方法)。SpringMVC提供另一种方式,可以不固定Handler接口类,也就是URL对应的Handler可以实现多个接口,每个接口定义不同的方法。
8.DispatcherServlet会根据Handler对象在其handlerAdapters集合中匹配哪个HandlerAdapter实例支持该Handler对象。接下去执行Handler对象的相应方法,如该Handler对象的相应方法返回一个ModelAndView对象接下就是去执行View渲染。
9.Model模块:ModelAandView对象是连接业务逻辑层与View展现层的桥梁,对SpringMVC来说它也是连接Handler与View的桥梁。ModelAndView对象持有一个ModelMap对象或Map对象和一个View对象或View名称。前者是执行模板渲染时需要的变量对应的实例,如在JSP端通过request获取。
10.View模块:由两个组件支持,RequestToViewNamoTranslator和ViewResolver。前者支持自定义对ViewName的解析eg.将请求的ViewName加前后缀。后者根据ViewName创建View对象,渲染出页面。

------------MyBatis-----------

1.总结:MyBatis通过SQLMap将Java对象映射成SQL语句,将结果集再转化成Java对象,与其他ORM框架相比,既解决了Java对象与输入参数和结果集的映射,又能够让用户方便的手写SQL语句。
2.MyBatis主要完成两件事:根据JDBC与数据库建立连接,通过反射打通Java对象与数据库参数交互之间相互转化的关系。
3.MyBatis一个重要组成部分是SqlMap配置文件,SqlMap配置文件的核心是Statement语句,形成ParameterMap、ResultMap两个对象,用于处理参数和经过解析后交给数据库处理的SQL对象。完成了除了数据库连接的SQL语句的执行条件。
4.数据映射大体过程:根据Statement定义的SQL语句,解析出其中的参数,按照出现的顺序保存在Map集合中,并按照Statement中定义的ParameterMap对象类型解析出参数的Java数据类型,根据其数据类型构建对象。
5.MyBatis运行执行步骤:创建SqlMapSession对象→对象池中取SessionScope对象→建立数据库连接→对象池取出RquestScope对象→执行SQL语句→映射Java对象参数到ParameterMap,映射数据库列名到ResultMap→归还RequestScope对象到对象池→释放数据库连接→归还SessionScope对象到对象池→销毁或共享SqlMapSession对象。
6.SqlMapSession负责创建数据库的连接,包括对事务的管理,MyBatis既可以管理事务又可以由外部管理。
7.MyBatis解析SQL语句:MyBatis配置文件中定义的SQL语句,参数的赋值是“#”包裹的变量。解析Statement成ParameterMap、ResultMap以及解析后的SQL。MyBatis构建好RequestScope执行环境后,把传过来对对象数据结合ParameterMap中的信息提取出参数数组,顺序对应于SQL中参数的顺序,调用方法提交参数。
8.数据库字段映射到Javz对象:返回信息需要的资源包含在RequestMap中,保存返回结果的ResultSet对象后,只需根据ResultClass创建返回对象,把列名映射到Java类对象的对应属性中setter()进去。
9.MyBatis实际完成:对数据库数据源管理,包括事务管理,MyBatis通过配置文件来管理SQL既输入参数的映射,返回结果到Java对象的映射,返回Java对象回Controller层。

时间: 2024-12-13 07:39:07

SpringMVC,MyBatis学习笔记的相关文章

springmvc+mybatis学习笔记(汇总)

springmvc+mybatis学习笔记(汇总) 标签 : springmvc mybaits springmvcmybatis学习笔记汇总 目录 联系作者 笔记分为两大部分:mybatis和springmvc mybatis springmvc 笔记内容主要是mybatis和springmvc的一些基本概念和使用方法,涉及概念介绍.环境搭建.编程细节.运行调试等方面. 这套笔记整体偏入门和应用,适合快速上手,对底层实现和机理并未做过多分析.我后续会研读spring源码,并把学习的收获写成博客

MyBatis:学习笔记(3)——关联查询

MyBatis:学习笔记(3)--关联查询 关联查询 理解联结 SQL最强大的功能之一在于我们可以在数据查询的执行中可以使用联结,来将多个表中的数据作为整体进行筛选. 模拟一个简单的在线商品购物系统,如果我们将用户信息和订单信息都保存在user表中,这样就不存在联结关系,因为我们仅仅操作一张表就好. 但是这是非常不明智的选择,举例来说,一个用户可以拥有多个订单,如果保存在一个表中,势必会导致用户信息的多次出现,因为每个订单绑定的用户信息都是相同的. 所以我们尽量要将不同的信息存储与不同的表中,但

mybatis学习笔记(1)

之前做项目的时候,DAO层写了一些spring jdbc,用起来的确不是很方便,今天特意去学习了新的框架:mybatis.把之前用spring-jdbc写的内容换成了mybatis框架搭建的内容. 首先你要到mybatis的官网去下mybatis的jar包:mybatis-3.2.7.jar.由于我是在spring的基础上去搭建mybatis所以还要去弄一个mybatis-spring-1.2.2.jar, 这个连接的包好像在spring官方是找不到的,需要自己去网上找. 进入正题.首先在src

Mybatis学习笔记(二) 之实现数据库的增删改查

开发环境搭建 mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包.这些软件工具均可以到各自的官方网站上下载.首先建立一个名字为 MyBaits 的 dynamic web project 1. 可以创建maven项目,依赖的包mybatis-3.2.0-SNAPSHOT.jar,mysql-connector-java-5.1.22-bin.jar <!-- mybatis包 --> <depe

MyBatis MapperScannerConfigurer配置――MyBatis学习笔记之八

MyBatis MapperScannerConfigurer配置——MyBatis学习笔记之八 2012-09-02 20:01:42 标签:Spring MyBatis MapperScannerConfigurer bean默认命名 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://legend2011.blog.51cto.com/3018495/980150 在上一篇博文的示例中,我们在beans.xml中配置了stu

mybatis学习笔记(9)-订单商品数据模型分析

mybatis学习笔记(9)-订单商品数据模型分析 mybatis学习笔记9-订单商品数据模型分析 数据模型分析思路 数据模型分析 订单商品数据模型建表sql 本文对接下来几篇博客中用到的数据模型进行分析,并附上建表sql文件和测试数据文件 数据模型分析思路 每张表记录的数据内容 分模块对每张表记录的内容进行熟悉,相当于你学习系统需求(功能)的过程. 每张表重要的字段设置 非空字段.外键字段 数据库级别表与表之间的关系 外键关系 表与表之间的业务关系 在分析表与表之间的业务关系时一定要建立在某个

mybatis学习笔记(11)-多对多查询

mybatis学习笔记(11)-多对多查询 mybatis学习笔记11-多对多查询 示例 多对多查询总结 resultMap总结 本文实现多对多查询,查询用户及用户购买商品信息. 示例 查询主表是:用户表 关联表:由于用户和商品没有直接关联,通过订单和订单明细进行关联,所以关联表:orders.orderdetail.items sql SELECT orders.*, user.username, user.sex, user.address, orderdetail.id orderdeta

mybatis学习笔记(11)-一对多查询

mybatis学习笔记(11)-一对多查询 mybatis学习笔记11-一对多查询 示例 小结 本文实现一对多查询,查询订单及订单明细的信息 示例 sql 确定主查询表:订单表 确定关联查询表:订单明细表 在一对一查询基础上添加订单明细表关联即可. SELECT orders.*, user.username, user.sex, user.address, orderdetail.id orderdetail_id, orderdetail.items_id, orderdetail.item

mybatis学习笔记(二)-- 使用mybatisUtil工具类体验基于xml和注解实现

项目结构  基础入门可参考:mybatis学习笔记(一)-- 简单入门(附测试Demo详细过程) 开始体验 1.新建项目,新建类MybatisUtil.java,路径:src/util/MybatisUtil.java package util; import java.io.InputStream; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; i

mybatis学习笔记(13)-查询缓存之二级缓存

mybatis学习笔记(13)-查询缓存之二级缓存 mybatis学习笔记13-查询缓存之二级缓存 二级缓存原理 开启二级缓存 调用pojo类实现序列化接口 测试方法 useCache配置 刷新缓存就是清空缓存 应用场景和局限性 本文主要讲mybatis的二级缓存,二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的. 二级缓存原理 首先开启mybatis的二级缓存. sqlS