首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >SpringBoot+MyBatis+Spring 技术整合实现商品模块的CRUD操作

SpringBoot+MyBatis+Spring 技术整合实现商品模块的CRUD操作

作者头像
用户5546570
发布于 2020-09-02 11:07:47
发布于 2020-09-02 11:07:47
1.4K00
代码可运行
举报
运行总次数:0
代码可运行

写在前面:2020年面试必备的Java后端进阶面试题总结了一份复习指南在Github上,内容详细,图文并茂,有需要学习的朋友可以Star一下! GitHub地址:https://github.com/abel-max/Java-Study-Note/tree/master

业务描述

基于Spring,MyBatis,SpringBoot,Thymeleaf技术实现商品模块的增删改查操作。

项目环境初始化

准备工作

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
1\. MySQL(5.7)
2\. JDK (1.8)
3\. Maven (3.6.3)
4\. STS(4.7.1)

数据库初始化

打开mysql控制台,然后按如下步骤执行goods.sql文件。

第一步:登录mysql。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql –uroot –proot

第二步:设置控制台编码方式。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
set names utf8;

第三步:执行goods.sql文件(切记不要打开文件复制到mysql客户端运行)。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
source d:/goods.sql

其中goods.sql文件内容如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
drop database if exists dbgoods;
create database dbgoods default character set utf8;
use dbgoods;
create table tb_goods(
     id bigint primary key auto_increment,
     name varchar(100) not null,
     remark text,
     createdTime datetime not null
)engine=InnoDB;
insert into tb_goods values (null,'java','very good',now());
insert into tb_goods values (null,'mysql','RDBMS',now());
insert into tb_goods values (null,'Oracle','RDBMS',now());
insert into tb_goods values (null,'java','very good',now());
insert into tb_goods values (null,'mysql','RDBMS',now());
insert into tb_goods values (null,'Oracle','RDBMS',now());
insert into tb_goods values (null,'java','very good',now());

创建项目并添加依赖

第一步:基于start.spring.io 创建项目并设置基本信息

image

第二步:创建项目时指定项目核心依赖

image

第三步:项目创建以后分析其结构

image

项目配置文件内容初始化

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#server
server.port=80
#server.servlet.context-path=/
#spring datasource
spring.datasource.url=jdbc:mysql:///dbgoods?serverTimezone=GMT%2B8&characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=root

#spring mybatis
mybatis.mapper-locations=classpath:/mapper/*/*.xml

#spring logging
logging.level.com.cy=debug

#spring thymeleaf
spring.thymeleaf.prefix=classpath:/templates/pages/
spring.thymeleaf.suffix=.html
spring.thymeleaf.cache=false

项目API架构设计

API架构设计,如图所示:

image

商品查询业务实现

业务描述

从商品库查询商品信息,并将商品信息呈现在页面上,如图所示:

image

商品查询时序分析

image

Pojo类定义

定义Goods对象,用于封装从数据库查询到的商品信息。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.cy.pj.goods.pojo;
import java.util.Date;
public class Goods {
    private Long id;//id bigint primary key auto_increment
    private String name;//name varchar(100) not null
    private String remark;//remark text
    private Date createdTime;//createdTime datetime
    public Long getId() {
        return id;
    }
    public void setId(Long id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getRemark() {
        return remark;
    }
    public void setRemark(String remark) {
        this.remark = remark;
    }
    public Date getCreatedTime() {
        return createdTime;
    }
    public void setCreatedTime(Date createdTime) {
        this.createdTime = createdTime;
    }
    @Override
    public String toString() {
        return "Goods [id=" + id + ", name=" + name + ",   
        remark=" + remark + ", createdTime=" + createdTime + "]";
    }
}

Dao接口及方法定义

在GoodsDao接口中定义商品查询方法以及SQL映射,基于此方法及SQL映射获取所有商品信息。代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.cy.pj.goods.dao;
import java.util.List;
import org.apache.ibatis.annotations.Select;
import com.cy.pj.goods.pojo.Goods;

@Mapper
public interface GoodsDao {
      @Select("select * from tb_goods")
      List<Goods> findGoods();
}

Service接口及实现

GoodsService接口及商品查询方法定义

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.cy.pj.goods.service;
import java.util.List;
import com.cy.pj.goods.pojo.Goods;
public interface GoodsService {
      List<Goods> findGoods();
}

GoodsService接口实现类GoodsServiceImpl定义及方法实现

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.cy.pj.goods.service;
import java.util.List;
import com.cy.pj.goods.pojo.Goods;
@Service
public class GoodsServiceImpl implements GoodsService {
     @Autowired
     private GoodsDao goodsDao;
     @Override
     public List<Goods> findGoods(){
         return goodsDao.findGoods();
     }
}

Controller定义及方法实现

定义GoodsController类,并添加doGoodsUI方法,添加查询商品信息代码,并将查询到的商品信息存储到model,并返回goods页面。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.cy.pj.goods.controller;
import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import com.cy.pj.goods.pojo.Goods;
import com.cy.pj.goods.service.GoodsService;
@Controller //@Service,@Component
@RequestMapping("/goods/")
public class GoodsController {
    //has a+di
    @Autowired
    private GoodsService goodsService;
    @RequestMapping("doGoodsUI")
    public String doGoodsUI(Model model) {
         //调用业务层方法获取商品信息
         List<Goods> list= goodsService.findGoods();
         //将数据存储到请求作用域
         model.addAttribute("goods", list);
         return "goods";//viewname
    }

}

基于Thymeleaf模板引擎实现数据呈现

在templates/pages目录中添加goods.html页面,并在body中添加如下元素:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<table width="50%">
        <thead>
           <th>id</th>
           <th>name</th>
           <th>remark</th>
           <th>createdTime</th>
           <th>operation</th>
        </thead>
        <tbody>
           <tr th:each="g:${list}">
             <td th:text="${g.id}">1</td>
             <td th:text="${g.name}">MySQL</td>
             <td th:text="${g.remark}">DBMS</td>
             <td th:text="${#dates.format(g.createdTime, 'yyyy/MM/dd HH:mm')}">2020/07/03</td>
             <td><a>delete</a></td>
           </tr>
        </tbody>
  </table>

thymeleaf 是一种模板引擎,此引擎以html为模板,将服务端model中数据填充在页面上,其官网为thymeleaf.org

Goods页面上数据呈现分析:

image

启动Tomcat进行访问测试分析

首先,启动tomcat,然后在打开浏览器,在地址栏输入访问地址,获取服务端数据并进行呈现,如图所示:

image

项目运行过程中的BUG分析

  • 控制台“?”符号,如图所示:

image

  • 数据库连不上,如图所示:

image

  • 服务启动失败,如图所示:

image

  • SQL语法问题,如图所示:

image

  • 日期格式不正确,如图所示:

image

  • 页面上${}内容错误,如图所示:

image

  • 页面日期格式不正确,如图所示:

image

  • 依赖注入失败,如图所示:

image

  • 空指针异常(NullPointerException),如图所示:

image

商品删除业务实现

业务描述

从商品库查询商品信息后,点击页面上删除超链接,基于id删除当前行记录,如图所示:

image

业务时序分析

在商品呈现页面,用户执行删除操作,其删除时序如图所示:

image

Dao接口方法及映射定义

在GoodsDao接口中定义商品删除方法以及SQL映射,代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Delete("delete from tb\_goods where id=#{id}")

 int deleteById(Integer id);

Service接口方法定义及实现

在GoodsService接口中添加删除方法,代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
int deleteById(Integer id);

在GoodsService的实现类GoodsServiceImpl中添加deleteById方法实现。代码如下。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Override
    public int deleteById(Integer id) {
        long t1=System.currentTimeMillis();
        int rows=goodsDao.deleteById(id);
        long t2=System.currentTimeMillis();
        System.out.println("execute time:"+(t2-t1));
        return rows;
    }

Controller对象方法定义及实现

在GoodsController中的添加doDeleteById方法,代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@RequestMapping("doDeleteById/{id}")
    public String doDeleteById(@PathVariable Integer id){
        goodsService.deleteById(id);
        return "redirect:/goods/doGoodsUI";
    }

说明:Restful 风格为一种软件架构编码风格,定义了一种url的格式,其url语法为/a/b/{c}/{d},在这样的语法结构中{}为一个变量表达式。假如我们希望在方法参数中获取rest url中变量表达式的值,可以使用@PathVariable注解对参数进行描述。

Goods页面上删除超链接定义

在goods.html页面中添加删除超链接,如图所示:

image

Thymeleaf 官方th:href应用说明,如图所示:

image

删除操作中,客户端与服务端代码关联说明,如图所示:

image

启动tomcat服务器进行访问测试分析

首先,启动tomcat,然后在打开浏览器,在地址栏输入访问地址,获取服务端数据并进行呈现,接下来点击页面上的删除按钮,如图所示:

image

删除成功以后,的页面如图所示:

image

项目启动及运行过程中的Bug及问题分析

  • SQL映射元素定义问题,如图所示:

image

  • 客户端请求参数与服务端参数不匹配,如图所示:

image

商品添加业务实现

业务描述

在Goods列表页面,添加添加按钮,进行添加页面,然后在添加页面输入商品相关信息,然后保存到数据库,如图所示:

image

商品添加页面,设计如图所示:

image

业务时序分析

在商品添加页面,输入商品信息,然后提交到服务端进行保存,其时序分析如图所示:

image

Dao接口方法及映射定义

在GoodsDao中添加用于保存商品信息的接口方法以及SQL映射,代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Insert("insert into tb_goods(name,remark,createdTime) 
values (#{name},#{remark},now())")
int insertObject(Goods entity);

说明:当SQL语句比较复杂时,也可以将SQL定义到映射文件(xml文件)中。

Service接口方法定义及实现

在GoodsService接口中添加业务方法,用于实现商品信息添加,代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
int saveGoods(Goods entity);

在GoodsSerivceImpl类中添加接口方法实现,代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Override
    public int saveGoods(Goods entity) {
        int rows=goodsDao.insertObject(entity);
        return rows;
    }

Controller对象方法定义及实现

在GoodsController类中添加用于处理商品添加请求的方法,代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@RequestMapping("doSaveGoods")
public String doSaveGoods(Goods entity) {
        goodsService.saveGoods(entity);
        return "redirect:/goods/doGoodsUI";
}

在GoodsController类中添加用于返回商品添加页面的方法,代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@RequestMapping("doGoodsAddUI")
    public String doGoodsAddUI() {
        return "goods-add";
    }

Goods添加页面设计及实现

在templates的pages目录中添加goods-add.html页面,代码如下

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<style type="text/css">
   ul li {list-style-type: none;}
</style>
</head>
<body>
<h1>The Goods Add Page</h1>
<form th:action="@{/goods/doSaveGoods}" method="post">
   <ul>
      <li>name:
      <li><input type="text" name="name">
      <li>remark:
      <li><textarea rows="5" cols="50" name="remark"></textarea>
      <li><input type="submit" value="Save">
   </ul>
</form>
</body>
</html>

在goods.html页面中添加,超链接可以跳转到添加页面,关键代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<a th:href="@{/goods/doGoodsAddUI}">添加商品</a>

启动Tomcat服务器进行访问测试分析

第一步:启动web服务器,检测启动过程是否OK,假如没有问题进入下一步。

第二步:打开浏览器在地址里输入 http://localhost/goods/doGood... ,出现如下界面,如图所示:

image

第三步:在添加页面中填写表单,然后点击save按钮将表单数据提交到服务端,如图所示:

image

第四步:添加页面中表单数据提交过程分析,如图所示:

image

项目启动及运行过程中的Bug及问题分析

  • 客户端显示400异常,如图所示:

image

  • 保存时500异常,如图所示:

image

  • 数据库完整性约束异常,如图所示:

image

总结(Summary)

本小节重点讲解了SpringBoot工程下MyBatis,SpringMVC,Thymeleaf技术的综合应用,重点理解其业务实现过程以及问题的解决过程。

来源:https://www.tuicool.com/articles/iy2IRbI

欢迎关注微信公众号【慕容千语】

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
虚拟机逃逸--QEMU案例学习
当前虚拟机被大量部署用于个人使用和企业部门。网络安全供应商使用不同的虚拟机来分析受控和受限环境中的恶意软件。这样就产生了一个问题恶意软件能够从虚拟机中逃脱出去并且执行远程代码吗?
半月弧
2020/09/01
2.1K0
QEMU 的一些基础知识及QOM(Qemu Object Model)的部分相关源码阅读
QEMU(quick emulator)是一款由Fabrice Bellard等人编写的免费开源的可执行硬件虚拟化的(hardware virtualization)开源托管虚拟机(VMM)。还可以为user-level的进程执行CPU仿真,进而允许了为一种架构编译的程序在另外一种架构上面运行。
用户1423082
2024/12/31
4930
QEMU 的一些基础知识及QOM(Qemu Object Model)的部分相关源码阅读
CTF QEMU 虚拟机逃逸之HITB-GSEC-2017-babyqemu
我们用ida载入,由于有符号的,函数那直接搜索hitb就出现相关函数了,通过初始化函数即下面的init函数可以看到device id是0x2333(记住WORD1这个是device id就行),还有设置了pci_hitb_realize也是初始化的,pci_hitb_uninit就是跟pci_hitb_realize相反的操作,进行destroy,del等操作
用户1423082
2024/12/31
1150
CTF QEMU 虚拟机逃逸之HITB-GSEC-2017-babyqemu
virtio详细介绍和1.1新功能
virtio是一种实践出来的技术,并且最终标准化,virtio是一种通用的虚拟化设备模拟标准,得到了大部分guest操作系统和hypervisor的支持,方便guest操作系统和hypervisor之间任意互相匹配。virtio出现之前hypervisor各有各的IO设备模拟方案,并在guest操作系统中大量合入驱动代码,导致一片混乱,后来xen中出来了部分virtio思想,在kvm中实现并且发扬光大,发表了论文《virtio: Towards a De-Facto Standard For Virtual I/O Devices》,论文促使virtio形成了正式标准。virtio标准最早是0.9.5版本(Virtio PCI Card Specification Version 0.9.5),于2012年形成了draft,并没有正式发布,继续发展,2016年发布了1.0版本(Virtual I/O Device (VIRTIO) Version 1.0),2019年发布了1.1版本(Virtual I/O Device (VIRTIO) Version 1.1)。
惠伟
2021/04/27
4.5K0
virtio 虚拟化系列之一:从 virtio 论文开始(文末有福利~)
SmartX是中国领先的超融合产品与企业云解决方案提供商,拥有国内最顶尖的分布式存储和超融合架构研发团队,在分布式存储、虚拟化计算、微服务、容器、前端开发、自动化测试等领域都做着行业最前沿的实践。现正在招兵买马,看完请点击左下角阅读原文查看福利哦~
Linux阅码场
2019/07/08
2.4K0
i.MX283开发板SPI驱动——RC522
内核版本:2.6.35 Linux下SPI驱动和I2C驱动很类似,他们都是一种总线,且都不支持热拔插,因为一般情况下spi或者i2c设备都是直接焊接在板子上的,不像USB设备那样随时插拔,所以根据总线——设备——驱动模型,spi和i2c设备都可以通过xxx_board_info结构体进行注册,Linux下spi驱动的架构如下:
知否知否应是绿肥红瘦
2025/02/19
1380
i.MX283开发板SPI驱动——RC522
MIT 6.828 操作系统工程 Lab6: e1000 网络驱动程序
lab6 实际上并没有想象中那么难,代码量很少,主要是需要理解网卡外设的运作方式。
云微
2023/02/24
6150
MIT 6.828 操作系统工程 Lab6: e1000 网络驱动程序
6.S081/6.828: xv6源码分析--networking
目的主机收到报文后会自底而上,层层处理,每一层header包含下一步处理的协议类型。
冰寒火
2022/11/20
1.1K0
Intel FPGA 100G VF(IFCVF) DPDK用户态VDPA设备probe探测流程
callfd: host侧IO处理完成后, 如果是split vring, 则将结果写入vring used字段, 然后写callfd通知qemu/guest
晓兵
2024/08/04
3820
Intel FPGA 100G VF(IFCVF) DPDK用户态VDPA设备probe探测流程
在QEMU-KVM环境下部署Oracle 19.16 RAC
KVM环境和其他虚拟化或真实生产最大差异主要就是在实施前期准备工作上: 具体在 DB节点 和存储环境 的准备工作上有差异,本文会详细说明。
Alfred Zhao
2023/01/10
1.8K0
CTF QEMU 虚拟机逃逸之XNUCA 2018 SSD
通过查看xnuca_class_init函数,可以知道xnuca对应00:04.0 Class 00ff: 1234:11e9
用户1423082
2024/12/31
700
CTF QEMU 虚拟机逃逸之XNUCA 2018 SSD
CTF QEMU 虚拟机逃逸之Defcon 2018 - EC3
这个题目给的qemu-system-x86_64的符号是被stripped掉了,相当于增加了点难度
用户1423082
2024/12/31
930
CTF QEMU 虚拟机逃逸之Defcon 2018 - EC3
一文讲透CRC校验码-附赠C语言实例
CRC(Cyclic Redundancy Checksum)是一种纠错技术,代表循环冗余校验和。
C语言与CPP编程
2021/07/27
12.6K1
一文讲透CRC校验码-附赠C语言实例
M-Arch(2)第一个示例:串口和CRC
先把背景交代一下,上一篇讲了下基本的设计意图和框架,实际上整体框架已经有了,这篇先把整个框架再描述下,再来实现我们的第一个例子。
滚神大人
2021/09/10
4480
CTF QEMU 虚拟机逃逸之强网杯2019线上赛qwct
一开始在16.04,18.04上尝试启动,结果安装的依赖库好像版本不太符合要求,最终在19.04上面安装依赖库即可启动了,看来强网杯还是紧跟最新的系统啊
用户1423082
2024/12/31
450
CTF QEMU 虚拟机逃逸之强网杯2019线上赛qwct
MIT 6.S081 Lab 11 -- NetWork - 下
上一节我们总体介绍了一下手册中有关数据接收和传输的章节,本节借助上节的基础来完成lab的具体代码实现。
大忽悠爱学习
2023/10/11
3830
MIT 6.S081 Lab 11 -- NetWork - 下
DPU/IPU SPDK存储卸载之用户态vfio(vfio_user)
IPU: Infrastructure Processing Units (lPUs), 基础设施处理单元(硬件卡), 如存储处理/卸载到IPU
晓兵
2024/09/01
6962
DPU/IPU SPDK存储卸载之用户态vfio(vfio_user)
Linux用户态协议栈与DPDK构建高性能应用
这里使用了已经搭建好的dpdk环境,dpdk的搭建过程网上有很多教程可以参考,后面有空再做一篇dpdk环境搭建文章吧! (1)检查网卡状态
Lion 莱恩呀
2024/09/15
5780
Linux用户态协议栈与DPDK构建高性能应用
CTF QEMU 虚拟机逃逸总结
来源:https://kirin-say.top/2019/11/06/QEMU-Escape-in-Cloud-Security-Game/
用户1423082
2024/12/31
1200
kvm虚拟化进阶 原
前面学习了kvm虚拟化的一些基础操作,本节整理一下kvm快照、扩容等等相关的内容。
阿dai学长
2019/04/03
1.1K0
相关推荐
虚拟机逃逸--QEMU案例学习
更多 >
交个朋友
加入[数据] 腾讯云技术交流站
获取数据实战干货 共享技术经验心得
加入[后端] 腾讯云技术交流站
后端架构设计 高可用系统实现
加入数据技术工作实战群
获取实战干货 交流技术经验
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档