SpringBoot-综合案例

综合案例

1. 整合Mybatis

1.1 数据准备

CREATE DATABASE springboot;
USE springboot;

-- 创建学生表
DROP TABLE IF EXISTS tb_student;
CREATE TABLE tb_student (
                              id bigint(20) NOT NULL primary key AUTO_INCREMENT COMMENT '主键ID',
                              number varchar(20) NOT NULL UNIQUE COMMENT '学号',
                              user_name varchar(20) NOT NULL COMMENT '姓名',
                              birthday DATE NOT NULL COMMENT '生日',
                              address varchar(11) DEFAULT NULL COMMENT '地址'
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


INSERT INTO tb_student VALUES (null,'hm001','张三','1995-05-05','北京市昌平区');
INSERT INTO tb_student VALUES (null,'hm002','李四','1996-06-06','北京市海淀区');
INSERT INTO tb_student VALUES (null,'hm003','王五','1997-07-07','北京市朝阳区');
INSERT INTO tb_student VALUES (null,'hm004','赵六','1998-08-08','北京市丰台区');
INSERT INTO tb_student VALUES (null,'hm005','周七','1999-09-09','北京市顺义区');
INSERT INTO tb_student VALUES (null,'hm006','孙悟空','2000-01-01','花果山水帘洞');
INSERT INTO tb_student VALUES (null,'hm007','猪八戒','2001-02-02','高老庄翠兰家');
INSERT INTO tb_student VALUES (null,'hm008','沙和尚','2002-03-03','流沙河河底');
INSERT INTO tb_student VALUES (null,'hm009','唐玄奘','2003-04-04','东土大唐');

1.2 添加依赖

  <!--父工程-->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.7.3</version>
    </parent>


    <dependencies>
        <!--web依赖启动器-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-configuration-processor</artifactId>
            <optional>true</optional>
        </dependency>

        <!--引入junit依赖启动器-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>

        <!--mysql-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>

        <!--加入mybatis的启动器,这是mybatis公司提供的-->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.1.1</version>
        </dependency>
    </dependencies>

1.3 创建实体类

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Student {
    private Long id;
    private String number;
    private String userName;
    private Date birthday;
    private String address;
}

1.4 创建接口

@Mapper
public interface StudentMapper {
    @Select("select * from  tb_student")
    List<Student> findAll();
}

1.5 添加接口扫描

在启动类上使用@MapperScan注解指定mapper接口所在的包

//注意一下:启动类的位置必须位于其他类的父包中
@SpringBootApplication//启动类专用注解
@MapperScan("com.itheima.mapper")  //指定mapper接口所在的包
public class SpringbootDemoApplication {

    public static void main(String[] args) {
        //参数1.启动类.class
        //参数2:args
        SpringApplication.run(SpringbootDemoApplication.class,args);
    }
}

1.6 添加配置文件

在配置文件application.yaml中添加数据源和mybatis的配置

spring:
  datasource: #数据源配置(springboot内置连接池对象HiKariCP)
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/springboot
    username: root
    password: chuyin
mybatis: #mybatis简单配置
  configuration:
    map-underscore-to-camel-case: true  #开启驼峰式映射

1.7 测试

@SpringBootTest //测试类注解
public class UserMapperTest {
 //这个爆红不影响使用,如果要取消,可以在Mapper接口上添加@Mapper注解
    @Autowired
    private StudentMapper studentMapper;

    @Test
    public void testFindAll() {
        studentMapper.findAll().forEach(e-> System.out.println(e));
    }
}

2. 列表查询

2.1 添加service层

添加业务层的接口和实现,然后在类中注入mapper对象,并调用其方法

public interface StudentService {

    //查询所有
    List<Student> findAll();
}

@Service
public class StudentServiceImpl implements StudentService {

    @Autowired
    private StudentMapper studentMapper;

    @Override
    public List<Student> findAll() {
        return studentMapper.findAll();
    }
}

2.2 添加controller

添加表示层实现类,然后在类中注入service对象,并调用其方法

@RestController
public class StudentController {

    @Autowired
    private StudentService studentService;

    //查询所有
    @GetMapping("/student")
    public List<Student> findAll(){
        List<Student> studentList = studentService.findAll();
        return studentList;
    }
}

3. 统一返回结果

3.1 思路

为了前后端更好的交互,我们应当对后端返回的数据格式做一定的约束,使得每次返回的数据格式基本一致

3.2 添加结果类

结果类就是我们规定好的一个规范类,以后后端返回的所有内容都要封装到这个类中返回

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Result {
    private Integer code; //响应码:1.代表成功;0.代表失败
    private String msg;   //响应信息,描述字符串
    private Object data;  //返回的数据


    //增删改  成功响应
    public static Result success(){
        return new Result(1,"success",null);
    }

    //查询 成功响应
    public static Result success(Object data){
        return new Result(1,"success",data);
    }

    //失败响应
    public static Result error(String msg){
        return new Result(0,msg,null);
    }
}

3.3 修改controller

修改查询方法,将查询到的结果列表封装到结果类中再返回

@RestController
public class StudentController {

    @Autowired
    private StudentService studentService;

    //查询所有
    @GetMapping("/student")
    public Result findAll(){
        List<Student> studentList = studentService.findAll();
        return Result.success(studentList);
    }
}

3.4 添加前端页面

在resources/static中添加前端页面

3.5 效果查看

访问首页,观察效果
请添加图片描述

3.6 调整返回时间格式

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Student {
    private Long id;
    private String number;
    private String userName;
    @JsonFormat(pattern = "yyyy-MM-dd",timezone = "Asia/Shanghai")
    private Date birthday;
    private String address;
}

4. 新增学生

4.1 controller

    //新增
    @PostMapping("/student")
    public Result save(@RequestBody Student student){
        studentService.save(student);
        return Result.success();
    }

4.2 service

接口
    //新增
    void save(Student student);
====================================================================================================
实现类
    @Override
    public void save(Student student) {
        studentMapper.save(student);
    }

4.3 mapper

    @Insert("insert into tb_student values (null,#{number},#{userName},#{birthday},#{address})")
    void save(Student student);

5. 回显学生

5.1 controller

    //根据id查询
    @GetMapping("/student/{id}")
    public Result findById(@PathVariable("id") Integer id){
        Student student = studentService.findById(id);
        return Result.success(student);
    }

5.2 service

接口
    //根据id查询
    Student findById(Integer id);
====================================================================================================
实现类
    @Override
    public Student findById(Integer id) {
        return studentMapper.finById(id);
    }

5.3 mapper

    @Select("select * from tb_student where id = #{id}")
    Student finById(Integer id);

6. 修改学生

6.1 controller

    //修改
    @PutMapping("/student")
    public Result update(@RequestBody Student student){
        studentService.update(student);
        return Result.success();
    }

6.2 service

接口
    //修改
    void update(Student student);
====================================================================================================
实现类
    @Override
    public void update(Student student) {
        studentMapper.update(student);
    }

6.3 mapper

    @Update("update tb_student  set number= #{number},user_name= #{userName},birthday= #{birthday},address= #{address} where id= #{id}")
    void update(Student student);

7. 删除学生

7.1 controller

    //删除
    @DeleteMapping("/student/{id}")
    public Result deleteById(@PathVariable("id") Integer id){
        studentService.deleteById(id);
        return Result.success();
    }

7.2 service

接口
    //删除
    void deleteById(Integer id);
====================================================================================================
实现类
    @Override
    public void deleteById(Integer id) {
        studentMapper.deleteById(id);
    }

7.3 mapper

    @Delete("delete from tb_student where id = #{id}")
    void deleteById(Integer id);
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本项目示例基于spring boot 最新版本(2.1.9)实现,Spring BootSpring Cloud 学习示例,将持续更新…… 在基于Spring BootSpring Cloud 分布微服务开发过程中,根据实际项目环境,需要选择、集成符合项目需求的各种组件和积累各种解决方案。基于这样的背景下,我开源了本示例项目,方便大家快速上手Spring BootSpring Cloud 。 每个示例都带有详细的介绍文档、作者在使用过程中踩过的坑、解决方案及参考资料,方便快速上手为你提供学习捷径,少绕弯路,提高开发效率。 有需要写关于spring bootspring cloud示例,可以给我提issue哦 ## 项目介绍 spring boot demo 是一个Spring BootSpring 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 BootSpring平台及第三方库提供开箱即用的设置,这样你就可以有条不紊地开始。多数Spring Boot应用只需要很少的Spring配置。 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Sprin
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值