13_mybatis总结

关于mybatis总结

mybatis是一个持久层框架,跟数据库打交道的,比hibernate火

  • 1.mybatis运行流程


    image.png

    1、mybatis配置
    SqlMapConfig.xml,此文件作为mybatis的全局配置文件,配置了mybatis的运行环境等信息。
    mapper.xml文件即sql映射文件,文件中配置了操作数据库的sql语句。此文件需要在SqlMapConfig.xml中加载。

2、通过mybatis环境等配置信息构造SqlSessionFactory即会话工厂
3、由会话工厂创建sqlSession即会话,操作数据库需要通过sqlSession进行。
4、mybatis底层自定义了Executor执行器接口操作数据库,Executor接口有两个实现,一个是基本执行器、一个是缓存执行器。
5、Mapped Statement也是mybatis一个底层封装对象,它包装了mybatis配置信息及sql映射信息等。mapper.xml文件中一个sql对应一个Mapped Statement对象,sql的id即是Mapped statement的id。
6、Mapped Statement对sql执行输入参数进行定义,包括HashMap、基本类型、pojo,Executor通过Mapped Statement在执行sql前将输入的java对象映射至sql中,输入参数映射就是jdbc编程中对preparedStatement设置参数。
Mapped Statement对sql执行输出结果进行定义,包括HashMap、基本类型、pojo,Executor通过Mapped Statement在执行sql后将输出结果映射至java对象中,输出结果映射过程相当于jdbc编程中对结果的解析处理过程。


image.png
  • 2.在classpath下创建SqlMapConfig.xml核心配置文件,上边文件的配置内容为数据源、事务管理。



    
    
        
        
            
        
            
                
                
                
                
            
        
    
    

  • `#{}和${}

` #{}表示一个占位符号,通过#{}可以实现preparedStatement向占位符中设置值,自动进行java类型和jdbc类型转换,#{}可以有效防止sql注入。 #{}可以接收简单类型值或pojo属性值。 如果parameterType传输单个简单类型值,#{}括号中可以是value或其它名称。

${}表示拼接sql串,通过${}可以将parameterType 传入的内容拼接在sql中且不进行jdbc类型转换, ${}可以接收简单类型值或pojo属性值,如果parameterType传输单个简单类型值,${}括号中只能是value。对于多参数, 需要使用pojo来封装参数。
注意, ${}不能防sql注入

  • 与hibernate的不同
  • 其他
    1.核心初始设置
核心初始测试.jpg

2.线程安全举例


![mybatis.hibernate初识.png](https://upload-images.jianshu.io/upload_images/11080459-b6097db4c8be3097.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

3.原始dao的开发方式


原始dao开发方式.png

4.异常
ambiguous 带有此单词的异常:核心配置文件SqlMapConfig.xml中mappers标签中加载的配置文件中包含多个相同statementId,解决办法,只加载一个mapper配置文件,其余的不加载
5.配置顺序,这个顺序不能颠倒


mybatis顺序.png

与测试程序


QQ截图20180523105134.png

6mybatis逆向工程 (MyBatis Generator)

.逆向工程生成代码
6.1什么是mybatis的逆向工程
mybatis官方为了提高开发效率,提高自动对单表生成sql,包括 :mapper.xml、mapper.java、表名.java(pojo类)
对着数据库用一下逆向工程,java各种类就建好了,很方便
2018年5月28日10:20:50...未完待续

你可能感兴趣的:(13_mybatis总结)