13_mybatis总结

作者: 七枷琴子 | 来源:发表于2018-05-28 10:52 被阅读0次

    关于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核心配置文件,上边文件的配置内容为数据源、事务管理。
    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE configuration
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">
    <configuration>
        <!-- 和spring整合后 environments配置将废除-->
        <environments default="development">
            <environment id="development">
            <!-- 使用jdbc事务管理-->
                <transactionManager type="JDBC" />
            <!-- 数据库连接池-->
                <dataSource type="POOLED">
                    <property name="driver" value="com.mysql.jdbc.Driver" />
                    <property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8" />
                    <property name="username" value="root" />
                    <property name="password" value="root" />
                </dataSource>
            </environment>
        </environments>
        
    </configuration>
    
    • `#{}和${}

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

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

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

    2.线程安全举例


    ![mybatis.hibernate初识.png](https://img.haomeiwen.com/i11080459/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总结

        本文链接:https://www.haomeiwen.com/subject/jayijftx.html