Mybatis day 1020

news2024/10/21 13:27:04

ok了这周学习了mybatis框架,今天最后一天,加油各位!!!(接上文)

.MyBatis扩展

8.1 Mapper批量映射优化

需求

Mapper 配置文件很多时,在全局配置文件中一个一个注册太
麻烦,希望有一个办法能够一劳永逸。
配置方式
Mybatis 允许在指定 Mapper 映射文件时,只指定其所在的
包:
<mappers>
<package name="com.lzw.mapper"/>
</mappers>
此时这个包下的所有 Mapper 配置文件将被自动加载、注
册,比较方便。
资源创建要求
        
  • Mapper 接口和 Mapper 配置文件名称一致
    • Mapper 接口:EmployeeMapper.java
    • Mapper 配置文件:EmployeeMapper.xml
  • Mapper 配置文件放在 Mapper 接口所在的包内
    • 可以将mapperxml文件放在mapper接口所在的包!
    • 可以在sources下创建mapper接口包一致的文件夹结构存放mapperxml文件

8.2 分页插件PageHelper

8.2.1 PageHelper插件介绍
MyBatis 对插件进行了标准化的设计,并提供了一套可扩展的
插件机制。插件可以在用于语句执行过程中进行拦截,并允许
通过自定义处理程序来拦截和修改 SQL 语句、映射语句的结
果等。
PageHelper MyBatis 中比较著名的分页插件,它提供了多
种分页方式(例如 MySQL Oracle 分页方式),支持多种
数据库,并且使用非常简单。下面就介绍一下 PageHelper
使用方式。
8.2.2 PageHelper插件使用
  • pom.xml引入依赖
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.1.11</version>
</dependency>
  • mybatis-config.xml配置分页插件
<plugins>
<plugin
interceptor="com.github.pagehelper.PageIntercept
or">
<property name="helperDialect"
value="mysql"/>
</plugin>
</plugins>
其中, com.github.pagehelper.PageInterceptor
PageHelper 插件的名称, dialect 属性用于指定数据库类型
(支持多种数据库)
  • 分页插件使用
public interface EmployeeMapper {
//查询所有员工信息
public List<Employee> findAll();
}
<?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.lzw.mapper.EmployeeMapper">
<select id="findAll" resultType="Employee">
select * from t_emp
</select>
</mapper>
@Test
public void testDemo(){
//使用工具类获取SqlSession对象
SqlSession sqlSession =
SqlSessionUtil.openSession();
//基于接口获取实现类对象(代理对象)
EmployeeMapper employeeMapper =
sqlSession.getMapper(EmployeeMapper.class);
//通过多态调用方法
//开启分页查询,但是分页更丰富的功能并非来自于它
PageHelper.startPage(3,3);
List<Employee> employeeList =
employeeMapper.findAll();
PageInfo<Employee> pageInfo=new
PageInfo<>(employeeList,3);
System.out.println("当前
页:"+pageInfo.getPageNum());
System.out.println("每页的数
量:"+pageInfo.getPageSize());
System.out.println("总页
数:"+pageInfo.getPages());
System.out.println("总条
数:"+pageInfo.getTotal());
System.out.println("是否为第一
页:"+pageInfo.isIsFirstPage());
System.out.println("是否为最后一
页"+pageInfo.isIsLastPage());
System.out.println("上一
页:"+pageInfo.getPrePage());
System.out.println("下一
页:"+pageInfo.getNextPage());
//导航条上页码的数量
System.out.println("导航页码
数:"+pageInfo.getNavigatePages());
System.out.println("==================");
//导航条上具体的页码
int[] nums =
pageInfo.getNavigatepageNums();
for (int num : nums) {
System.out.print(num+"\t");
}
System.out.println("");
//释放资源
sqlSession.close();
}

8.3 ORM介绍

8.3.1 ORM思维介绍
ORM Object-Relational Mapping ,对象 - 关系映射)是一种
将数据库和面向对象编程语言中的对象之间进行转换的技术。
它将对象和关系数据库的概念进行映射,通过一系列的操作将
对象关联到数据表中的一行或多行上。
让我们可以使用面向对象思维进行数据库操作!!
8.3.2 ORM 框架通常有半自动和全自动两种方式
  • 半自动 ORM 通常需要程序员手动编写 SQL 语句或者配置
    文件,将实体类和数据表进行映射,还需要手动将查询的
    结果集转换成实体对象。
  • 全自动 ORM 则是将实体类和数据表进行自动映射,使用
    API 进行数据库操作时, ORM 框架会自动执行 SQL 语句并
    将查询结果转换成实体对象,程序员无需再手动编写 SQL
    语句和转换代码。
8.3.3 半自动和全自动 ORM 框架的区别
映射方式:半自动 ORM 框架需要程序员手动指定实体类
和数据表之间的映射关系,通常使用 XML 文件或注解方式
来指定;全自动 ORM 框架则可以自动进行实体类和数据
表的映射,无需手动干预。
查询方式:半自动 ORM 框架通常需要程序员手动编写
SQL 语句并将查询结果集转换成实体对象;全自动 ORM
框架可以自动组装 SQL 语句、执行查询操作,并将查询结
果转换成实体对象。
性能:由于半自动 ORM 框架需要手动编写 SQL 语句,因
此程序员必须对 SQL 语句和数据库的底层知识有一定的了
解,才能编写高效的 SQL 语句;而全自动 ORM 框架通过
自动优化生成的 SQL 语句来提高性能,程序员无需进行优
化.
学习成本:半自动 ORM 框架需要程序员手动编写 SQL
句和映射配置,要求程序员具备较高的数据库和 SQL
识;全自动 ORM 框架可以自动生成 SQL 语句和映射配
置,程序员无需了解过多的数据库和 SQL 知识。
常见的半自动 ORM 框架包括 MyBatis 等;常见的全自动
ORM 框架包括 Hibernate Spring Data JPA 、MyBatis-
Plus 等。

 8.4 逆向工程

8.4.1 逆向工程介绍
MyBatis 的逆向工程是一种自动化生成持久层代码和映射文件
的工具,它可以根据数据库表结构和设置的参数生成对应的实
体类、 Mapper.xml 文件、 Mapper 接口等代码文件,简化了
开发者手动生成的过程。逆向工程使开发者可以快速地构建起
DAO 层,并快速上手进行业务开发。
MyBatis 的逆向工程有两种方式:通过 MyBatis Generator
插件实现和通过 Maven 插件实现。无论是哪种方式,逆向工
程一般需要指定一些配置参数,例如数据库连接 URL 、用户
名、密码、要生成的表名、生成的文件路径等等。
总的来说, MyBatis 的逆向工程为程序员提供了一种方便快捷
的方式,能够快速地生成持久层代码和映射文件,是半自动
ORM 思维像全自动发展的过程,提高程序员的开发效率
注意:逆向工程只能生成单表 crud 的操作,多表查询依然需
要我们自己编写
8.4.2 逆向工程插件MyBatisX使用
MyBatisX 是一个 MyBatis 的代码生成插件,可以通过简单的
配置和操作快速生成 MyBatis Mapper pojo 类和
Mapper.xml 文件。下面是使用 MyBatisX 插件实现逆向工程
的步骤:
安装插件:
IntelliJ IDEA 中打开插件市场,搜索 MyBatisX 并安装。
使用 IntelliJ IDEA 连接数据库

8.5 注解开发

使用注解开发会比配置文件开发更加方便。如下就是使用注解
进行开发
public interface EmployeeMapper {
@Select("select * from t_emp where emp_id =
#{empId}")
public Employee findEmpById(Integer EmpId);
//查询所有员工信息
public List<Employee> findAll();
}

注解是用来替换映射配置文件方式配置的,所以使用了注解,就不需要再映射配置文件中书写对应的statement

Mybatis 针对 CURD 操作都提供了对应的注解,已经做到见
名知意。如下:
  • 查询 :@Select
  • 添加 :@Insert
  • 修改 :@Update
  • 删除 :@Delete
注意:注解完成简单功能,配置文件完成复杂功能。
public interface EmployeeMapper {
//@Results注解相当于ResultMap
@Select("select * from t_emp where emp_id =
#{empId}")
@Results(value={
@Result(id=true,column =
"emp_id",property = "empId"),
@Result(column = "emp_name",property
= "empName"),
@Result(column =
"emp_salary",property = "empSalary")
})
public Employee findEmpById(Integer EmpId);
//查询所有员工信息
public List<Employee> findAll();
}

8.6 设置模板

ok了家人们,下周见,特别是你hh

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

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

相关文章

MFC工控项目实例二十六创建数据库

承接专栏《MFC工控项目实例二十五多媒体定时计时器》 用选取的型号为文件名建立文件夹&#xff0c;再在下面用测试的当天的时间创建文件夹&#xff0c;在这个文件中用测试的时/分/秒为数据库名创建Adcess数据库。 1、在StdAfx.h文件最下面添加代码 #import "C:/Program F…

Ubuntu下安装Bochs2.7

文章目录 前言下载安装在Bochs实现最简单的操作系统创建软盘编写并编译汇编指令编写bochs配置文件将操作系统写入到软盘启动操作系统 前言 通过自带软件库sudo apt-get install bochs bochs-x安装的Bochs运行时不显示任何内容&#xff0c;这里选用源码安装方式。 下载安装 …

Atlas800昇腾服务器(型号:3000)—AIPP加速前处理(四)

服务器配置如下&#xff1a; CPU/NPU&#xff1a;鲲鹏 CPU&#xff08;ARM64&#xff09;A300I pro推理卡 系统&#xff1a;Kylin V10 SP1【下载链接】【安装链接】 驱动与固件版本版本&#xff1a; Ascend-hdk-310p-npu-driver_23.0.1_linux-aarch64.run【下载链接】 Ascend-…

CSS 居中那些事

一、父子元素高度确定 简单粗暴, 直接通过设置合适的 padding 或 margin 实现居中 <style>.p {padding: 20px 0;background: rgba(255, 0, 0, 0.1);}.c {width: 40px;height: 20px;background: blue;} </style> <div class"p"><div class"…

服务器模块测试

目录 测试逻辑 测试工具 测试 测试逻辑 我们可以使用一个简单的业务处理逻辑来进行测试。 最简单的&#xff0c;我们业务逻辑就直接返回一个固定的字符串 void Message(const PtrConnection&con,Buffer* inbuffer) //模拟用户新数据回调 {inbuffer->MoveReadOf…

Vite 前端开发的超级加速器 - 从入门到精通

大家好&#xff01;今天我们来聊聊前端开发中的一个革命性工具 - Vite。如果你觉得你的前端开发速度慢得像蜗牛爬&#xff0c;那么Vite就是为你量身打造的超级加速器&#xff01; 一、什么是Vite&#xff1f; Vite&#xff08;法语意为"快速"&#xff09;是一个现代化…

LDR6500芯片:引领USB-C拓展坞转接器新风

在当今这个数字化浪潮汹涌澎湃的时代&#xff0c;手机和电脑已然深深融入我们生活的每一个角落&#xff0c;成为了不可或缺的关键工具。然而&#xff0c;不得不承认的是&#xff0c;它们所配备的接口数量往往有限&#xff0c;难以充分满足我们日益多样化、丰富化的需求。正因如…

5G 现网信令参数学习(1) - MIB

MIB消息中的参数 systemFrameNumber 000101B, subCarrierSpacingCommon scs30or120, ssb-SubcarrierOffset 6, dmrs-TypeA-Position pos2, pdcch-ConfigSIB1 { controlResourceSetZero 10, searchSpaceZero 4 }, cellBarred notBarred, intraFreqReselection allowed, sp…

nginx解决非人类使用http打开的443,解决网安漏扫时误扫443端口带来的问题

一、问题描述 正常访问https的站点时&#xff0c;使用网址https://www.baidu.com&#xff0c;但会有一种错误的访问请求http://www.baidu.com:443&#xff0c;一般都是非人类所为&#xff0c;如漏洞扫描工具&#xff0c;那么请求以后带来的后果是个错误页面 400 Bad Request T…

Vue及项目结构介绍

今天滴学习目标&#xff01;&#xff01;&#xff01; 项目结构介绍1.Vue 项目文件结构2. 文件结构详解2.1 index.html2.2 src/main.js2.3 src/App.vue2.4 src/components/2.5 src/assets/2.6 package.json 3. 项目启动 首先我们先学习Vue项目结构&#xff0c;我们创建Vue项目时…

【专题】计算机网络之物理层

计算机网络体系结构&#xff1a; 1. 物理层的基本概念 物理层考虑的是怎样才能在连接各种计算机的传输媒体上传输数据比特流&#xff0c;而不是指具体的传输媒体。 作用&#xff1a;尽可能屏蔽掉不同传输媒体和通信手段的差异。 用于物理层的协议也常称为物理层规程 (procedu…

js.矩阵置零

链接&#xff1a;73. 矩阵置零 - 力扣&#xff08;LeetCode&#xff09; 题目&#xff1a; 给定一个 m x n 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 示例 1&#xff1a; 输入&#xff1a;matrix [[1,1,1],…

如何使用Java语言调用API数据

在当今的数据驱动世界中&#xff0c;API&#xff08;应用程序编程接口&#xff09;成为了连接不同服务和数据源的桥梁。无论是社交媒体数据、金融市场信息还是地理位置服务&#xff0c;API都能提供一种便捷的方式来获取这些数据。Java&#xff0c;作为最受欢迎的编程语言之一&a…

无mac电脑在苹果开发者上传构建版本

我们登录苹果开发者网站的后台&#xff0c;进入app store后&#xff0c;发现上架的页面需要上传一个构建版本。 这个构建版本的意思就是我们的应用二进制文件&#xff0c;是上架最重要的文件。但是在苹果开发者后台是无法直接上传这个文件的&#xff0c;它提示我们可以使用xco…

VSCODE c++不能自动补全的问题

最近安装了vscode&#xff0c;配置了C/C扩展&#xff0c;也按照网上说的配置了头文件路径 我发现有部分头文件是没办法解析的&#xff0c;只要包含这些头文件中的一个或者多个&#xff0c;就没有代码高亮和代码自动补全了&#xff0c;确定路径配置是没问题的&#xff0c;因为鼠…

Caffeine Cache解析(一):接口设计与TinyLFU

Caffeine is a high performance Java caching library providing a near optimal hit rate. 自动加载value, 支持异步加载基于size的eviction&#xff1a;frequency and recency基于时间的过期策略&#xff1a;last access or last write异步更新valuekey支持weak referenceva…

RK3588部署及其RKNPU工具链使用学习

文章目录 RKNPU 推理框架推理软件框架RKNPU 硬件层&#xff1a;RKNPU 驱动层&#xff1a;RKNPU 应用层 RKNN 模型RKNN 的工具链介绍RKNN 软件栈整体介绍RKNN-Toolkit2 功能介绍RKNPU2-SDK总结 开发环境搭建PC 端采用 虚拟机上的 Ubunt20.04 系统安装 anconda通过 conda 创建虚拟…

机器学习“捷径”:自动特征工程全面解析

引言 在机器学习项目中&#xff0c;特征工程是影响模型性能的关键步骤。它通过从原始数据中提取出更有用的特征&#xff0c;帮助模型更好地捕捉数据中的模式。然而&#xff0c;传统的特征工程过程往往需要大量的领域知识和实验调整&#xff0c;是一项耗时费力的工作。 近年来…

关于modbus与HMI车载侧屏通信的错误机制处理

目录 1.关于6个人机交互功能按钮逻辑图设计 2.错误处理机制 1.关于6个人机交互功能按钮逻辑图设计 初次的设计想法是按钮亮表示大家能按&#xff0c;但要是想在按一次&#xff0c;发送有效数据&#xff0c;就得先按亮&#xff0c;在按灭。这里以上料区为例&#xff0c;其它区…

Midjourney中文版:创意无界,绘梦成真

在数字艺术的浩瀚宇宙中&#xff0c;Midjourney中文版如同一颗璀璨的新星&#xff0c;以其独特的魅力和无限可能&#xff0c;引领着每一位创作者探索创意的无限边界。作为专为国内用户打造的AI绘画工具&#xff0c;Midjourney中文版不仅继承了原版的核心优势&#xff0c;更在本…