【MyBatis详解】mybatis框架详解总结

目录

什么是MyBatis?

步骤

        1.导入依赖

        2.在项目中去加入主配置文件(在此之前,实体类和持久接口和数据库应该建立好),然后根据项目去修改主配置文件的内容。

        3.导入映射文件

MyBatis组成三个基本要素

        1.核心接口和类(SqlSessionFactory 和 SqlSession)

        2.核心配置文件mybatis.cfg.xml

        3.SQL映射文件(mapper.xml)

SqlSessionFactory

SqlSession

核心配置文件mybatis.cfg.xml

SQL映射文件(mapper.xml)


什么是MyBatis?

        简单来说,MyBatis是一个持久层框架,属于JDBC的替代方案之一,他的前身是iBatis。

        它属于ORM关系型映射。

        ORM(O/R - Mapping 对象关系映射),是一种把内存中的对象保存到关系型数据库的技术。用它封装数据库访问的细节。采用元数据(XML)的方式来描述对象-关系(数据库表)的映射细节,可以使得ORM充当任何一个Java应用业务层到数据库之间的桥梁。

        MyBatis 几乎免除了(简化)JDBC中那些繁琐的工作(建立连接、PreparedStatement-预编译sql、设置占位符、获取结果集等一系列),可以让开发者更多的关注SQL语句本身。(MyBatis 内部封装了JDBC)。

步骤

        1.导入依赖

        在Maven工程中,我们使用mybatis框架需要导入3个依赖

        <!--   mybatis核心包-->
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.9</version>
        </dependency>
        <!--       mybatis支持JDK8新类型的扩展包    -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-typehandlers-jsr310</artifactId>
            <version>1.0.2</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.29</version>
        </dependency>

        2.在项目中去加入主配置文件(在此之前,实体类和持久接口和数据库应该建立好),然后根据项目去修改主配置文件的内容。

        2.1类型别名

<typeAliases><!-- 别名配置 允许使用指定包中的类名作为实体类的类型 -->
   <package name="com.Yuu"/>
</typeAliases>

        2.2数据源配置(驱动,URL,数据库端口号,名称,密码)

<environments default="dev">  <!-- 环境配置  -->

     <environment id="dev">  
        <!-- 指定事物管理器类型  此时指定为JDBC  -->
         <transactionManager type="JDBC"></transactionManager>  
        <!-- 设置数据源 -->
         <dataSource type="POOLED">  
           <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
           <property name="url" value="jdbc:mysql://localhost:端口号/数据库名?characterEncoding=utf-8&amp;allowMultiQueries=true"/>
           <property name="username" value="用户名"/>
           <property name="password" value="密码"/>
         </dataSource>  

     </environment>  

 </environments> 

        2.3 映射文件所在位置

        映射文件所在位置通常情况下和持久接口在同一个包中。

<mappers>
      <!--  扫描指定包下的映射文件     -->
      <package name="com.Yuu.Dao"/>
</mappers>

        3.导入映射文件

        3.1导入映射文件前需要在resources目录下,创建和持久接口所在包同名的目录。

        3.2 导入映射文件时,需要将映射文件和需要映射的持久接口同名。

        3.3导入后,在映射文件mapper元素的namespace属性书写接口全路径。

<mapper namespace="com.Yuu.Dao.映射文件的接口名"><!-- 指定映射文件的接口的全限定名 -->

        3.4 在3.3完成后,就可以通过标签书写sql语句

<!-- <select id=""></select>  书写查询sql语句 -->
<!-- <insert id=""></select>  书写插入sql语句 -->
<!-- <delete id=""></select>  书写删除sql语句 -->
<!-- <update id=""></select>  书写修改sql语句 -->

MyBatis组成三个基本要素

        1.核心接口和类(SqlSessionFactory 和 SqlSession)

        2.核心配置文件mybatis.cfg.xml

        3.SQL映射文件(mapper.xml)

SqlSessionFactory

        它是MyBatis中的核心对象,是数据库映射关系经过编译后的内存镜像。   

        作用:用来创建 SqlSession。

        SqlSessionFactory可以根据上层对象(接口)SqlSessionFactoryBuilder来进行创建。

        SqlSessionFactoryBuilder可以通过核心配置文件 或者 Java代码定义好的配置类来构建。

        SqlSessionFactory是线程安全的,一旦被创建,在整个应用的生命周期都会存在。如果多次创建同一个数据库的SqlSessionFactory,会导致数据库资源被消耗过剩。因此通常情况下,同一个数据库只会对应一个SqlSessionFactory,所以在构建SqlSessionFactory实例时,会使用单例模式创建。

SqlSession

·        它是MyBatis中的核心对象,是应用程序与持久层之间执行交互操作的单线程对象。

        SqlSession是线程不安全的。使用范围最好限制在一次请求或一个方法中。不能放在类的静态字段中。

        作用:执行数据库持久化操作。

        【注意】:在使用完SqlSession对象后,需要关闭资源。

        通常情况下,每一个线程都应该有一个SqlSession实例,且不共享。

核心配置文件mybatis.cfg.xml

        作用:主要用来配置mapper文件的位置、mybatis的缓存、设置类的别名以及连接数据库的驱动等, 另一个就是与接口相关的mapper文件,用来指定执行那个接口的操作。

        1.项目必须为Maven,才能通过依赖导入Jar包。(见第一段插入代码)

        2.mybatis.cfg.xml---主配置文件必须放在resources目录下。

        3.configuration配置顺序不可更改,否则解析出错

SQL映射文件(mapper.xml)

        作用:可以通过读取映射文件调用相应的方法,获取SqlSessionFactoty工厂对象;在映射文件中 完成sql语句。

        1.通常是用来映射持久层接口,因此需要映射文件和它对应的接口同名

        2.在resources目录下,需要创建和接口所在包同名的文件夹。

        【注意】注意在resources目录下,如果创建目录时有多个层级的目录,需要在每个层级之间用 / 分割,此时才会创建出有层级关系的目录。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值