JavaEE——MyBatis配置文件的详细介绍

news2024/11/17 9:33:28

简单介绍:

需要我们编写的配置文件主要有三个,分别是核心配置文件(mybatis-config.xml),数据库连接信息文件(db.properties),SQL语句映射文件(Mappers);这些配置文件大多数都是以xml文件的形式进行编写的,所以其中包含了很多的标签,也称为他们的元素,之前我们只是从官网复制这些文件的模板文件并进行简单的修改进行使用,并不知道这些文件的中的元素的具体含义,那么接下来就是对这些文件中出现过的那些元素进行比较详细的讲解。

数据库连接信息文件db.propertioes文件:

这个文件存放的是关于数据库连接相关的信息,其中常用的有driver,url,username,password的配置信息,如果之前配置过数据库连接池,会发现这个配置文件在数据库连接池中也出现过。

这种以propertioes文件结尾的文件的数据存储形式是以键值对的形式存放,是以键等于值的形式存储。所以当我们在其他的文件中引用这种文件的时候只需要在需要值的地方动态的引用她的键就可以,非常的方便维护和修改。

下面是正常的简单配置数据库连接信息的文件:

核心配置文件mybatis-config.xml:

mybatis的核心配置文件配置了mybatis的全局信息,以及能够修改默认行为的属性。

mybatis的核心配置文件的主要元素如下:

其中<configuration>元素是所有元素的根元素,所有的元素都要写在它下面。并且这些元素的顺序不能乱写,一定要根据上面的顺序从上到下开始编写,否则在编写配置文件的时候会报错:

不过也不同特意的去记住这些元素的顺序,在我们报错之后,他会提醒我们正确的顺序并且告诉我们是哪一个元素的位置错了,我们只需要对照修改就可以了。

接下来我们就比较详细的介绍一下这些每一个元素:

<properties>:

该元素的作用是将外部的配置文件引入到此配置文件中。

比如我们的数据库连接信息文件都是存放在db.properties文件中,我们就可以使用这个元素引入这个文件,然后在需要db.properties文件中信息的地方使用动态引入的方式。

 动态引入的语法为:${key}

<settings>:

这个元素的作用是改变MyBatis运行时候的行为,比如开启二级缓存,开启延时加载,懒加载等。

关于这个标签的作用我们在之后学习过缓存机制和懒加载机制之后再深入了解这个标签的作用

<typeAliases>:别名映射

在我们将查询结果集输出到一个Java的实体类的时候,需要在resultType中输入实体类的全限定类名,即必须写入完整的包名和类名,但是在我们的开发中,有一些包名就非常的长,写起来很麻烦而且也很容易就写错。这个标签的作用就是帮我们简化这个写法,在配置完成之后,我们就可以简化为直接写实体类的类名的方式就可以了。

当我们映射的实体类有多个的时候,可以配置多个标签来达到效果:

当我们映射的实体类非常多的时候,一个一个的写就非常的麻烦,这时候我们就可以以包扫描器的方式来添加我们的别名映射:

 

当我们进行这样的配置之后,当我们需要这个包下面的实体类进行映射的时候,都可以直接写类名就可以进行自动映射 

<typeHandlers>:

<objectFacetory>:

<plugins>:

<environments>:

MyBatis支持配置多套运行环境,比如开发环境,生产环境,测试环境等;可以灵活的选择不同的配置,从而将SQL映射到不同运行环境的数据库中。

        <enbironment>

不同的运行环境可以通过<environment>子元素来配置,但是不管有多少套运行环境,都必须要明确选择出当钱要用的唯一的一个运行环境。

MyBatis的运行环境信息包括事务管理器和数据源。通过<environment>的两个子元素,<transactionManger>来配置运行环境的事务管理器,<dataSource>元素用来配置环境的数据源信息。

                <transactionManager>:

<transactionManger>来配置运行环境的事务管理器,可以配置两种类型的事务管理器,其中一种是JDBC:直接使用JDBC的提交和回滚设置,依赖于从数据源得到的连接来管理事务的作用域。还有一种是MANAGED:此配置不提交或回滚一个链接,而是让容器来管理事务的整个生命周期。

如果项目使用的是Spring+MyBatis,则没有必要在MyBatis中配置事务管理器,因为在实际开发中会使用Spring自带的管理器来实现事务的管理。

                <dataScurce>:

<dataSource>元素用来配置环境的数据源信息。对于数据源的配置,MyBatis提供了三种数据源类型,分别是:

UNPOOLED:表示数据源为无连接池类型。适用于对性能要求不高的简单应用程序

POOLED:表示数据源为连接池属性。POOLED使并发Web应用可以快速响应请求,是当前比较流行的数据源配置类型。

JNDI:表示数据源可以在FJB或应用服务器容器中使用。

切换运行环境的方法:

一种是通过更改<environments>的default属性的值的方式来切换运行那一套环境

还有一种就是在编程的时候,将SqlSessionFactoryBuilder()方法的第二个参数修改成运行环境id的值的方式来切换运行环境:

<mappers>:引入映射文件

在MyBatis的核心配置文件中,<mappers>用于引入MyBatis映射文件。映射文件包含了POJO对象和数据表之前的映射关系,MyBatis通过核心配置文件中的<mappers>元素找到映射文件并解析其中的映射关系

 使用<mappers>引入映射文件的方式有四种:

1.使用类路径引入:

2.使用本地文件路径引入:

3.使用接口类引入:

使用接口类引入需要提前准备一个和映射文件同一个包下面的接口,并且接口名必须与文件名相同,且接口中的方法名与映射文件中的唯一标识的名字相同,在下一章的接口化开发中会详细的介绍这种方法的使用:

 4.使用包名导入

 

SQL语句映射文件:

MyBatis真正强大的地方是可以配置SQL映射文件。

SQL语句映射文件的常用元素:

<mappers>:

mappers元素是映射文件的根元素,其他元素都是她的子元素。mappers有一个属性叫做namespace,类似于我们的包,是用来当SQL映射的id属性相同时区分SQL映射的。

<cache>:

配置给定命名空间的缓存

<chache-ref>:

从其他命名空间引用缓存配置

<select>:

用于映射查询语句,它可以从数据库中查询数据并返回。它有四个常用的属性,idSQL语句的唯一标识,parametType表示参数的类型,resultType表示查询结果集映射到的POJO实体类的全限定类型,如果之前配置了类名映射,可以直接写类名。

 

<insert>:

<insert>用于映射插入语句,在执行完<insert>元素中定义的SQL语句后,会返回插入记录的数量。该元素有两个常用属性,id表示SQL语句的唯一标识,parameterType表示数据来源的POJO实体类。

注意在使用的时候,插入数据的时候要使用动态引入的方式,因为数据来源是来自于POJO的实体类,所以要动态的引入实体类中的属性的名称

<update>:

<update>用于映射更新语句,它可以更新数据库中的数据,在执行完元素中定义的SQL语句之后,会返回更新的记录数量。

<delete>:

<delete>用来映射删除语句,在执行完<delete>元素中的SQL语句之后,会返回删除的记录数量。

还有<sql>和<resultMap>属性由于比较的常用和重要我们在下一章节进行单独的讲解 

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

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

相关文章

蒙特卡洛方法

蒙特卡洛方法 理解&#xff1a;是一种利用大量样本与样本中正确数量形成的概率去逼近真实值的一种方法。 可以很巧妙的求取某些问题&#xff1a;如 π 的值 1、利用蒙特卡洛方法求π 我们知道圆的面积公式是&#xff1a;π * r * r 那么 1 / 4 圆的面积就是 1/ 4 *π * r …

Spring Data JPA关于懒加载的那些事

背景 环境 相关环境配置&#xff1a; SpringBootPostGreSQL Spring Data JPA 懒加载现象 首先声明一下 application.yml 文件中关于 JPA 的配置&#xff1a; spring:jpa:show-sql: truehibernate:ddl-auto: noneopen-in-view: falseproperties:hibernate:order_by:defaul…

「6」线性代数(期末复习)

&#x1f680;&#x1f680;&#x1f680;大家觉不错的话&#xff0c;就恳求大家点点关注&#xff0c;点点小爱心&#xff0c;指点指点&#x1f680;&#x1f680;&#x1f680; 目录 第五章 相似矩阵及二次型 &2&#xff09;方阵的特征值与特征向量 &3&#xff…

从transformers开始,哪些工作可以被看成是自然语言处理里程碑式的突破。

文本生成的含义是在某一语言数据基础上对语言的从前到后&#xff08;自监督本身下行目标&#xff09;、两段对齐语言序列&#xff08;相互之间的文本共性矩阵计算&#xff09;分布的研究实现路线。简而言之如何以具有可微可导的向量去寻找攻关语言分布的能力即为当代信息科学与…

Springcloud 集成 Seata1.5.2

一、关于seata1.5.2的安装部署请参考&#xff1a; Seata1.5.2安装配置部署_不知道取啥昵称的博客-CSDN博客 二、springcloud程序集成seata 我这里使用的alibaba-cloud版本为 2.2.6.RELEASE&#xff0c;其对应的seata版本为1.3.0&#xff0c;但是想使用seata1.5.2的版本&…

MongoDB-查找表里面重复的记录

一、背景 项目中使用的是mongodb数据库&#xff0c;在测试数据入库的时候&#xff0c;会根据源数据&#xff0c;然后生成一个自增的id到数据库里面&#xff0c;然后线上和测试环境针对同一条数据的id是不一致的。某些数据又只有id与线上匹配上的时候&#xff0c;才能关联上更多…

CentOS 7转化系统为阿里龙蜥Anolis OS 7

转载&#xff1a;原社区CentOS 7迁移Anolis OS 7迁移手册 一、注意事项 Anolis OS 7生态上和依赖管理上保持跟CentOS7.x兼容&#xff0c;一键式迁移脚本centos2anolis.py&#xff0c;实现CentOS7.x到Anolis OS 7的平滑迁移。 使用迁移脚本前需要注意如下事项&#xff1a; 迁…

Springboot扩展点之CommandLineRunner和ApplicationRunner

Springboot扩展点系列&#xff1a;Springboot扩展点之ApplicationContextInitializerSpringboot扩展点之BeanDefinitionRegistryPostProcessorSpringboot扩展点之BeanFactoryPostProcessorSpringboot扩展点之BeanPostProcessorSpringboot扩展点之InstantiationAwareBeanPostPro…

获取保存在本地的帐户密码,支持浏览器|数据库|邮件|无线|管理员等等

获取保存在本地的帐户密码&#xff0c;支持浏览器|数据库|邮件|无线|管理员等等。 #################### 免责声明&#xff1a;工具本身并无好坏&#xff0c;希望大家以遵守《网络安全法》相关法律为前提来使用该工具&#xff0c;支持研究学习&#xff0c;切勿用于非法犯罪活动…

使用 Nodejs、Express、Postgres、Docker 在 JavaScript 中构建一个 CRUD Rest API

让我们在 JavaScript 中创建一个 CRUD rest API&#xff0c;使用&#xff1a;节点.js表达续集Postgres码头工人码头工人组成介绍这是我们将要创建的应用程序架构的架构&#xff1a;我们将为基本的 CRUD 操作创建 5 个端点&#xff1a;创造阅读全部读一个更新删除我们将使用以下…

python自学之《21天学通Python》(11)——网络编程

第14章 网络编程 网络编程是现代编程主题中的一个重要组成部分&#xff0c;而Python在标准库中就已经提供了丰富的网络编程模块&#xff0c;以支持用户进行编写具有各种网络功能的程序或软件。在Python标准库中&#xff0c;支持底层网络编程的是socket模块&#xff1b;针对特定…

ilasm 和 ildasm编译和反编译工具介绍使用教程

目录前言一、使用 ildasm 反编译 dll 文件二、使用 ilasm 将il文件编译成 dll 或 exe 文件前言 文本讲述怎么通过 ildasm 工具将 dll 文件进行反编译为 il 文件&#xff0c;修改 il 文件后再如何通过 ilasm 工具将 il 文件反编译成 dll 或 exe 文件。 ildasm工具&#xff1a;…

【2023最火教程】5分钟学会接口自动化测试框架

今天&#xff0c;我们来聊聊接口自动化测试。 接口自动化测试是什么&#xff1f;如何开始&#xff1f;接口自动化测试框架如何搭建&#xff1f; 自动化测试 自动化测试&#xff0c;这几年行业内的热词&#xff0c;也是测试人员进阶的必备技能&#xff0c;更是软件测试未来发展…

【蓝桥杯集训5】递推专题(3 / 3)

目录 3777. 砖块 - 递推 1208. 翻硬币 - 递推 95. 费解的开关 - 递推 位运算 3777. 砖块 - 递推 3777. 砖块 - AcWing题库 题目&#xff1a; 思路&#xff1a; 要使所有砖块颜色一致&#xff0c;则要不全B&#xff0c;要不全W 则分情况讨论&#xff1a;全为白色和全为黑色…

MariaDB 成功敲钟上市 | 它与 Navciat 缘起 10 年前

MariaDB 敲钟上市2022 年底&#xff0c;云数据库公司 MariaDB 与 Angel Pond Holdings 公司完成合并&#xff0c;并在纽交所上市。新公司更名为 MariaDB&#xff0c;MySQL 之父奋斗了13年终敲钟。这标志着 MariaDB 开启新篇章。无论从开源还是商业之路&#xff0c;都将成为业内…

整理了十个Python自动化操作,拿走就用

01OS模块相关一、遍历文件夹 批量操作的前提就是对文件夹进行遍历&#xff0c;使用os模块可以轻松的遍历文件夹&#xff0c;os.walk 遍历后产生三个参数&#xff1a; 当前文件夹路径 包含文件夹名称[列表形式] 包含文件名称[列表形式] 代码如下&#xff0c;大家可以根据自己的…

SpringCloudAlibab-nacos

一、介绍注册中心配置中心的整合SpringCloudAlibaba中文地址&#xff1a;https://github.com/alibaba/spring-cloud-alibaba/blob/2.2.x/README-zh.md下载地址&#xff1a;https://github.com/alibaba/nacos/访问&#xff1a;http://localhost:8848/nacos/二、使用1、添加依赖&…

[大邻域算法](MD)VRPTW常见求解算法--代码解析

相关链接&#xff1a; 【路径分割】序列分隔和路径提取的案例【算法】LNS(大邻域算法)和ALNS(自适应大邻域算法)(持更)Python实现(MD)VRPTW常见求解算法——自适应大邻域搜索算法&#xff08;ALNS&#xff09;,本文也是该篇的解析干货 | 自适应大邻域搜索(Adaptive Large Neig…

【每日一题Day121】LC1139最大的以 1 为边界的正方形 | 前缀和数组 + 枚举

最大的以 1 为边界的正方形【LC1139】 给你一个由若干 0 和 1 组成的二维网格 grid&#xff0c;请你找出边界全部由 1 组成的最大 正方形 子网格&#xff0c;并返回该子网格中的元素数量。如果不存在&#xff0c;则返回 0。 写了50分钟写出来了 思路是对的 但就是不够清晰 并且…

ACPI on ARMv8 Servers

文章目录前言一、Why ACPI on ARM&#xff1f;二、Kernel Compatibility三、Relationship with Device Tree四、Booting using ACPI tables五、ACPI Detection六、Device Enumeration七、Driver Recommendations参考资料前言 ARM64处理器除了可以用设备树&#xff08;DT&#…