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层。

posted @ 2016-08-09 20:04  roren  阅读(208)  评论(0编辑  收藏  举报