news 2026/5/26 0:59:14

Mybatis

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Mybatis

介绍

MyBatis是一款优秀的持久层框架

官网:MyBatis中文网

配置

创建springboot工程,并导入 mybatis的起步依赖、mysql的驱动包、lombok。

项目工程创建完成后,自动在pom.xml文件中,导入Mybatis依赖和MySQL驱动依赖。如下所示:

配置Mybatis

application.properties中配置数据库的连接信息。

#数据库访问的url地址 spring.datasource.url=jdbc:mysql://localhost:3306/web01?serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&useSSL=false&allowPublicKeyRetrieval=true #访问数据库-用户名 spring.datasource.username=root #访问数据库-密码 spring.datasource.password=root@1234 #非必须 #数据库驱动类类名 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

注:url地址中的/web01是Schema名称,根据自己的名字来

url后面跟的参数

参数作用
serverTimezone=Asia/Shanghai解决 MySQL 8 时区报错
useUnicode=true开启 Unicode
characterEncoding=utf-8防中文乱码
zeroDateTimeBehavior=convertToNull处理 0000-00-00
useSSL=false关闭 SSL 警告
allowPublicKeyRetrieval=trueMySQL 8 登录必需(无 SSL)

配置SQL提示

配置当前IDEA关联的MySQL数据库

配置Mybatis日志输出

默认情况下,在Mybatis中,SQL语句执行时,我们并看不到SQL语句的执行日志。 在application.properties加入如下配置,即可查看日志:

#mybatis的配置 mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

打开上述开关之后,就可以看到控制台输出的SQL语句是什么样子的。

Druid连接池(可选)

Druid连接池是阿里巴巴开源的数据库连接池项目,功能强大,性能优秀,是Java语言最好的数据库连接池之一

如果我们想把默认的数据库连接池切换为Druid数据库连接池,只需要完成以下两步操作即可:

参考官方地址:https://github.com/alibaba/druid/tree/master/druid-spring-boot-starter

①在pom.xml文件中引入依赖

<dependency> <!-- Druid连接池依赖 --> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.2.19</version> </dependency>

②在application.properties中引入数据库连接配置

#非必须 spring.datasource.type=com.alibaba.druid.pool.DruidDataSource spring.datasource.druid.driver-class-name=com.mysql.cj.jdbc.Driver #必须 spring.datasource.druid.url=jdbc:mysql://localhost:3306/web01?serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&useSSL=false&allowPublicKeyRetrieval=true spring.datasource.druid.username=root spring.datasource.druid.password=1234

配置完毕之后,会看到控制台输出的日志中,已经将连接池切换为了 Druid连接池。

XML映射配置

Mybatis的开发有两种方式:

  1. 注解

  2. XML

使用Mybatis的注解方式,主要是来完成一些简单的增删改查功能。如果需要实现复杂的SQL功能,建议使用XML来配置映射语句,也就是将SQL语句写在XML配置文件中。

在Mybatis中使用XML映射文件方式开发,需要符合一定的规范:

  1. XML映射文件的名称与Mapper接口名称一致,并且将XML映射文件和Mapper接口放置在相同包下(同包同名)

  2. XML映射文件的namespace属性为Mapper接口全限定名一致

  3. XML映射文件中sql语句的id与Mapper接口中的方法名一致,并保持返回类型一致。

创建XML映射文件

编写XML映射文件

xml映射文件中的dtd约束,固定格式(直接cv)

<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "https://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace=""> </mapper>
XML映射文件的namespace属性为Mapper接口全限定名
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "https://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.itheima.mapper.UserMapper"> </mapper>
XML映射文件中sql语句的id与Mapper接口中的方法名一致,并保持返回类型一致
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "https://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.itheima.mapper.EmpMapper"> <!--查询操作--> <select id="findAll" resultType="com.itheima.pojo.User"> select * from user </select> </mapper>

MybatisX

MybatisX是一款基于IDEA的快速开发Mybatis的插件

MybatisX的安装:

可以通过MybatisX快速定位:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/26 2:42:02

提升Maya创作效率的实用插件盘点

在影视动画、游戏制作等视觉创作领域&#xff0c;Maya始终以其扎实的基础功能占据标杆地位&#xff0c;成为行业从业者的必备工具。面对日益复杂的项目需求和紧张的交付周期&#xff0c;仅依靠软件原生功能往往难以实现高效创作。适配性强的Maya插件就成了提升效率的关键助力—…

作者头像 李华
网站建设 2026/5/26 4:35:05

终极指南:5分钟快速上手ArcGIS API for Python地理空间分析

想要轻松处理地图数据、进行地理编码和空间分析吗&#xff1f;&#x1f680; ArcGIS API for Python 是一个强大的地理空间数据处理库&#xff0c;专门为Python开发者设计。这个由Esri开发的库不仅支持深度学习、复杂的向量与栅格分析&#xff0c;还能与Jupyter Notebook完美配…

作者头像 李华
网站建设 2026/5/26 4:41:31

算法革新驱动AI训练效率革命:从技术原理到工程实践

算法革新驱动AI训练效率革命&#xff1a;从技术原理到工程实践 【免费下载链接】modded-nanogpt GPT-2 (124M) quality in 5B tokens 项目地址: https://gitcode.com/GitHub_Trending/mo/modded-nanogpt 在人工智能飞速发展的今天&#xff0c;训练效率已成为制约AI技术规…

作者头像 李华
网站建设 2026/5/25 7:33:19

无人直播资源合集(第二辑)

无人直播助眠项目 文件大小: -内容特色: 零人值守搭建助眠直播间&#xff0c;附脚本与工具包适用人群: 想副业创收或做无人直播的运营/自媒体人核心价值: 低成本挂机变现&#xff0c;24h持续流量与礼物收益下载链接: https://pan.quark.cn/s/0f7c3b56420e 【08052】抖音无人直…

作者头像 李华
网站建设 2026/5/26 4:40:00

终极方案:Expo蓝牙开发完整指南15分钟:从概念到生产部署

终极方案&#xff1a;Expo蓝牙开发完整指南15分钟&#xff1a;从概念到生产部署 【免费下载链接】expo An open-source platform for making universal native apps with React. Expo runs on Android, iOS, and the web. 项目地址: https://gitcode.com/GitHub_Trending/ex/…

作者头像 李华
网站建设 2026/5/26 0:28:17

3.10 Elasticsearch-结果可解释性:explain=true 与 Lucene explain 日志

3.10 Elasticsearch-结果可解释性&#xff1a;explaintrue 与 Lucene explain 日志 3.10.1 为什么需要“看得见”的打分 搜索排序一旦上线&#xff0c;业务方最常见的追问是&#xff1a;“为什么 A 排在 B 前面&#xff1f;” 如果没有量化依据&#xff0c;只能靠“BM25 公式…

作者头像 李华