=======================================================================
以书籍表为例子,进行书籍的增删改查。数据库如下所示。
- 在
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
文件夹,用于存放数据库操作文件。
- 最终形成的工程结构如下图所示。
增加数据
- 根据数据库表的格式在
model
文件夹下创建数据类对象——Book
。
@Data
//采用注解,默认存在get和set方法
public class Book {
//数据类型和名称尽量和数据库表中的一致
private int bno;
private String bname;
private String bauth;
}
- 在
dao
文件夹下创建抽象接口,内部加入增加数据的方法。
@Mapper //采用注解,表示其为抽象接口类
public interface BookMapper {
//增加数据方法
//传入的是整本书籍的数据
int addBook(Book book);
}
- 在
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);
}
}
- 创建工具类,里面存储异常信息和通知消息。
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());
}
}
- 在
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("增加书籍失败");
}
}
- 在
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)]