总体思路:先写dao,再写service
生成对应的模板
![](https://img-blog.csdnimg.cn/direct/10f81ba9851b4c9b92a2dfe4edcfae4b.png)
2.写TestCotroller类,类上写@RestCotroller注解
3.TestCotroller类里写方法,方法上写@GetMapping("/方法名")注解
![](https://img-blog.csdnimg.cn/direct/761efeaece9f4263989d9113e50e7e5d.png)
4.不一定要写GetMapping,具体看做什么操作
![](https://img-blog.csdnimg.cn/direct/c6fdd6fcf7a0467c9481950bb0e14326.png)
5.服务跑起来,试试效果
![](https://img-blog.csdnimg.cn/direct/271fce47b0c841708843fa57dea3009c.png)
6.安装MySQL数据库,网上很多资料,可以参考https://www.cnblogs.com/zhangkanghui/p/9613844.html
7.建立测试库
CREATE DATABASE test CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
![](https://img-blog.csdnimg.cn/direct/d66dd7cf01d44cf4bab5ba71495e2a8e.png)
8.建表
CREATE TABLE student( id int AUTO_INCREMENT PRIMARY KEY,name VARCHAR(50) NOT NULL,email VARCHAR(100) NOT NULL,age int );
![](https://img-blog.csdnimg.cn/direct/a4eb396a682d4e9fb04b7e9eca182388.png)
9.返回IDEA,写dao层,dao层都是接口,负责与数据库的交互。加上注解@Restpository
注解作用:告诉SpringBoot框架,这是Repository层的代码。底层原理是依赖注入,将代码加入容器中,让框架能扫描到。
实现要继承JpaRepository,因为父类JpaRepository几乎包含了对数据库的增删查改。
![](https://img-blog.csdnimg.cn/direct/a3ed6dfda1014571b01497a862bf97cb.png)
10.在dao层中建一个student类,这个类用来映射数据库中的student表。
注解:
@Entity
@Table(name="student")
告诉SpringBoot框架这个类用来映射数据库中的student表。
注解:
@Id,告诉SpringBoot框架,它是一个自增的主键。
@Colum(name="age"),写在字段头上,告诉SpringBoot框架,java中的字段对应数据库中哪个字段。如果相同可以不写。
@GeneratedValue(strategy="IDENTITY"),写在字段头,告诉SpringBoot框架,id字段是数据库自增的字段。
![](https://img-blog.csdnimg.cn/direct/689991b96fbe4c68b44023e8515dabf7.png)
如果不知道注解的参数,可以按住crtl键,鼠标左键进去看。
10.返回去写StudentRepository接口,给父类的泛类型添上值。
![](https://img-blog.csdnimg.cn/direct/1063066a229a4c359cffc4288407c9de.png)
11.开始写service层
面向接口编程,先写接口,再写实现。
注解:@Service在实现层,让SpringBoot框架来注入。
@Override:告诉SpringBoot的框架,这个方法是实现接口的。(自动带出)
声明StudentRepository接口,使用@AutoWired注入
@Autowired:告诉SpringBoot框架,StudentRepository接口被注入到实现类中。
![](https://img-blog.csdnimg.cn/direct/6e626732deae4627ae058f9f481e1831.png)
12.开始写Controller层的代码。
注入@RestController,告诉SpringBoot框架这个是Controller层。
因为是查询,所以再注入@GetMapping。
@PathVariable:对应路径变量。
@Autowired代表:注入Service层的代码
总结,可以看到,咱们先写了dao层,然后写service层的时候,使用了这个注解@Autowired,这是把dao层的代码注入进Service层,然后Controller层也写了这个注解@Autowired,这就是Service层的代码又注入到Controller层。
![](https://img-blog.csdnimg.cn/direct/bd04809ae7514d4ca6b326d7b7b58c59.png)
![](https://img-blog.csdnimg.cn/direct/e33ac2ff17a04001930f81901ff78de1.png)
13.配置数据库url
![](https://img-blog.csdnimg.cn/direct/8dee3f48438d455cbad3a0c3b87ae02b.png)
14.手工插数据进mysql数据库
![](https://img-blog.csdnimg.cn/direct/83048c1f2a6541d295125bd728a18d6e.png)
15.启动项目,网页输出json
![](https://img-blog.csdnimg.cn/direct/a70815bb803c41a3b488e459e656365b.png)
![](https://img-blog.csdnimg.cn/direct/7a68a30627b7414f8940bfe570281d3b.png)