MyBatis框架简介

news2024/12/23 20:18:11

8607319d612b436e885ea96d0c2d32cf.jpgMyBatis是一个开源的数据持久层框架,内部封装了通过JDBC访问数据库的操作,支持普通的SQL查询、存储过程和高级映射。作为持久层框架,主要思想是将程序中的大量的SQL语句分离出来,配置在相应的配置文件中,这样可以在不修改代码的情况下,直接在配置文件中的修改SQL。

 

         ORM(Object/Relational Mapping)对象关系映射。是一种数据持久化的技术。在对象模型和关系型数据库之间建立关系,并且提供了一种机制,通过JavaBean对象去操作数据库表中的数据。MyBatis通过简单的XML或者注解进行配置和原始映射,将实体类和SQL语句之间建立映射关系,是一种半自动化的ORM实现。

MyBatis环境搭建:

         1.下载jar包,

官方网站:http://mybatis.org.(目前官网在国内受限制,若可以访问到,所有下载链接全部引导至github上-----推荐下载mybatis-3.2.2.zip和mybatis-3-mybatis-3.2.2.zip)

github网址:https://github.com/mybatis/mybatis-3/releases.

         2.部署jar包,

将下载的jar包以及需要的jar包(如:数据库驱动jar文件或log4j负责日志数据jar文件)部署至项目的lib目录下。

         3.创建mybatis核心配置文件-configuration.xml

copycode.gif

<?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>
    <properties resource="mybatis.properties" />
    <typeAliases>
        <package name="cn.bdqn.pojo" />
    </typeAliases>
    <!-- 配置数据源,事务 -->
    <environments default="deploy">
        <environment id="deploy">
            <!-- 事务管理器:JDBC/MANAGED -->
            <transactionManager type="JDBC" />
            <!-- 数据源:POOLED/UNPOOLED/JNDI -->
            <dataSource type="POOLED">
                <property name="driver" value="${driver}" />
                <property name="url" value="${url}" />
                <property name="username" value="${username}" />
                <property name="password" value="${password}" />
            </dataSource>
        </environment>
    </environments>
</configuration>

copycode.gif

  configuration:配置文件的根节点。

  Properties:从外部引入指定的properties属性文件,一般为数据库连接的配置信息。

  Settings:设置MyBatis运行中的一些行为,如果,此次设置MyBatis的log日志文件实现为LOG4J,既使用log4j实现日志功能。

  Environments表示配置多套运行环境,映射到不同的数据库,该元素下可以配置多个environment子元素节点,但是必须通过default指定一个默认的运行环境。

    <mappers>
        <mapper resource="cn/bdqn/dao/IUserMapper.xml" />
    </mappers>

  Mappers:作用是告诉MyBatis去哪里找SQL映射文件。

  Mapper:具体指定SQL映射文件的路径,resource属性的值表示映射文件的路径。

------注意:MyBatis中核心配置文件的元素节点是有一定顺序的,若不按顺序排位,那么XML文件会报错。

4.创建持久化类(POJO)和SQL映射文件。

  因为MyBatis是pojo(实体类)与是SQL语句之间的映射机制,一般情况下,保证pojo类的属性和表中的字段名一致。

SQL映射文件元素节点

         Mapper:映射文件的根元素节点,只有一个属性namespace:

                   Namespace:用于区分不同的mapper.全局唯一。(一般为接口的完全限定名)

         Select:查询语句,常用属性如下(特别属性后面介绍---)

                   Id:该命名空间下的唯一标识符。

                   resultType:表示SQL语句的返回值类型。

5.编写测试类

         (1)读取全局配置文件(xxx.xml”)

    Reader reader = Resources.getResourceAsReader(“xxx.xml”);

         (2)创建sqlsessionfactory,完成配置文件的读取。

    SqlSessionFactory    sessionFactory = new SqlSessionFactoryBuilder().build(reader);

         (3)创建sqlSession对象,通过sqlSession调用相应的方法进行操作。

    sessionFactory.openSession();//打开sqlSession对象

    Sqlsession.getMapper(接口名.class).执行的方法(参数);

         (4)关闭sqlSession对象。

    sessionFactory.close();//关闭sqlSession对象

 

MyBatis优缺点以及其适用场合

优点:

    1.与JDBC相比,代码量减少了50%以上。

    2.最简单的持久层框架,小巧简单易学

    3.SQL语句写在XML文件,从程序代码中彻底分离,便于统一管理和优化,并可重用。

    4.提供XML标签,支持编写动态SQL语句。

    5.提供映射文件,支持对象与数据库的ORM字段关系映射。

缺点:

    1.SQL编写工作量较大,对开发人员编写SQL语句的功底有一定的要求。

    2.SQL依赖于数据库,数据库的移植性差,不能随意更换数据库。

适应场合:

    专注于SQL本身,一个灵活的DAO层的解决方案,对性能要求较高,或者需求变化较多的项目。

 

MyBatis的基本要素-----核心对象。

一、核心接口和类。

  (1)每个MyBatis的应用程序都以一个SqlSessionFactory对象的实例为核心。

  (2)首先获取SqlSessionFactoryBuilder对象,根据xml文件或Configuration类的实例构建该对象。

  (3)获取SqlSessionFactory对象,通过SqlSessionFactoryBuilder对象获取。

  (4)通过SqlSessionFactory获取SqlSession实例,此实例完全包含以数据库为背景的所有执行SQL操作方法。

    直接执行已经映射的SQL语句。

  1.SqlSessionFactoryBuilder对象

作用:负责构建SqlSessionFactory,并且提供了多个build()方法的重载

    (1).build(Reader reader,String environment,Properties properties)//字节流

    (1).build(InputStream inputStream,String environment,Properties properties)//字符流

    (1).build(Configuration config)//类

生命周期和作用域:最大的特点为用过即丢,一旦创建了SqlSessionFactory对象之后,这个类就不再需要了。

最佳范围存在于方法体内,也就是个局部变量而已。

·  2.SqlSessionFactory对象

作用:可以通过此对象的OpenSession()方法获得SqlSession()实例。

生命周期和作用域:对象一旦创建,在整个应用运行过程中始终存在。最佳的作用域范围是Application,随着应用的生命周期一同存在。

--------------------------------------------------------------------------------------------------------------------------

1.创建工具类util,在静态块中创建SqlSessionFactory对象。

    1422675-20180619102025473-208054118.png

 2.创建SqlSession对象和关闭SqlSession

   1422675-20180619104649010-1349764835.png

 

--------------------------------------------------------------------------------------------------------------------------

 ·  3.SqlSession对象

作用:用于持久化操作的对象,类似于JDBC中的connection,提供了面向数据库执行SQL命令所需的所有方法,

 生命周期和作用域:对应着一次数据库会话,若关闭的SqlSession会话,就需要重新创建它。

注意:每个线程都有自己的SqlSession实例,所以不能被共享,是线程非安全的,最佳作用域范围是request作用域或者方法体作用域。

使用方式:1.直接执行已映射的Sql语句,例如:直接调用selectList方法执行查询。

     2.基于mapper接口方式操作数据。例子:Sqlsession.getMapper(接口名.class).执行的方法(参数);

二、核心配置文件

核心配置文件的一些基本的元素,需注意,元素节点有相应的先后顺序。如下图:

    1422675-20180619111212911-816923129.png

----configuration元素为整个xml配置文件的根节点,相当于总管。

1.properties元素:外部化、可替代的属性。

  (1)通过外部指定的方式:<properties resource="database.properties">引入database.properties文件。

  (2)直接配置xml文件。

    <properties>

      <property name = "xx" value = "xx">......

    </properties>

补充:如果以上的两种方式同时使用的话,外部引入优先级高于property子节点配置的值。

2.settings元素:设置重要的选项,用于设置和改变MyBatis运行中的行为。

设置项描述允许值默认值
cacheEnabled对在此配置文件下的所有cache进行全局性开/关设置true | falsetrue
lazyLoadingEnabled全局设置懒加载,设置为false,则所有相关联的都会被初始化加载true | falsetrue
autoMappingBehaviorMyBatis对于resultMap自动映射的自动匹配级别NONE | PARTIAL | FULLPARTAL

  autoMappingBehavior的三个允许值:

  NONE 表示取消自动映射;PARTIAL 只会自动映射没有定义嵌套结果集映射的结果集。 FULL 会自动映射任意复杂的结果集(无论是否嵌套)。

3.typeAliases元素:配置类型别名,减少输入多余的完整类名,以简化操作。

  更简化的写法:通过package的name属性直接指定包名,MyBatis会自动扫描指定包下的JavaBean,并默认设置别名(javabean的非限定类名)

4.environments元素:配置多套运行环境,可讲SQL映射应用到不同数据库环境上.

  (1)默认的运行ID:通过default属性来指定当前的运行环境ID。对于环境ID的命名要确保唯一。

  (2)transactionManager事务管理器:类型分为JDBC和MANAGED,直接使用JDBC的提交和回滚功能。

    一、使用JDBC的事务管理机制:即利用java.sql.Connection对象完成对事务的提交(commit())、回滚(rollback())、关闭(close())等

    二、使用MANAGED的事务管理机制:这种机制MyBatis自身不会去实现事务管理,而是让程序的容器如(JBOSS,Weblogic)来实现对事务的管理

  (3)dataSource元素使用标准的JDBC数据源接口配置JDBC连接对象的资源。

    1.UNPOOLED:为每一个数据库操作创建一个新的连接,并关闭它,该方式只适用于只有小规模数量并发用户的简单应用程序上。

    2.POOLED:创建一个数据库连接池,池中的一个连接将会被用作数据库操作,一旦完成,会将此连接返回给连接池,经常使用此种方式。

    3.JNDI:从在应用服务器配置好的JNDI数据源datasource获取数据库连接,在生产环境中,优先考虑此方式。

5.mapper元素:映射器,用来定义SQL的映射语句,只需告诉MyBatis去哪里找这个SQL语句,

  (1)使用类资源路径获取资源。

    <mappers>

      <mapper resource="cn/smbms/dao/user/UserMapper.xml" />

    </mappers>

  (2)使用URL获取资源。

    <mappers>

      <mapper url="file:///E:/sqlmappers/UserMapper.xml" />

    </mappers>

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/59184.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java—数据类型

文章目录数据类型八大基本数据类型Java中有了基本数据类型&#xff0c;为什么还要包装类型String字符串类型函数字符串类的length()方式是否能够得到字符串内有多少个字符&#xff1f;不可变字符串String为什么要设计成不可变的&#xff1f;boolean类型占多少位&#xff1f;为什…

【springboot进阶】使用aop + 注解方式,简单实现spring cache功能

目录 一、实现思路 二、定义缓存注解 三、aop 切面处理 四、使用方式 五、灵活的运用 六、总结 前几天有同学看了 SpringBoot整合RedisTemplate配置多个redis库 这篇文章&#xff0c;提问spring cache 能不能也动态配置多个redis库。介于笔者没怎么接触过&#xff0c;所以…

【Java开发】 Spring 08 :访问 Web 资源( 借助 RestTemplate or WebClient )

web 资源就是运行在服务器上的资源&#xff0c;比如放到 web 下的页面 js 文件、图片、css等&#xff0c;web资源分为静态web资源和动态web资源两类&#xff0c;接下来访问的就是动态资源&#xff08;页面返回的数据是动态的&#xff0c;由后端程序产生&#xff09;&#xff0…

Android 使用元数据

Android 使用元数据 前提介绍Metadata 有时候为安全起见&#xff0c;某个参数要给某个活动专用&#xff0c;并不希望其他活动也能获取该参数&#xff0c;也就是要使用第三方SDK时。Activity提供了元数据&#xff08;Metadata&#xff09;的概念&#xff0c;元数据是一种描述其…

C++类和对象(二)构造函数、析构函数、拷贝构造函数

目录 1.类的6个默认成员函数 2. 构造函数 2.1 概念 2.2 特性 3.析构函数 3.1 概念 3.2 特性 4. 拷贝构造函数 4.1 概念 4.2 特征 1.类的6个默认成员函数 如果一个类中什么成员都没有&#xff0c;简称为空类。 空类中真的什么都没有吗&#xff1f;并不是&#xff0c;…

【菜菜的sklearn课堂笔记】聚类算法Kmeans-聚类算法的模型评估指标

视频作者&#xff1a;菜菜TsaiTsai 链接&#xff1a;【技术干货】菜菜的机器学习sklearn【全85集】Python进阶_哔哩哔哩_bilibili 可以只看轮廓系数和卡林斯基-哈拉巴斯指数 不同于分类模型和回归&#xff0c;聚类算法的模型评估不是一件简单的事。在分类中&#xff0c;有直接结…

【尚硅谷】Java数据结构与算法笔记02 - 队列

文章目录一、使用场景二、队列介绍三、数组模拟队列3.1 思路分析3.2 Java代码实现3.3 问题分析与优化四、数组模拟环形队列4.1 思路分析4.2 Java代码实现一、使用场景 银行排队&#xff0c;先到先得测核酸&#xff0c;先到先测 二、队列介绍 队列是一个有序列表, 可以用数组…

硬盘压缩将C盘拓展成D盘和E盘

硬盘压缩将C盘拓展成D盘和E盘1. 现状2. 硬盘压缩2.1 进入计算机管理2.2 磁盘管理压缩卷3. 分配新盘符3.1 查看盘符是否被占用3.2 新建D盘刚安装好系统的电脑有可能只有一个C盘&#xff0c;我们工作学习的时候远远不够&#xff0c;那怎么拓展其他盘符呢&#xff1f; 接下来让我们…

PyQt5基础练习1

0. 本文学习地址 1. PyQt5是由一系列Python模块组成 超过620个类&#xff0c;6000函数和方法。能在诸如Unix、Windows和Mac OS等主流操作系统上运行。 1.1 PyQt5有两种证书 GPL商业证书 2. 实验1 实现简单的窗体 2.1 完整代码 #!/usr/bin/python3 # -*- coding: utf-8 -*…

专业尖端远心光学,高精度视觉检测解决者

随着机器视觉系统在精密检测领域的广泛应用&#xff0c;在精密光学测量系统中&#xff0c;由于普通光学镜头会存在一定的制约因素&#xff0c;如影像的变形、视角选择而造成的误差、不适当光源干扰下造成边界的不确定性等问题&#xff0c;进而影响测量的精度。为弥补普通镜头应…

155. RESTframe的请求和响应

1.请求和响应 REST framework引入了2个新的对象&#xff1a;Request和Response 1.1 Request 包结构&#xff1a;rest_framework.request.Request 该对象扩展了常规的HttpRequest &#xff0c;增加了对REST框架灵活的请求解析和请求认证的支持 主要属性&#xff1a; data 这个…

基于PHP+MySQL毕业生档案管理系统

毕业生档案管理系统是信息时代的产物&#xff0c;它是学校档案管理部门的一个好帮手。有了它不再需要繁重的纸质登记&#xff0c;有了它档案管理员不在需要繁重的工作&#xff0c;一些成绩信息和奖惩等基本信息可以由管理人员及时的对信息进行查询、更新、修改和删除&#xff0…

SpringBoot_启动原理分析

一共分为三部分来解析: 一 依赖导入原理 二 springboot 包扫描原理三 springboot自动配置原理一 依赖导入原理 父项目进行版本控制 ctrl 点击spring-boot-starter-parent 进入 继续点击,进入spring-boot-dependencies 这里管理着springboot中所有依赖的版本,版本…

38 | Linux 磁盘空间异常爆满

1 场景 收到告警 找到对应的服务器&#xff1a;df -hl 要找到导致磁盘空间满的目录或文件。 2 找占用空间大的目录或文件 2.1方式一 在根目录下&#xff0c;通过du -hs命令&#xff0c;列出各目录所占空间大小 命令&#xff1a;du -hs * 之后再用同样的方法继续到对应目…

[附源码]计算机毕业设计springboot医学图像管理平台

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

EXSI-NFS实验

A-EXSI-NFS实验 2022年3月25日 8:20 iptables -F iptables-save systemctl stop firewalld #setenforce [0|1]命令修改SELinux当前的运行模式&#xff08;0为禁用&#xff0c;1为启用&#xff09; getenforce Enforcing setenforce 0 getenforce Permissive NFS 两台CentOS 7即…

【车载开发系列】UDS诊断---读取内存($0x23)

【车载开发系列】UDS诊断—读取内存&#xff08;$0x23&#xff09; UDS诊断---读取内存&#xff08;$0x23&#xff09;【车载开发系列】UDS诊断---读取内存&#xff08;$0x23&#xff09;一.概念定义二.注意事项三.报文格式1&#xff09;报文请求2&#xff09;肯定响应3&#x…

一、Node.js 环境安装 (详)

1. 下载Node.js 首先进入node.js官网&#xff0c;选择下载这一项&#xff0c;此时映入眼帘的可以看到有两项LTS(长期维护版本)和Current(最新的版本)&#xff0c;一般在开发会选择左边进行下载安装&#xff0c;具稳定性以及有长期维护。那么下面演示的是64位的Windows操作系统&…

PCI bar 解析

只要是接入系统的 pci 设备就需要和系统软件进行交互&#xff0c;设备和系统之间的交流主要包含以下两部分&#xff1a; 1&#xff0c;系统要能访问到设备的寄存器 用于控制设备行为&#xff0c;包括DMA&#xff0c;数据收发等&#xff1b;设备通过寄存器报告自身的状态&…

Nginx部署vue项目和配置代理

Nginx部署vue项目和配置代理目录概述需求&#xff1a;实现思路分析1.一般前后端分离的项目需要进行跨域2.微服务代理3.vuenginx实现服务端跨域4.网页解析器参考资料和推荐阅读Survive by day and develop by night. talk for import biz , show your perfect code,full busy&am…