【SpringBoot + MyBatis + MySQL + Thymeleaf 的使用】

目录:

    • 一:创建项目
    • 二:修改目录
    • 三:添加配置
    • 四:创建数据表
    • 五:创建实体类
    • 六:创建数据接口
    • 七:编写xml文件
    • 八:单元测试
    • 九:编写服务层
    • 十:编写控制层
    • 十一:创建页面
    • 十二:返回JSON数据

一:创建项目

 
🟢第一步:打开 IDEA,选择 New Project,选择 Spring Boot,然后按照下面截图进行操作…

在这里插入图片描述

🟢 第二步:添加依赖 (Spring Web场景启动器、Thymeleaf依赖、MyBatis依赖、MySQL驱动依赖 等)

在这里插入图片描述

🟢 稍作等待,IDEA正在帮助我们从Spring官网下载SpringBoot项目的框架,并且正在通过Maven进行构建…

在这里插入图片描述

🟢在IDEA的右下角会有Maven的下载进度。想了解Maven的使用可以参考:Maven的安装与配置教程 👈


 

二:修改目录

 
🟠项目刚创建完的目录结构大致如下,可能包的路径名有所区别,一般用自己所在组织的简拼 👇

https://blog.csdn.net/SuperCodeZhy/article/details/143754767

🟠 添加一些新包,添加之后的项目结构如下 👇

在这里插入图片描述

🟠一般情况下,还会创建一些名为 utilscommon 的包,是为了方便管理和存放其他工具类等。


 

三:添加配置

 

🟣打开项目的默认配置文件 application.properties ,然后复制粘贴以下代码 👇

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/数据库名
spring.datasource.username=数据库用户名
spring.datasource.password=数据库密码
mybatis.mapper-locations=classpath:mapper/*.xml
mybatis.configuration.map-underscore-to-camel-case=true

🟣粘贴后修改 数据库名数据库用户名数据库密码 ,修改后的效果如下图所示👇(第一行是项目名,可忽略)

在这里插入图片描述

🟣通常为了结构更加清晰,会将默认配置文件 application.properties 的后缀 改为 .yml 其配置格式如下:

spring:datasource:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/数据库名username: 数据库用户名password: 数据库密码
mybatis:mapper-locations: classpath:mapper/*.xmlconfiguration:map-underscore-to-camel-case: true

在这里插入图片描述

🟣其他配置信息这里就不过多介绍了,大家用到时自会了解~ 😁😁😁


 

接下来,我以 药品管理 为例,简单演示一下各模块代码的编写~ 😊😊😊

 

四:创建数据表

 

🟡首先,在 MySQL 数据库中创建一个数据库,然后在库中创建一个 药品表SQL 如下 👇

CREATE DATABASE `drug`;
USE DATABASE `drug`;
CREATE TABLE `medicine`  (`id` int UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '药品编号',`name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '药品名称',`code` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '国药准字',`compose` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '药品成分',`specs` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '药品规格',`usage` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '用法用量',`image` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '药品照片',`origin` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '生产厂家',`count` int UNSIGNED NOT NULL COMMENT '库存数量',PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;

🟡 然后,在数据表中添加几条数据 (下面是我使用 Navicat 连接了 本地的 MySQL 数据库的截图) 👇

在这里插入图片描述


 

五:创建实体类

 

🔵在 entity 包下创建一个名为 MedicineJava类,如下

package com.nxu.entity;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;@Data
@AllArgsConstructor
@NoArgsConstructor
@ToString
public class Medicine {private int id;             // 药品编号private String name;        // 药品名称private String code;        // 国药准字private String compose;     // 药品成分private String specs;       // 药品规格private String usage;       // 用法用量private String image;       // 药品照片private String origin;      // 生产厂家private int count;          // 库存数量
}

在这里插入图片描述


 

六:创建数据接口

 

🔴在 Java目录下的 mapper 包中,创建一个名为 MedicineMapperJava接口,如下

package com.nxu.mapper;import com.nxu.entity.Medicine;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;import java.util.List;@Mapper
public interface MedicineMapper {List<Medicine> selectAllMedicine();Medicine selectOneMedicine(@Param("id") int id);}

在这里插入图片描述


 

七:编写xml文件

 

接下来我们要使用 Mybatis 框架编写 SQL 语句。为了以后使用的方便,可以添加一个 Mybatis模板文件

Mybatis 模板文件的代码如下:

<?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>

🟤复制上面的模板代码,然后打开 IDEAFileSettings,然后进行如下操作 👇

在这里插入图片描述

在这里插入图片描述

🟤然后 我们在 resources 目录下的 mapper 文件中 创建一个名为 MedicineMapper 的 MyBatis XML 文件,并添加以下代码 👇

<?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.nxu.mapper.MedicineMapper"><select id="selectAllMedicine" resultType="com.nxu.entity.Medicine">select * from medicine</select><select id="selectOneMedicine" resultType="com.nxu.entity.Medicine">select * from medicine where id = #{id}</select></mapper>

🟤这里大家可以安装一个名为 MyBatisX 的插件,挺好用的,如下 👇

在这里插入图片描述

🟤安装好之后,我们的 MyBatis接口 和 MyBatis 的 xml 文件可以点击小鸟进行跳转,还有其他提示功能~

在这里插入图片描述


 

八:单元测试

 

写到这里,我们可以先简单的做个单元测试,确保数据库连通,以及测试 MyBatis 是否可以正常使用。😀😀😀

🟢在我们的 test 目录下,新建一个名为 MedicineTestJava测试类,然后添加以下代码进行测试 👇

package com.nxu;import com.nxu.entity.Medicine;
import com.nxu.mapper.MedicineMapper;
import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;import java.util.List;@Slf4j
@SpringBootTest
public class MedicineTest {@Autowiredprivate MedicineMapper medicineMapper;@Testpublic void testSelectAllMedicine() {List<Medicine> allMedicine = medicineMapper.selectAllMedicine();for (Medicine medicine : allMedicine) {log.info(medicine.toString());}}
}

在这里插入图片描述

🟢点击 方法前面的 启动 按钮,执行单元测试,控制台效果如下 👇

在这里插入图片描述


 

九:编写服务层

 

🟠首先,在 java 目录 下的 service 包中 创建一个名为 MedicineServiceJava接口,如下 👇

package com.nxu.service;import com.nxu.entity.Medicine;import java.util.List;public interface MedicineService {List<Medicine> getAllMedicine();Medicine getOneMedicine(int id);
}

🟠然后,继续 在 service 包中创建一个名为 MedicineServiceImplJava类 继承刚才的接口 👇

package com.nxu.service;import com.nxu.entity.Medicine;
import com.nxu.mapper.MedicineMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import java.util.List;@Service
public class MedicineServiceImpl implements MedicineService {@Autowiredprivate MedicineMapper medicineMapper;@Overridepublic List<Medicine> getAllMedicine() {// 此处可以写更多业务逻辑,这里只是简单调用return medicineMapper.selectAllMedicine();}@Overridepublic Medicine getOneMedicine(int id) {// 此处可以写更多业务逻辑,这里只是简单调用return medicineMapper.selectOneMedicine(id);}
}

在这里插入图片描述


 

十:编写控制层

 

🟣在 java目录 下的 controller 包中,创建一个名为 MedicineController 的 Java类 👇

package com.nxu.controller;import com.nxu.entity.Medicine;
import com.nxu.service.MedicineService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;import java.util.List;@Controller
public class MedicineController {@Autowiredprivate MedicineService medicineService;@RequestMapping("/")public String index(Model model) {model.addAttribute("msg", "我的第N个SpringBoot项目!");List<Medicine> list = medicineService.getAllMedicine();model.addAttribute("list", list);return "index";}}

在这里插入图片描述


 

十一:创建页面

 

🔴在 resources 目录的 templates 文件下 创建一个名为 indexhtml 文件,然后添加以下代码 👇

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"><title>药品管理</title><link href="//unpkg.com/layui@2.10.3/dist/css/layui.css" rel="stylesheet">
</head>
<body>
<h1 th:text="${msg}" style="text-align: center;"></h1><table class="layui-table"><thead><tr><th>序号</th><th>药品编号</th><th>药品名称</th><th>国药准字</th><th>药品成分</th><th>药品规格</th><th>用法用量</th><th>药品照片</th><th>生产厂家</th><th>库存数量</th></tr></thead><tbody><!--此处演示Thymeleaf的循环,sb是单个数据体的名字,it是迭代器的别名,${medicines}是我们存的集合--><tr th:each="sb,it : ${medicines}"><td th:text="${it.index+1}"></td><td th:utext="|编号${sb.id}|"></td><td th:text="${sb.name}"></td><td th:text="${sb.code}"></td><td th:text="${sb.compose}"></td><td th:text="${sb.specs}"></td><td th:text="${sb.usage}"></td><td><img th:src="${sb.image}" width="30px" height="30px" alt=""></td><td th:text="${sb.origin}"></td><td>[[${sb.count}]]</td></tr></tbody>
</table><script src="//unpkg.com/layui@2.10.3/dist/layui.js"></script>
</body>
</html>

🔴启动项目

在这里插入图片描述

在这里插入图片描述

🔴打开浏览器,输入 localhost:8080,回车,即可看到我们的index页面,以及使用Thymeleaf显示的数据。

在这里插入图片描述

🔴像图片这些静态资源,一般放在 resources 目录下的 static 文件夹中,页面中通过 / 路径 的方式引用 👇

在这里插入图片描述

🔴那么在引用 该 照片时的路径就是 /image/samil.jpg


 

十二:返回JSON数据

 

🟢如果我们写了一个前后端分离项目,或者本身我需要返回JSON格式的数据,那么我们可以这么写 👇

🟡在原来的 MedicineController 中添加以下代码:

    @GetMapping("/medicine/{id}")@ResponseBodypublic Medicine getMedicine(@PathVariable Integer id) {return medicineService.getOneMedicine(id);}

在这里插入图片描述

🟢重启项目,然后浏览器中输入 localhost:8080/medicine/1 然后回车,可以看到返回的数据 👇

在这里插入图片描述

🟢如果你的某个 controller 仅作为数据接口,不返回视图,可以直接用 @RestController ,这个注解相当于 @Controller@ResponseBody 注解的组合,这样当前整个 controller 中都跳过 Spring 的视图解析器。


 

至此,关于 SpringBoot 的简单使用就介绍完了。想要了解更多知识或交个朋友,欢迎访问 👉 作者博客 😁😁😁

 

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

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

相关文章

Elasticsearch索引的字段映射

目录 type String类型 text和keyword的区别 数值类型 日期类型 index doc_values fields analyzer store index_options ElasticSearch索引映射示例 Elasticsearch中的字段设置直接影响数据的存储、索引和查询行为。结合索引查询场景合理设置mapping信息可以起到提…

【已解决】实际参数列表和形式参数列表长度不同、java: 无法将类xxx中的构造器xxx应用到给定类型| lombok相关

idea运行maven项目时&#xff0c;报错这个&#xff08;如标题&#xff09; 解决方案记录&#xff1a; 找到了之前的、能运行成功不报错的 maven项目。参考其pom.xml文件中lombok相关部分&#xff0c;将<path>标签下的lombok加个版本号&#xff0c;就运行成功了&#xff1…

4. 学习网站:学习新的技能或培养兴趣爱好

文章目录 前言英文网站&#xff1a;培养兴趣爱好的应用总结 前言 学习网站以及具体提供的内容。 英文网站&#xff1a; Coursera&#xff1a;提供来自全球顶尖大学和机构的在线课程&#xff0c;涵盖广泛的学科&#xff0c;包括编程、数据科学、商业和艺术等。Udemy&#xff1…

LabVIEW 开发中 TCP 与 UDP 协议的差异

在 LabVIEW 开发的网络通信场景中&#xff0c;TCP 和 UDP 是常用的两种传输层协议&#xff0c;它们各自具有独特的特点&#xff0c;适用于不同的应用需求。理解它们之间的差异&#xff0c;有助于开发者根据具体项目需求选择合适的协议&#xff0c;以实现高效、稳定的网络通信。…

04-深入解析 Spring 事务管理原理及源码

深入解析 Spring 事务管理原理及源码 Spring 事务管理&#xff08;Transaction Management&#xff09;是企业级应用开发中至关重要的功能之一&#xff0c;它确保数据操作的 原子性、一致性、隔离性、持久性&#xff08;ACID&#xff09;。 本篇博客将从 Spring 事务的基本概…

【Linux】用户向硬件寄存器写入值过程理解

思考一下&#xff0c;当我们咋用户态向寄存器写入一个值&#xff0c;这个过程是怎么样的呢&#xff1f;以下是应用程序通过标准库函数&#xff08;如 write()、ioctl() 或 mmap()&#xff09;向硬件寄存器写入值的详细过程&#xff0c;从用户空间到内核再到硬件的完整流程&…

自动驾驶02:点云预处理——02(运动补偿篇LIO-SAM)

当激光雷达&#xff08;LiDAR&#xff09;在运动中采集点云时&#xff0c;每个点的时间戳不同&#xff0c;而车辆在移动&#xff0c;导致点云在不同时间点的坐标与实际情况不符&#xff0c;这种现象称为运动畸变&#xff08;Motion Distortion&#xff09;。为了得到无畸变的点…

基础算法篇(3)(蓝桥杯常考点)—图论

前言 这期是基础算法篇的第三节&#xff0c;其中的dijkstra算法更是蓝桥杯中的高频考点 图的基本相关概念 有向图和无向图 自环和重边 稠密图和稀疏图 对于不带权的图&#xff0c;一条路径的路径长度是指该路径上各边权值的总和 对于带权的图&#xff0c;一条路径长度时指该路…

Crawl4AI:专为AI设计的开源网页爬虫工具,释放大语言模型的潜能

在当今数据驱动的AI时代,高效获取结构化网页数据是模型训练和应用落地的关键。Crawl4AI作为一款专为大型语言模型(LLMs)设计的开源爬虫工具,凭借其极速性能、AI友好输出和模块化设计,正在成为开发者社区的热门选择。本文将深入解析其核心特性与技术优势。 一、Crawl4AI的核…

前后端数据序列化:从数组到字符串的旅程(附优化指南)

&#x1f310; 前后端数据序列化&#xff1a;从数组到字符串的旅程&#xff08;附优化指南&#xff09; &#x1f4dc; 背景&#xff1a;为何需要序列化&#xff1f; 在前后端分离架构中&#xff0c;复杂数据类型&#xff08;如数组、对象&#xff09;的传输常需序列化为字符…

汇编学习之《移位指令》

这章节学习前需要回顾之前的标志寄存器的内容&#xff1a; 汇编学习之《标志寄存器》 算数移位指令 SAL (Shift Arithmetic Left)算数移位指令 : 左移一次&#xff0c;最低位用0补位&#xff0c;最高位放入EFL标志寄存器的CF位&#xff08;进位标志&#xff09; OllyDbg查看…

NLP高频面试题(二十九)——大模型解码常见参数解析

在大语言模型的实际应用中&#xff0c;如何更有效地控制文本生成的质量与多样性&#xff0c;一直是热门研究话题。其中&#xff0c;模型解码&#xff08;decode&#xff09;策略至关重要&#xff0c;涉及的主要参数包括 top_k、top_p 和 temperature 等。本文将详细介绍这些常见…

【C#】Task 线程停止

CancellationTokenSource cts 是用于控制任务&#xff08;线程&#xff09;停止运行的。我们一步步来解释它的作用。 &#x1f50d; 现在的代码结构大概是这样的&#xff1a; Task.Run(() > {while (true){// 不断循环采集图像} });这种写法虽然简单&#xff0c;但最大的问…

WebRTC的ICE之TURN协议的交互流程中继转发Relay媒体数据的turnserver的测试

WebRTC的ICE之TURN协议的交互流程和中继转发Relay媒体数据的turnserver的测试 WebRTC的ICE之TURN协议的交互流程中继转发Relay媒体数据的turnserver的测试 WebRTC的ICE之TURN协议的交互流程和中继转发Relay媒体数据的turnserver的测试前言一、TURN协议1、连接Turn Server 流程①…

Redis + Caffeine多级缓存电商场景深度解析

Redis Caffeine多级缓存 Redis Caffeine多级缓存电商场景深度解析一、实施目的二、具体实施2.1 架构设计2.2 组件配置2.3 核心代码实现 三、实施效果3.1 性能指标对比3.2 业务指标改善3.3 系统稳定性 四、关键策略4.1 缓存预热4.2 一致性保障4.3 监控配置Prometheus监控指标 …

前端开发3D-基于three.js

基于 three.js 渲染任何画面&#xff0c;都要基于这 3 个要素来实现 1场景scene&#xff1a;放置物体的容器 2摄像机&#xff1a;类似人眼&#xff0c;可调整位置&#xff0c;角度等信息&#xff0c;展示不同画面 3渲染器&#xff1a;接收场景和摄像机对象&#xff0c;计算在浏…

代码随想录算法训练营--打卡day4

一.移除链表元素 1.题目链接 203. 移除链表元素 - 力扣&#xff08;LeetCode&#xff09; 2.思路 通过 while 循环来遍历链表&#xff0c;只要 cur 的下一个节点不为空&#xff0c;就继续循环。在循环中&#xff0c;对 cur 的下一个节点的值进行判断&#xff1a; 值不等于…

虚拟电厂:多元能源聚合,开启绿色电力新时代

虚拟电厂&#xff1a;多元能源聚合&#xff0c;开启绿色电力新时代 在“双碳”目标驱动下&#xff0c;电力系统正经历从集中式向分布式、从单一能源向多能互补的深刻变革。 作为能源互联网的核心载体&#xff0c;虚拟电厂通过数字化技术整合多种能源资源&#xff0c;而是像指…

高通Android10 铃声通话音频80%音量修改

先修改最高的音量step --- a/SC60_AP/frameworks/base/services/core/java/com/android/server/audio/AudioService.javab/SC60_AP/frameworks/base/services/core/java/com/android/server/audio/AudioService.java-311,14 311,14 public class AudioService extends IAudio…

类加载过程?类隔离了解过吗?

类加载过程详解 类加载是 JVM 将类的字节码从磁盘、网络或其他来源加载到内存&#xff0c;并转换为 Class 对象的过程&#xff0c;主要分为以下 五个阶段&#xff1a; 1. 加载&#xff08;Loading&#xff09; 任务&#xff1a;查找类的二进制字节流&#xff08;如 .class 文…