【JavaEE】SpringBoot框架,2024年最新一个回答引发热烈讨论

单表CRUD操作

=======================================================================

以书籍表为例子,进行书籍的增删改查。数据库如下所示。

在这里插入图片描述

配置数据库驱动连接


  • pom.xml文件的<dependencies>标签中加入如下依赖。

<dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-jdbc</artifactId>

        </dependency>

        <dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-thymeleaf</artifactId>

        </dependency>

        <dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-web</artifactId>

        </dependency>

        <dependency>

            <groupId>org.mybatis.spring.boot</groupId>

            <artifactId>mybatis-spring-boot-starter</artifactId>

            <version>2.1.4</version>

        </dependency>



        <dependency>

            <groupId>mysql</groupId>

            <artifactId>mysql-connector-java</artifactId>

            <scope>runtime</scope>

        </dependency>

        <dependency>

            <groupId>org.projectlombok</groupId>

            <artifactId>lombok</artifactId>

            <optional>true</optional>

        </dependency>

        <dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-test</artifactId>

            <scope>test</scope>

            <exclusions>

                <exclusion>

                    <groupId>org.junit.vintage</groupId>

                    <artifactId>junit-vintage-engine</artifactId>

                </exclusion>

            </exclusions>

        </dependency>



  • 创建配置文件application.yml

在这里插入图片描述

  • 在配置文件中配置数据库驱动、端口号、路径等。

server:

  servlet:

    context-path: /springbootdemo   # 配置路径

  port: 8081  # 配置端口号

spring:

  datasource:

    username: root    # 数据库连接用户名

    password: 123456  # 数据库连接密码

    # 配置数据库    bookstore 是数据库名称

    url: jdbc:mysql://localhost:3306/bookstore?useUnicode=true&characterEncoding=utf-8&useSSL=true&serverTimezone=UTC

    # 配置JDBC驱动

    driver-class-name: com.mysql.cj.jdbc.Driver



mybatis:

  mapper-locations: classpath:mapper/*.xml    # 配置数据库操作文件

  type-aliases-package: com.hnucm.springbootdemo.model  # 配置数据来源



#showSql

logging:

  level:

    com:

      hnucm:

        springboot: debug



实现单表增删改查


传参:

  • 如果是json格式的,使用@RequestBody注释;

  • 如果是/格式的,使用@PathVariable(value = "")注释;

  • 如果是?格式的,使用@RequestParam(value = "")注释。

构建工程结构

  • 创建一个model文件夹,用于存放数据类。注:下列创建方式都一样。

在这里插入图片描述

  • 创建一个dao文件夹,用于存放抽象接口。

  • 创建一个controller文件夹,用于存放控制器类。

  • 创建一个service文件夹,用于存放逻辑接口和具体实现。

  • 创建一个tools文件夹,用于存放错误信息提示和消息通知工具类。

  • resources文件夹中创建mapper文件夹,用于存放数据库操作文件。

在这里插入图片描述

  • 最终形成的工程结构如下图所示。

在这里插入图片描述

增加数据

  1. 根据数据库表的格式在model文件夹下创建数据类对象——Book

@Data

//采用注解,默认存在get和set方法

public class Book {

    //数据类型和名称尽量和数据库表中的一致

    private int bno;

    private String bname;

    private String bauth;

}



  1. dao文件夹下创建抽象接口,内部加入增加数据的方法。

@Mapper   //采用注解,表示其为抽象接口类

public interface BookMapper {

    //增加数据方法

    //传入的是整本书籍的数据

    int addBook(Book book);

}



  1. service文件夹下创建逻辑接口和具体实现类,利用dao层抽象接口实现具体功能。

//逻辑接口

public interface BookService {

    int addBook(Book book);

}




@Service   //利用注解证明其为具体实现类

public class BookServiceImpl implements BookService{

    //利用dao层抽象接口方法实现

    @Autowired

    BookMapper bookMapper;

    

    @Override

    public int addBook(Book book) {

        //实现功能

        return bookMapper.addBook(book);

    }

}



  1. 创建工具类,里面存储异常信息和通知消息。

package com.huncm.springbootdemo.tools;



import java.util.HashMap;

import java.util.Map;



/**

 * 返回数据封装类

 */

public class Result extends HashMap<String, Object> {

    private static final long serialVersionUID = 1L;



    public Result() {

        put("code", 0);

        put("msg", "success");

    }



    public static Result error() {

        return error(500, "未知异常,请联系管理员");

    }



    public static Result error(String msg) {

        return error(500, msg);

    }



    public static Result error(int code, String msg) {

        Result r = new Result();

        r.put("code", code);

        r.put("msg", msg);

        return r;

    }



    public static Result ok(String msg) {

        Result r = new Result();

        r.put("msg", msg);

        return r;

    }



    public static Result ok(Map<String, Object> map) {

        Result r = new Result();

        r.putAll(map);

        return r;

    }



    public static Result ok() {

        return new Result();

    }



    public Result put(String key, Object value) {

        super.put(key, value);

        return this;

    }

}




package com.huncm.springbootdemo.tools;



import org.springframework.web.bind.annotation.ControllerAdvice;

import org.springframework.web.bind.annotation.ExceptionHandler;

import org.springframework.web.bind.annotation.ResponseBody;



import java.sql.SQLException;



@ControllerAdvice

public class MyControllerAdvice {



    @ResponseBody

    @ExceptionHandler(value = SQLException.class)

    public Result sqlHandler(Exception ex) {

        return Result.error(501,ex.getMessage());

    }



    /**

     * 全局异常捕捉处理

     *

     * @param ex

     * @return

     */

    @ResponseBody

    @ExceptionHandler(value = Exception.class)

    public Result errorHandler(Exception ex) {

        return Result.error(500,ex.getMessage());

    }



}



  1. controller文件夹下创建控制器类,进行接口的实现,利用工具类提示信息。

@RestController //控制器注解

@CrossOrigin  //跨域注解

public class BookController {

    @Autowired

    BookService bookService;



    @RequestMapping("addBook")

    public Result addBook(Book book) {

        //打印需要加入的书籍信息

        System.out.println(book);

        //利用服务层接口方法进行功能实现

        int result = bookService.addBook(book);

        //判断是否成功

        if(result > 0){

            return Result.ok("增加书籍成功");

        }

        return Result.error("增加书籍失败");

    }

}



  1. mapper文件夹下创建数据库操作文件,进行数据库操作,真正实现功能。

在这里插入图片描述


<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.huncm.springbootdemo.dao.BookMapper">



    <!--  增加操作 使用insert

          id 数据接口方法名

          parameterType 是传入的数据类型

          中间是SQL语句进行数据库操作 -->


**自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。**

**深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**

**因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。**
![img](https://img-blog.csdnimg.cn/img_convert/9b640c1947f5c255b5f821b76b35f016.png)
![img](https://img-blog.csdnimg.cn/img_convert/a3cf27827061c7acb582990dec8dd8c2.png)
![img](https://img-blog.csdnimg.cn/img_convert/5d34aa0cd19b9d8c70cda0b6773e50ac.png)
![img](https://img-blog.csdnimg.cn/img_convert/61be3d8c38de2b569b3f927a2da9418b.png)
![img](https://img-blog.csdnimg.cn/img_convert/750418fcbc0b2eeca2bce0d1b36b8711.png)
![img](https://img-blog.csdnimg.cn/img_convert/6ef8a9b412bc20cd40e439bcaaa602e6.png)
![img](https://img-blog.csdnimg.cn/13f2cb2e05a14868a3f0fd6ac81d625c.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!**

**由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新**

**如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)**
![img](https://img-blog.csdnimg.cn/img_convert/995ddbd2180c4b4b060066e028dc1679.png)



最后为了帮助大家深刻理解**Android相关知识点的原理以及面试相关知识**,这里放上我搜集整理的**2019-2021BATJ 面试真题解析**,我把大厂面试中**常被问到的技术点**整理成了PDF,包知识脉络 + 诸多细节。

节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

**《960全网最全Android开发笔记》**

![](https://img-blog.csdnimg.cn/img_convert/a23f2e803000deb8fac9630762fa0979.webp?x-oss-process=image/format,png)

**《379页Android开发面试宝典》**

历时半年,我们整理了这份市面上最全面的安卓面试题解析大全 
包含了腾讯、百度、小米、阿里、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。熟悉本文中列出的知识点会大大增加通过前两轮技术面试的几率。

如何使用它? 

1.可以通过目录索引直接翻看需要的知识点,查漏补缺。
2.五角星数表示面试问到的频率,代表重要推荐指数

![](https://img-blog.csdnimg.cn/img_convert/3c3576f8ef8f7079f41442a16497d909.webp?x-oss-process=image/format,png)

**《507页Android开发相关源码解析》**

只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。

真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。

![](https://img-blog.csdnimg.cn/img_convert/5f042fee3869d025cb61f54acded2fa9.webp?x-oss-process=image/format,png)

**腾讯、字节跳动、阿里、百度等BAT大厂 2019-2021面试真题解析**

![](https://img-blog.csdnimg.cn/img_convert/9c220d2c99ff34d8457c42322563b806.webp?x-oss-process=image/format,png)

>资料太多,全部展示会影响篇幅,暂时就先列举这些部分截图



**一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
![img](https://img-blog.csdnimg.cn/img_convert/bfdd7b42efe28ffb4517dbc4c248c927.png)
、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。熟悉本文中列出的知识点会大大增加通过前两轮技术面试的几率。

如何使用它? 

1.可以通过目录索引直接翻看需要的知识点,查漏补缺。
2.五角星数表示面试问到的频率,代表重要推荐指数

[外链图片转存中...(img-MkrMgSND-1712767597614)]

**《507页Android开发相关源码解析》**

只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。

真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。

[外链图片转存中...(img-32OHOvgg-1712767597615)]

**腾讯、字节跳动、阿里、百度等BAT大厂 2019-2021面试真题解析**

[外链图片转存中...(img-JBvJIiNY-1712767597615)]

>资料太多,全部展示会影响篇幅,暂时就先列举这些部分截图



**一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
[外链图片转存中...(img-gslrSdGx-1712767597615)]
  • 7
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值