总体思路:先写dao,再写service
生成对应的模板
data:image/s3,"s3://crabby-images/07f08/07f082ea5ea1bec9e5d3988361195e05e1677382" alt=""
2.写TestCotroller类,类上写@RestCotroller注解
3.TestCotroller类里写方法,方法上写@GetMapping("/方法名")注解
data:image/s3,"s3://crabby-images/6be3c/6be3ce4b54fac63670bf9ef6694b9d633daa2d1d" alt=""
4.不一定要写GetMapping,具体看做什么操作
data:image/s3,"s3://crabby-images/d33cd/d33cd8a6752fdea82feae10960f53e3da5265f20" alt=""
5.服务跑起来,试试效果
data:image/s3,"s3://crabby-images/9f18e/9f18eb4a6abfe04aad80f94a0675623cf5566ac1" alt=""
6.安装MySQL数据库,网上很多资料,可以参考https://www.cnblogs.com/zhangkanghui/p/9613844.html
7.建立测试库
CREATE DATABASE test CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
data:image/s3,"s3://crabby-images/df915/df915e2ce2b8426ae1e27c8b89d0f47cb20bf731" alt=""
8.建表
CREATE TABLE student( id int AUTO_INCREMENT PRIMARY KEY,name VARCHAR(50) NOT NULL,email VARCHAR(100) NOT NULL,age int );
data:image/s3,"s3://crabby-images/d0d02/d0d02a9f395973d9d0f20523ee34b308345981e1" alt=""
9.返回IDEA,写dao层,dao层都是接口,负责与数据库的交互。加上注解@Restpository
注解作用:告诉SpringBoot框架,这是Repository层的代码。底层原理是依赖注入,将代码加入容器中,让框架能扫描到。
实现要继承JpaRepository,因为父类JpaRepository几乎包含了对数据库的增删查改。
data:image/s3,"s3://crabby-images/274be/274be9d75d4cc2f61c0b066ac8cfdd555157439c" alt=""
10.在dao层中建一个student类,这个类用来映射数据库中的student表。
注解:
@Entity
@Table(name="student")
告诉SpringBoot框架这个类用来映射数据库中的student表。
注解:
@Id,告诉SpringBoot框架,它是一个自增的主键。
@Colum(name="age"),写在字段头上,告诉SpringBoot框架,java中的字段对应数据库中哪个字段。如果相同可以不写。
@GeneratedValue(strategy="IDENTITY"),写在字段头,告诉SpringBoot框架,id字段是数据库自增的字段。
data:image/s3,"s3://crabby-images/d3f6e/d3f6e3c94111f7746f84cdd7f57da3d1799ea915" alt=""
如果不知道注解的参数,可以按住crtl键,鼠标左键进去看。
10.返回去写StudentRepository接口,给父类的泛类型添上值。
data:image/s3,"s3://crabby-images/55f72/55f720866131cf83e0f836ab99c93267ecb1214f" alt=""
11.开始写service层
面向接口编程,先写接口,再写实现。
注解:@Service在实现层,让SpringBoot框架来注入。
@Override:告诉SpringBoot的框架,这个方法是实现接口的。(自动带出)
声明StudentRepository接口,使用@AutoWired注入
@Autowired:告诉SpringBoot框架,StudentRepository接口被注入到实现类中。
data:image/s3,"s3://crabby-images/ecf0f/ecf0f5f2668e7be61dadc94c17b43a4da973c097" alt=""
12.开始写Controller层的代码。
注入@RestController,告诉SpringBoot框架这个是Controller层。
因为是查询,所以再注入@GetMapping。
@PathVariable:对应路径变量。
@Autowired代表:注入Service层的代码
总结,可以看到,咱们先写了dao层,然后写service层的时候,使用了这个注解@Autowired,这是把dao层的代码注入进Service层,然后Controller层也写了这个注解@Autowired,这就是Service层的代码又注入到Controller层。
data:image/s3,"s3://crabby-images/4a31b/4a31b319bd95bc1385badaf79c78a2526179aeb4" alt=""
data:image/s3,"s3://crabby-images/1b123/1b12348690ee4796c7c2e52bbb10cd5f33f53d47" alt=""
13.配置数据库url
data:image/s3,"s3://crabby-images/fd8f9/fd8f96347b44966f148863bfa1bcd607ba15fb70" alt=""
14.手工插数据进mysql数据库
data:image/s3,"s3://crabby-images/d5c6c/d5c6cb8e8dfed09d8308bbae73c9500e119fab74" alt=""
15.启动项目,网页输出json
data:image/s3,"s3://crabby-images/e6d13/e6d136db84eca6a34cae1a7fb4bdd81e72238004" alt=""
data:image/s3,"s3://crabby-images/27256/272564e3a0fe514a5ec4a627fb06e4c77bc78e76" alt=""