49、Spring Boot 详细讲义(六)(SpringBoot2.x整合Mybatis实现CURD操作和分页查询详细项目文档)

项目文档:银行借据信息CURD操作和分页查询

一、项目概述

1. 项目简介

本项目旨在使用Spring Boot框架整合MyBatis连接Mysql数据库实现借据信息的增加、删除、修改和查询功能,同时支持分页查询,并提供对应的Restful风格的接口。

2.环境准备

2.1.工具和软件准备

  • JDK(建议版本:JDK 11)
  • IDE(建议IntelliJ IDEA)
  • Maven(用于构建和管理项目)
  • 数据库(Mysql)
  • Apifox (接口测试)

2.2. 技术栈

  • Spring Boot:用于快速搭建应用程序框架。
  • MyBatis:用于数据库操作和持久化。
  • Spring Web:用于构建接口

3.概念介绍

Mybatis框架

MyBatis 是一个基于 Java 的持久层框架,它主要解决了传统 JDBC 编码中存在的大量样板代码和繁琐的 SQL 语句编写问题。MyBatis 提供了一个简单易用的 API,通过配置 XML 文件或者注解来实现对象与 SQL 语句的映射,从而实现了数据库操作的简化和灵活性。其主要特点包括:

  1. 简化 SQL 编写:MyBatis 使用 XML 文件或者注解来描述 SQL 映射关系,将 SQL 语句和 Java 对象进行映射,避免了手动编写大量的 SQL 语句,提高了开发效率。
  2. 灵活性:MyBatis 不强制开发者使用特定的 ORM 映射规范,开发者可以自由地编写 SQL 语句,从而更灵活地处理复杂的数据库操作。
  3. 动态 SQL:MyBatis 支持动态 SQL,可以根据条件动态生成 SQL 语句,使得 SQL 的编写更加灵活和可控。
  4. 缓存支持:MyBatis 提供了一级缓存和二级缓存机制,能够有效减少数据库访问次数,提升系统性能。
  5. 与 Spring 等框架集成:MyBatis 与 Spring 等主流 Java 框架集成良好,可以方便地与其他框架结合使用,如 Spring Boot、Spring MVC 等。

4. 功能模块介绍

3.1. 增加借据信息

添加新的借据信息到系统中,包括借据号、借款人信息、借款金额等。

3.2. 删除借据信息

根据借据号删除特定的借据信息。

3.3. 修改借据信息

修改已有的借据信息,包括借款金额、借款人信息等。

3.4. 查询借据信息

根据借据号查询特定的借据信息,查询所有借据信息

3.5. 分页查询

支持对借据信息进行分页查询

二. 数据库设计

详细的借据信息系统包含客户信息、借据信息、还款信息和利率信息等,这里以借据信息表为例。

借据信息表(loan)

  • Loan_ID (主键)
  • Customer_ID (外键,指向 Customer 表)
  • Loan_Amount 贷款金 额
  • Loan_Type 贷款类型
  • Loan_Term 贷款期限
  • Loan_Interest_Rate 贷款利率
  • Loan_Status 状态(如:已还清、未还清等)

参考代码如下:

-- 创建 Loan 表
CREATE TABLE loan (loan_id INT AUTO_INCREMENT PRIMARY KEY,customer_id INT,loan_amount DECIMAL(10,2),loan_type VARCHAR(50),loan_term INT,loan_interest_rate DECIMAL(5,2),loan_status VARCHAR(20)
);-- 添加测试数据
INSERT INTO loan (customer_id, loan_amount, loan_type, loan_term, loan_interest_rate, loan_status)
VALUES
(1, 5000.00, '个人贷款', 12, 5.5, '未还清'),
(2, 10000.00, '抵押贷款', 24, 4.2, '未还清'),
(3, 8000.00, '车贷', 36, 4.5, '已还清');

三. 创建项目

1.创建SpringBoot项目

https://start.aliyun.com/

使用脚手架创建springboot项目,并将创建的代码在idea中打开

在这里插入图片描述

在这里插入图片描述

添加配置文件

通过云原生脚手架创建出来的项目默认没有resources目录,可以手动创建一下

在main文件夹上右键选择->新建->目录
在这里插入图片描述

取名为resources
在这里插入图片描述

在resouces目录下创建application.yml

2.添加依赖

在pom.xml文件中添加Mybatis,Spring web ,分页控件等相关依赖

<!--lombok-->
<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.22</version>
</dependency><!--mysql-->
<dependency>

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

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

相关文章

youtube视频和telegram视频加载原理差异分析

1. 客户侧缓存与流式播放机制​​ 流式视频应用&#xff08;如 Netflix、YouTube&#xff09;通过​​边下载边播放​​实现流畅体验&#xff0c;其核心依赖以下技术&#xff1a; ​​缓存预加载​​&#xff1a;客户端在后台持续下载视频片段&#xff08;如 DASH/HLS 协议的…

把城市变成智能生命体,智慧城市的神奇进化

智能交通系统的建立与优化 智能交通系统&#xff08;ITS&#xff09;是智慧城市建设的核心部分之一&#xff0c;旨在提升交通管理效率和安全性。该系统利用传感器网络、GPS定位技术以及实时数据分析来监控和管理城市中的所有交通流动。例如&#xff0c;通过部署于道路两侧或交…

Oracle 23ai Vector Search 系列之5 向量索引(Vector Indexes)

文章目录 Oracle 23ai Vector Search 系列之5 向量索引Oracle 23ai支持的向量索引类型内存中的邻居图向量索引 (In-Memory Neighbor Graph Vector Index)磁盘上的邻居分区矢量索引 (Neighbor Partition Vector Index) 创建向量索引HNSW索引IVF索引 向量索引示例参考 Windows 环…

cas 5.3单点登录中心开发手册

文档格式PDF 只读文档。 代码源码。 一、适用对象 需要快速上手出成果的服务端开发人员&#xff0c;具备3年经验java 开发&#xff0c;熟悉数据库&#xff0c;基本的Linux操作系统配置。 工期紧张需要快速搭建以cas为基础的统一登录中心&#xff0c;遇到技术瓶颈&#xff0c…

行星际激波在日球层中的传播:Propagation of Interplanetary Shocks in the Heliosphere (第一部分)

行星际激波在日球层中的传播&#xff1a;Propagation of Interplanetary Shocks in the Heliosphere &#xff08;第二部分&#xff09;- Chapter 3: Solar and heliospheric physics 行星际激波在日球层中的传播&#xff1a;Propagation of Interplanetary Shocks in the Hel…

Linux——消息队列

目录 一、消息队列的定义 二、相关函数 2.1 msgget 函数 2.2 msgsnd 函数 2.3 msgrcv 函数 2.4 msgctl 函数 三、消息队列的操作 3.1 创建消息队列 3.2 获取消息队列并发送消息 3.3 从消息队列接收消息recv 四、 删除消息队列 4.1 ipcrm 4.2 msgctl函数 一、消息…

蓝桥杯常考排序

1.逆序 Collections.reverseOrder() 方法对列表进行逆序排序。通过 Collections.sort() 方法配合 Collections.reverseOrder()&#xff0c;可以轻松实现从大到小的排序。 import java.util.ArrayList; // 导入 ArrayList 类&#xff0c;用于创建动态数组 import java.util.C…

ILGPU的核心功能使用详解

什么是ILGPU? ILGPU 是一种用于高性能 GPU 程序的新型 JIT&#xff08;即时&#xff09;编译器 &#xff08;也称为 kernels&#xff09;编写的 .基于 Net 的语言。ILGPU 完全 用 C# 编写&#xff0c;没有任何原生依赖项&#xff0c;允许您编写 GPU 真正可移植的程序。…

金融的未来

1. DeFi的爆发式增长与核心使命 DeFi&#xff08;去中心化金融&#xff09;的使命是重构传统金融基础设施&#xff0c;通过区块链技术实现更高的透明度、可访问性、效率、便利性和互操作性。其增长数据印证了这一趋势&#xff1a; TVL&#xff08;总锁定价值&#xff09;爆炸…

在Vue项目中查询所有版本号为 1.1.9 的依赖包名 的具体方法,支持 npm/yarn/pnpm 等主流工具

以下是 在Vue项目中查询所有版本号为 1.1.9 的依赖包名 的具体方法&#xff0c;支持 npm/yarn/pnpm 等主流工具&#xff1a; 一、使用 npm 1. 直接过滤依赖树 npm ls --depth0 | grep "1.1.9"说明&#xff1a; npm ls --depth0&#xff1a;仅显示直接依赖&#xf…

其利天下即将亮相第21届(顺德)家电电源与智能控制技术研讨会

2025年4月25日&#xff0c;第21届&#xff08;顺德&#xff09;家电电源与智能控制技术研讨会即将拉开帷幕&#xff0c;其利天下应大比特之邀&#xff0c;确认将参加此次研讨会。 本次研讨会&#xff0c;我司委派研发总监冯建武先生围绕《重新定义风扇驱动&#xff1a;一套算法…

阿里云OSS

目录 第三方服务-通用思路 SDK 准备工作 阿里云OSS-入门程序 .putObject 如何拿到文件对应的字节数组&#xff1f; .readAllBytes&#xff08;&#xff09; 集成阿里云OSS完成文件上传 引入阿里云OSS文件上传的工具类 上传文件接口开发 .getOriginalFilename() 程序…

李宏毅NLP-4-语音识别part3-CTC

Connectionist Temporal Classification&#xff5c;CTC 基于连接主义时间分类&#xff08;CTC&#xff09;的语音识别架构&#xff0c;具体描述如下&#xff1a; 输入层&#xff1a;底部的 x 1 , x 2 , x 3 , x 4 x^1, x^2, x^3, x^4 x1,x2,x3,x4代表输入的语音信号分帧数据…

如何构建类似云数据仓库 Snowflake 的本地数据仓库?

目录 一、Snowflake 架构的三大核心价值 二、本地数据仓库要“像 Snowflake”&#xff0c;关键在数据服务化 三、SQL2API&#xff1a;本地数据服务共享的核心引擎 ✅ 什么是 SQL2API&#xff1f; ✅ 为什么是构建本地类 Snowflake 架构的关键&#xff1f; 四、QuickAPI&a…

设计模式 - 单例模式

一个类不管创建多少次对象&#xff0c;永远只能得到该类型一个对象的实力 常用到的&#xff0c;比如日志模块&#xff0c;数据库模块 饿汉式单例模式&#xff1a;还没有获取实例对象&#xff0c;实例对象就已经产生了 懒汉式单例模式&#xff1a;唯一的实例对象&#xff0c;…

【Windows Cmake工程配置Boost库】

Windows Cmake工程配置Boost库 背景配置流程1. 下载Boost库2. 配置环境变量3. 修改CmakeLists背景 Windows环境下使用cmake开发程序,如图需要用到boost库,但是从官网下载的boost库源码没有编译成功,于是从网上下载boost预编译库,直接配置。 配置流程 1. 下载Boost库 官…

长期坚持的本质,看重休息,看轻自律

01 你有没有这样的经历&#xff0c; 年初立下减肥20斤、读完100本书、旅行10次等目标&#xff0c; 年中发现进度太慢&#xff0c; 于是降低年初目标&#xff0c; 但年终完成度仍然不及格。 只好跨年时将希望寄托于来年&#xff0c; 明年复明年&#xff0c;明年何其多。 …

Python实现贪吃蛇三

上篇文章Python实现贪吃蛇一&#xff0c;实现了一个贪吃蛇的基础版本。后面第二篇文章Python实现贪吃蛇二修改了一些不足&#xff0c;但最近发现还有两点需要优化&#xff1a; 1、生成食物的时候有概率和记分牌重合 2、游戏缺少暂停功能 先看生成食物的时候有概率和记分牌重合的…

LSTM概述

一、LSTM的背景与动机 1.1 为什么需要LSTM? 在深度学习中,普通的神经网络(如全连接网络或卷积神经网络)在处理序列数据时表现不佳,因为它们无法捕捉数据中的时间依赖关系。循环神经网络(RNN)被设计来处理序列数据,通过隐藏状态在时间步之间传递信息。然而,传统RNN存…

DDS信号发生器设计

一、基本概述 1.1 DDS简介 DDS信号发生器即直接数字频率合成&#xff08;Direct Digital Frequency Synthesis&#xff0c;简称DDS&#xff09;是一种利用数字技术生成信号的方法。它通过数字信号处理技术&#xff0c;将数字信号转换为模拟信号&#xff0c;从而生成高质量的正…