springboot项目案例-curd功能实现

本文详细介绍了如何使用SpringBoot框架整合MyBatis,包括创建项目、数据库配置、实体类定义、Mapper接口及XML文件编写等关键步骤,并通过具体案例展示了CRUD功能的实现过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  本篇文章主要记录第一次利用springboot创建项目的步骤以及一些知识问题总结。

创建springboot项目

在这里插入图片描述

  • 导入项目依赖
    在这里插入图片描述
    在这里插入图片描述

整合mybatis

1.创建数据库与表

create database springboot;
create table department(
	id int auto_increment, 
	departmentName varchar(50), 
	primary key(id)
) DEFAULT CHARSET=utf8;

create table empolyee( 
	 id int auto_increment, 
	 name varchar(50),  
	 email vachar(50), 
	 gender int,
	 uid int,
	 birth Date,
	 primary key(id),
	 foreign key(uid) references department(id)
	)DEFAULT CHARSET=utf8;
  • 插入几条数据
insert into department(departmentName) values('运营部''宣传部','市场部','后勤部')

insert into employee(name,email,gender,uid,birth) values
('jack1''563246432@qq.com','0','1','2004-2-24'),
('jack2''534435532@qq.com','0','1','2020-2-14'),
('jack3''563222242@qq.com','0','1','2012-2-4'),
('jack4''363246432@qq.com','0','1','2008-3-4');

2.连接数据库连接池

  • 在application配置文件中配置连接池的四大属性(username,password,url,driver-class-name),springboot自动配置连接池,默认使用hikari连接池。
    在这里插入图片描述
    注意:由于springboot默认使用的是8.0+版本的驱动,所以url配置时需要添加时区设置(serverTimezone=UTC)

3.创建pojo实体类

  • 记得导入lombok依赖
    在这里插入图片描述
    在这里插入图片描述

4.创建mapper接口与mappe.XML文件

  • 部门与员工的mapper接口
    在这里插入图片描述
    在这里插入图片描述

  • mapper接口的xml文件配置

    • resource文件夹下的mapper文件下创建xml文件

    员工数据库sql语句XML文件配置:在这里插入图片描述
    部门数据库sql语句xml文件配置:
    在这里插入图片描述

5.application配置文件中整合mybatis

在这里插入图片描述

CURD功能实现

1.显示全部员工

  • 创建controller请求,页面返回所有员工对象
      因为员工表有外键约束,需要将员工的外键信息也返回页面,即部门信息,所以可以创建一个属性为员工对象与部门对象实体类对象,这样只需返回此对象给页面即可获取到员工以及部门信息。
    实体类对象:
    在这里插入图片描述
    创建一个工具类用于获取到多个实体类对象或者一个实体类对象:
    在这里插入图片描述
    controller请求代码编写:
    在这里插入图片描述

  • 编写list页面获取遍历数据信息
    导入thymeleaf命名空间
    在这里插入图片描述
    利用thymeleaf模板引擎foreach遍历信息
    在这里插入图片描述

2.添加员工功能

在list页面添加新增员工按钮功能;
在这里插入图片描述
跳转添加页面请求以及添加员工请求:
在这里插入图片描述
编写add添加页面,实现添加员工功能:
导入thymeleaf模板引擎命名空间
在这里插入图片描述
编写from表单提交添加员工信息:
  表单提交请求路径“/emps”,方式为post方式。get方式的“/emsps”为跳转add页面请求。
在这里插入图片描述
在这里插入图片描述

3.修改员工信息与删除员工功能

在list页面遍历的每个员工后面添加编辑与删除操作:
在这里插入图片描述

  • 编辑功能实现

编写跳转页面请求和编辑请求:
在这里插入图片描述
编写update更新页面:
  表单提交员工信息:
在这里插入图片描述
在这里插入图片描述

  • 删除功能实现

编写删除员工请求:
在这里插入图片描述
前端通过from表单的隐藏属性更改请求方式为Delete:
  为了防止表单过重,影响前端页面美观,采用script对表单按钮添加单击事件,从而提交表单(记得在static文件夹下导入静态资源jquery)。
在这里插入图片描述
注意:刚开始使用的id选择器进行编写,发现删除功能只能从上到下删除的bug,然后更改为class属性解决问题,原因是:id具有唯一性,导致每次删除都只能识别出遍历的第一个按钮的单击事件,导致用户不能随机删除某一个员工。

4.查询员工信息功能

编写查询员工请求(采用的是模糊查询name属性):
在这里插入图片描述
list页面添加查询员工from表单:
在这里插入图片描述
提供一个返回所有员工信息页面请求;
在这里插入图片描述

总结:

  springboot项目的curd核心还是mabytis框架的整合,xml文件里的sql语句编写正确,这里的项目并没有使用serveice层,全程只采用了dao层,若要创建新的类对象都需通过注解注入spring容器中,才能识别。

项目示例基于spring boot 最新版本(2.1.9)实现Spring Boot、Spring Cloud 学习示例,将持续更新…… 在基于Spring Boot、Spring Cloud 分布微服务开发过程中,根据实际项目环境,需要选择、集成符合项目需求的各种组件和积累各种解决方案。基于这样的背景下,我开源了本示例项目,方便大家快速上手Spring Boot、Spring Cloud 。 每个示例都带有详细的介绍文档、作者在使用过程中踩过的坑、解决方案及参考资料,方便快速上手为你提供学习捷径,少绕弯路,提高开发效率。 有需要写关于spring boot、spring cloud示例,可以给我提issue哦 ## 项目介绍 spring boot demo 是一个Spring Boot、Spring Cloud的项目示例,根据市场主流的后端技术,共集成了30+个demo,未来将持续更新。该项目包含helloworld(快速入门)、web(ssh项目快速搭建)、aop(切面编程)、data-redis(redis缓存)、quartz(集群任务实现)、shiro(权限管理)、oauth2(四种认证模式)、shign(接口参数防篡改重放)、encoder(用户密码设计)、actuator(服务监控)、cloud-config(配置中心)、cloud-gateway(服务网关)、email(邮件发送)、cloud-alibaba(微服务全家桶)等模块 ### 开发环境 - JDK1.8 + - Maven 3.5 + - IntelliJ IDEA ULTIMATE 2019.1 - MySql 5.7 + ### Spring Boot 模块 模块名称|主要内容 ---|--- helloworld|[spring mvc,Spring Boot项目创建,单元测试](https://github.com/smltq/spring-boot-demo/blob/master/helloworld/HELP.md) web|[ssh项目,spring mvc,过滤器,拦截器,监视器,thymeleaf,lombok,jquery,bootstrap,mysql](https://github.com/smltq/spring-boot-demo/blob/master/web/HELP.md) aop|[aop,正则,前置通知,后置通知,环绕通知](https://github.com/smltq/spring-boot-demo/blob/master/aop/HELP.md) data-redis|[lettuce,redis,session redis,YAML配置,连接池,对象存储](https://github.com/smltq/spring-boot-demo/blob/master/data-redis/HELP.md) quartz|[Spring Scheduler,Quartz,分布式调度,集群,mysql持久化等](https://github.com/smltq/spring-boot-demo/blob/master/quartz/HELP.md) shiro|[授权、认证、加解密、统一异常处理](https://github.com/smltq/spring-boot-demo/blob/master/shiro/HELP.md) sign|[防篡改、防重放、文档自动生成](https://github.com/smltq/spring-boot-demo/blob/master/sign/HELP.md) security|[授权、认证、加解密、mybatis plus使用](https://github.com/smltq/spring-boot-demo/blob/master/security/HELP.md) mybatis-plus-generator|[基于mybatisplus代码自动生成](https://github.com/smltq/spring-boot-demo/blob/master/mybatis-plus-generator) mybatis-plus-crud|[基于mybatisplus实现数据库增、册、改、查](https://github.com/smltq/spring-boot-demo/blob/master/mybatis-plus-crud) encoder|[主流加密算法介绍、用户加密算法推荐](https://github.com/smltq/spring-boot-demo/blob/master/encoder/HELP.md) actuator|[autuator介绍](https://github.com/smltq/spring-boot-demo/blob/master/actuator/README.md) admin|[可视化服务监控、使用](https://github.com/smltq/spring-boot-demo/blob/master/admin/README.md) security-oauth2-credentials|[oauth2实现密码模式、客户端模式](https://github.com/smltq/spring-boot-demo/blob/master/security-oauth2-credentials/README.md) security-oauth2-auth-code|[基于spring boot实现oauth2授权模式](https://github.com/smltq/spring-boot-demo/blob/master/security-oauth2-auth-code/README.md) mybatis-multi-datasource|[mybatis、数据库集群、读写分离、读库负载均衡](https://github.com/smltq/spring-boot-demo/blob/master/mybatis-multi-datasource) template-thymeleaf|[thymeleaf实现应用国际化示例](https://github.com/smltq/spring-boot-demo/blob/master/template-thymeleaf) mq-redis|[redis之mq实现,发布订阅模式](https://github.com/smltq/spring-boot-demo/blob/master/mq-redis) email|[email实现邮件发送](https://github.com/smltq/spring-boot-demo/blob/master/email) jGit|[java调用git命令、jgit使用等](https://github.com/smltq/spring-boot-demo/blob/master/jGit) webmagic|[webmagic实现某电影网站爬虫示例](https://github.com/smltq/spring-boot-demo/blob/master/webmagic) netty|[基于BIO、NIO等tcp服务器搭建介绍](https://github.com/smltq/spring-boot-demo/blob/master/netty) ### Spring Cloud 模块 模块名称|主要内容 ---|--- cloud-oauth2-auth-code|[基于spring cloud实现oath2授权模式](https://github.com/smltq/spring-boot-demo/blob/master/cloud-oauth2-auth-code) cloud-gateway|[API主流网关、gateway快速上手](https://github.com/smltq/spring-boot-demo/blob/master/cloud-gateway) cloud-config|[配置中心(服务端、客户端)示例](https://github.com/smltq/spring-boot-demo/blob/master/cloud-config) cloud-feign|[Eureka服务注册中心、负载均衡、声明式服务调用](https://github.com/smltq/spring-boot-demo/blob/master/cloud-feign) cloud-hystrix|[Hystrix服务容错、异常处理、注册中心示例](https://github.com/smltq/spring-boot-demo/blob/master/cloud-hystrix) cloud-zuul|[zuul服务网关、过滤器、路由转发、服务降级、负载均衡](https://github.com/smltq/spring-boot-demo/blob/master/cloud-zuul) cloud-alibaba|[nacos服务中心、配置中心、限流等使用(系列示例整理中...)](https://github.com/smltq/spring-boot-demo/blob/master/cloud-alibaba) #### Spring Cloud Alibaba 模块 模块名称|主要内容 ---|--- nacos|[Spring Cloud Alibaba(一)如何使用nacos服务注册和发现](https://github.com/smltq/spring-boot-demo/blob/master/cloud-alibaba/README1.md) config|[Spring Cloud Alibaba(二)配置中心多项目、多配置文件、分目录实现](https://github.com/smltq/spring-boot-demo/blob/master/cloud-alibaba/README2.md) Sentinel|[Spring Cloud Alibaba(三)Sentinel之熔断降级](https://github.com/smltq/spring-boot-demo/blob/master/cloud-alibaba/README3.md) Dubbo|[Spring Cloud Alibaba(四)Spring Cloud与Dubbo的融合](https://github.com/smltq/spring-boot-demo/blob/master/cloud-alibaba/README4.md) RocketMQ|[Spring Cloud Alibaba(五)RocketMQ 异步通信实现](https://github.com/smltq/spring-boot-demo/blob/master/cloud-alibaba/README5.md) ### 其它 模块名称|主要内容 ---|--- leetcode|[力扣题解目录](https://github.com/smltq/spring-boot-demo/blob/master/leetcode) ## Spring Boot 概述 Spring Boot简化了基于Spring的应用开发,通过少量的代码就能创建一个独立的、产品级别的Spring应用。 Spring Boot为Spring平台及第三方库提供开箱即用的设置,这样你就可以有条不紊地开始。多数Spring Boot应用只需要很少的Spring配置。 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Sprin
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值