MyBatis核心配置文件:解锁数据之美的密码

MyBatis,这位编程的诗人,通过其独特的核心配置文件,为我们描绘出一幅数据之美的画卷。本篇博客将带你深入探讨MyBatis核心配置文件的奥秘,让你能够更好地理解和运用这个优雅的数据持久化框架。

最近想搞私域,欢迎各位大佬光临😀😀😀!

在这里插入图片描述

踏入奇妙的数据之美

首先,让我们一起踏入MyBatis的奇妙世界。在这个世界中,数据不再是冰冷的存储单元,而是充满艺术和灵感的精灵。而MyBatis的核心配置文件,就如同这个精灵的指南,引领我们探索数据之美的深邃奥秘。

创建MyBatis配置文件

MyBatis的核心配置文件通常被命名为mybatis-config.xml,是MyBatis的启动文件,负责整体引导。让我们一起来创建这个神奇的配置文件。

<!-- mybatis-config.xml -->
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><!-- 配置数据源 --><environments default="development"><environment id="development"><transactionManager type="JDBC" /><dataSource type="POOLED"><property name="driver" value="com.mysql.cj.jdbc.Driver" /><property name="url" value="jdbc:mysql://localhost:3306/mybatis_example" /><property name="username" value="your_username" /><property name="password" value="your_password" /></dataSource></environment></environments><!-- 配置Mapper映射文件 --><mappers><mapper resource="mapper/UserMapper.xml" /></mappers>
</configuration>

这段配置文件中,我们完成了两项主要配置:配置数据源和配置Mapper映射文件。下面,让我们逐步深入了解这些配置的细节。

数据源的魔法

在MyBatis的世界里,environments元素用于配置数据源,而数据源是连接数据库的魔法之钥。一个environment代表一个数据库环境,里面包含了一个事务管理器和一个数据源。

<environments default="development"><environment id="development"><transactionManager type="JDBC" /><dataSource type="POOLED"><property name="driver" value="com.mysql.cj.jdbc.Driver" /><property name="url" value="jdbc:mysql://localhost:3306/mybatis_example" /><property name="username" value="your_username" /><property name="password" value="your_password" /></dataSource></environment>
</environments>
  • default="development":指定默认使用的环境,这里是development
  • <transactionManager type="JDBC" />:配置事务管理器的类型,这里使用JDBC事务管理器。
  • <dataSource type="POOLED">:配置数据源的类型,这里使用POOLED数据源,即连接池。
  • 数据库连接信息:<property>元素用于配置数据库连接信息,包括驱动、URL、用户名和密码。

通过这样的配置,我们为MyBatis打开了连接数据库的大门,让数据之美的奇妙旅程开始。

Mapper映射文件的魔法笔触

在MyBatis的世界中,mappers元素用于配置Mapper映射文件。Mapper映射文件是MyBatis中最为重要的配置之一,其中包含了与SQL语句的咒语,通过这些咒语,我们能够操控数据库的灵魂。

<mappers><mapper resource="mapper/UserMapper.xml" />
</mappers>

这里通过<mapper>元素引入了UserMapper.xml文件,这个文件中包含了与User实体类相关的SQL语句。接下来,我们一起进入这个神秘的映射文件。

编写Mapper映射文件:UserMapper.xml

在这个映射文件中,我们将定义一些神奇的咒语,以及与User实体类相关的SQL语句。

<!-- mapper/UserMapper.xml -->
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.mapper.UserMapper"><resultMap id="UserResultMap" type="com.example.model.User"><id property="id" column="id" /><result property="username" column="username" /><result property="password" column="password" /></resultMap><select id="getUserById" resultMap="UserResultMap">SELECT * FROM user WHERE id = #{id}</select><!-- 其他SQL语句可以继续在此添加 -->
</mapper>

在这个文件中,我们定义了一个命名空间com.example.mapper.UserMapper,并且配置了一个resultMap用于映射查询结果到User实体类。接着,我们编写了一个简单的SELECT语句,通过id查询用户信息。这里的resultMap指定了如何将数据库查询结果映射到User对象,其中id表示主键,property表示Java对象的属性,column表示数据库表的列名。

通过这个Mapper映射文件,我们向MyBatis传达了“通过用户ID获取用户信息”的咒语,为数据之美的呈现创造了条件。

Java中的奇迹:创建SqlSessionFactory

在Java代码中,我们需要通过SqlSessionFactory来启动MyBatis,这个对象是MyBatis的核心工厂,负责创建SqlSession对象。

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;
import java.io.InputStream;public class MyBatisMagic {public static void main(String[] args) {// 读取MyBatis配置文件String resource = "mybatis-config.xml";try (InputStream inputStream = Resources.getResourceAsStream(resource)) {// 创建SqlSessionFactorySqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);// 创建SqlSessiontry (SqlSession sqlSession = sqlSessionFactory.openSession()) {// 执行SQL语句User user = sqlSession.selectOne("com.example.mapper.UserMapper.getUserById", 1);// 打印查询结果System.out.println("User ID: " + user.getId());System.out.println("Username: " + user.getUsername());System.out.println("Password: " + user.getPassword());}} catch (IOException e) {e.printStackTrace();}}
}

这段Java代码演示了如何使用MyBatis。通过SqlSessionFactoryBuilder从配置文件创建SqlSessionFactory,然后通过SqlSessionFactory创建SqlSession。最后,我们执行了一个查询并输出了结果。

Type Aliases:类型的名字是什么?

在MyBatis的配置文件中,可以通过typeAliases元素为Java类型指定别名。这个功能类似于给Java类取个昵称,使得在配置文件中使用起来更加方便。

<typeAliases><typeAlias alias="User" type="com.example.model.User" />
</typeAliases>

这段配置为com.example.model.User这个类指定了别名为User。这样,在后续的配置或映射文件中,可以使用User代替完整的类名,使得配置文件更加简洁易读。

Settings:全局配置的魔法

settings元素用于配置MyBatis的全局行为。这里可以设置各种属性,影响MyBatis的整体运行。

<settings><setting name="cacheEnabled" value="true" /><setting name="lazyLoadingEnabled" value="true" /><!-- 更多全局配置项可以继续添加 -->
</settings>

上述配置启用了MyBatis的缓存和懒加载。通过适当地配置settings,可以根据项目需求定制MyBatis的行为。

Environments and Database Connection:数据库连接的奇妙之旅

environments元素用于配置MyBatis的运行环境,包括事务管理器和数据源。在一个环境中,可以配置多个数据源和事务管理器的选择。

<environments default="development"><environment id="development"><transactionManager type="JDBC" /><dataSource type="POOLED"><property name="driver" value="com.mysql.cj.jdbc.Driver" /><property name="url" value="jdbc:mysql://localhost:3306/mybatis_example" /><property name="username" value="your_username" /><property name="password" value="your_password" /></dataSource></environment>
</environments>

上述配置中,我们使用了JDBC事务管理器和POOLED数据源。通过适当的配置,可以连接不同的数据库和使用不同的事务管理器。

Type Handlers:Java类型和数据库类型的魔法桥梁

typeHandlers元素用于配置MyBatis的类型处理器,这些处理器负责Java类型和数据库类型之间的映射关系。通过配置typeHandlers,我们可以为特定的Java类型指定自定义的类型处理器。

<typeHandlers><typeHandler handler="com.example.handlers.CustomTypeHandler" />
</typeHandlers>

上述配置中,我们指定了一个自定义的类型处理器com.example.handlers.CustomTypeHandler。类型处理器在处理数据库和Java类型映射时发挥着重要作用,允许我们根据需求选择合适的处理器。

Plugins:插件的魔法

MyBatis的插件系统允许我们在SQL语句执行的过程中插入自定义的逻辑,从而对MyBatis的行为进行增强。插件可以拦截方法的执行,修改SQL语句,甚至完全替代原始的方法。

<plugins><plugin interceptor="com.example.plugins.CustomInterceptor"><property name="pluginProperty" value="pluginValue" /></plugin>
</plugins>

上述配置中,我们配置了一个自定义的插件com.example.plugins.CustomInterceptor。插件为MyBatis提供了灵活的扩展性,允许我们在MyBatis的运行过程中插入自定义的逻辑,实现更加强大的功能。

窥探全局配置的奥秘

MyBatis的全局配置文件是数据之美的密码,通过巧妙的配置,我们可以引导MyBatis的行为,让它按照我们的意愿工作。在这篇博客中,我们深入了解了MyBatis核心配置文件的一些重要元素,包括数据源的配置、Mapper映射文件的编写、Java代码中的使用,以及一些全局配置的技巧。

MyBatis的核心配置文件不再是冰冷的配置项,而是编程的艺术。通过简单的配置,我们为MyBatis打开了数据之美的大门,让它为我们展示出最优雅的数据操作方式。希望通过这篇博客,你能更好地理解MyBatis核心配置文件的奥秘,将其应用到实际项目中,创造出属于你的数据之美。这是一场关于数据和艺术的奇妙之旅,让我们一起踏入这片神秘的领域。

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Docker与containerd:容器技术的双璧

&#x1f407;明明跟你说过&#xff1a;个人主页 &#x1f3c5;个人专栏&#xff1a;《Docker幻想曲&#xff1a;从零开始&#xff0c;征服容器宇宙》 &#x1f3c5; &#x1f516;行路有良友&#xff0c;便是天堂&#x1f516; 目录 一、前言 1、Docker和containerd的背景…

PyTorch 深度学习(GPT 重译)(五)

十二、通过指标和增强改进训练 本章涵盖 定义和计算精确率、召回率以及真/假阳性/阴性 使用 F1 分数与其他质量指标 平衡和增强数据以减少过拟合 使用 TensorBoard 绘制质量指标图 上一章的结束让我们陷入了困境。虽然我们能够将深度学习项目的机制放置好&#xff0c;但实…

Hive SQL必刷练习题:日期交叉问题(两种思路)

思路一&#xff1a; ​ 首先想到的是借助炸裂函数&#xff0c;一行变成多行&#xff0c;就可以进行去重操作&#xff0c;然后再统计日期。 用到炸裂函数&#xff0c;就首先需要可以拿到起始和终止日期差大小的数组&#xff0c;然后再炸裂​ 那这个指定长度数组怎么获取呢&…

sentry-cli - error: Failed to load .sentryclirc file from project path

Xcode 15.2 warning sentry-cli - error: Failed to load .sentryclirc file from project path (/Users/zhuhongwei/Desktop/pandabill/.sentryclirc)推荐一下刚上线的 App 熊猫小账本&#xff0c;里面有用到这篇博客讲的内容 熊猫小账本 一个简洁的记账 App&#xff0c;用于…

文件IO(代码案例: 文件复制, 指定目录查找文件, 指定目录查找内容)

文件复制 进行普通文件的复制 使用操作字节流的对象操作文件 // 文件复制 public class Main {public static void main(String[] args) throws IOException {// 输入两个路径, 源路径, 目的路径Scanner scanner new Scanner(System.in);System.out.println("请输入拷贝文…

将OpenCV与gcc和CMake结合使用

返回&#xff1a;OpenCV系列文章目录&#xff08;持续更新中......&#xff09; 上一篇&#xff1a;OpenCV4.9.0开源计算机视觉库在 Linux 中安装 下一篇&#xff1a; 引言&#xff1a; 近年来&#xff0c;计算机视觉技术在图像处理、目标检测和机器人等方面得到了广泛的应用…

Centos7部署使用TELEMAC-MASCARET

Background TELEMAC-MASCARET是一款研究水动力学和水文学领域的高性能数值仿真开源软件。MASCARET&#xff08;1980&#xff09;和 TELEMAC&#xff08;1987&#xff09;最初是由法电集团所属的法国国立水利与环境实验室开发&#xff0c;随后整合为TELEMAC-MASCARET并由法英德三…

简单了解多线程

并发和并行 并发&#xff1a; 在同一时刻&#xff0c;多个指令在单一CPU上交替指向 并行&#xff1a;在同一时刻&#xff0c;多个指令在多个CPU上同时执行 2核4线程&#xff0c;4核8线程&#xff0c;8核16线程&#xff0c;16核32线程 基础实现线程的方式 Thread :继承类 &…

UE5.3 StateTree使用实践

近期浏览UE的CitySample&#xff08;黑客帝国Demo&#xff09;&#xff0c;发现有不少逻辑用到了StateTree学习一下&#xff0c;StateTree是多层状态机实现&#xff0c;以组件的形式直接挂载在蓝图中运行。 与平时常见的一些FSM库不同&#xff0c;StateTree并不会返回给外界当…

软件工程-第9章 软件工程项目管理概述

9.1 软件工程管理活动 9.2 软件规模、成本和进度估算 9.3 能力成熟度模型CMM 9.4 ISO 9000系列标准简介 9.5 CMM与ISO 9000系列标准的比较 9.6 本章小结

【MySQL】学习和总结使用列子查询查询员工工资信息

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-5odctDvQ0AHJJc1C {font-family:"trebuchet ms",verdana,arial,sans-serif;font-siz…

[保姆级教程]Windows安装MongoDB教程

文章目录 MongoDB安装包下载1.点击进入mongodb官网2.点击MongoDB Community Edition&#xff08;社区版&#xff09;&#xff0c;进入下图界面3.选择版本4.下载5.安装6.勾选同意协议&#xff0c;点击“Next"7.选择自定义安装8.点击“Next"9.修改到合适的地址10.点击i…

Java SE入门及基础(44)

目录 I / O流(上) 1. 什么是I / O流 过程分析 I / O的来源 Java 中的 I / O流 2. 字节流 OutputStream 常用方法 文件输出流 FileOutputStream 构造方法 示例 InputStream 常用方法 文件输入流 FileInputStream 构造方法 示例 综合练习 字节流应用场景 Java SE文…

FREERTOS空闲任务和低功耗

空闲任务 空闲任务是 FreeRTOS 必不可少的一个任务&#xff0c;其他 RTOS 类系统也有空闲任务&#xff0c;比如uC/OS。看名字就知道&#xff0c;空闲任务是处理器空闲的时候去运行的一个任务&#xff0c;当系统中没有其他就绪任务的时候空闲任务就会开始运行&#xff0c;空闲任…

腾讯春招后端一面(算法篇)

前言&#xff1a; 哈喽大家好&#xff0c;前段时间在小红书和牛客上发了面试的经验贴&#xff0c;很多同学留言问算法的具体解法&#xff0c;今天就详细写个帖子回复大家。 因为csdn是写的比较详细&#xff0c;所以更新比较慢&#xff0c;大家见谅~~ 就题目而言&#xff0c;…

Cache缓存:HTTP缓存策略解析

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

基于CNN多阶段图像超分+去噪(超级简单版)

这是之前的一项工作&#xff0c;非常简单&#xff0c;简单的复现了两个算法&#xff0c;然后把它们串起来了。 可执行的程序链接&#xff1a;CSDN; Github 我们分成两部分进行讲解&#xff1a; 1. 图像去噪 1.1 基本思路 图像的去噪工作基于很普通的CNN去噪&#xff0c;效…

Django分页器

Django分页器 分页器前瞻之url urls.py不需要做修改 urlpatterns [path(test/, views.test,nametest), ]假设此时在原有的路径http://127.0.0.1:8000/app01/test后面添加/?page2 然后再后端获取到page def test(request):page request.GET.get(page)print(page) # 2retu…

【二分查找】算法例题

目录 十八、二分查找 114. 搜索插入位置 ① √- 115. 搜索二维矩阵 ② 116. 寻找峰值 ② √- 117. 搜索旋转排序数组 ② 118. 在排序数组中查找元素的第一个和最后一个位置 ② √ 119. 寻找寻钻排序数组中的最小值 ② 120. 寻找两个正序数组的中位数 ③ 136. 直线上最多…

在react中使用tailwindcss

安装tailwind css npm i -D tailwindcssnpm:tailwindcss/postcss7-compat postcss^7 autoprefixer^9安装 CRACO 由于 Create React App 不能让您覆盖原生的 PostCSS 配置&#xff0c;所以我们还需要安装 CRACO 才能配置 Tailwind。 npm install craco/craco配置CRACO 在项目根…