阶段一-01.万丈高楼,地基首要-第2章 单体架构设计与准备工作-2-21 基于通用Mapper基于Rest编写api接口-1
基于rest service的一些增删改查的操作。
数据库内预先创建的表
这个表是用来给大家做演示用的
id为主键。设置为自增长。
逆向生成代码
运行,生成代码
运行的控制台输出
可以看到相关的代码已经生成了
拷贝相关生成的代码。mapper工程拷贝两个 一个stuMapper类还有一个xml映射类,
pojo是放在pojo的工程内的
注意逆向工具生成的注意事项
逆向生成的resultMap是帮我们做映射关系的
映射关系是映射到这个Stu的的pojo类
假设我们再次运行生成代码的类
在下面又追加了一个resultMap。id都是叫做BaseresultMap。也就是生成的代码是追加式的。如果多次生成了,要注意我们生成的xml文件里面多生成的resultMap。
在一个映射里面也就是RsultMap的id也保证唯一。
编写Service层
在service工程下创建包
创建service类
接口类里面,定义四个基本的增删盖茶的方法。
public interface StuService { public Stu getStuInfo(int id); public void saveStu(); public void updateStu(int id); public void deleteStu(int id); }
创建实现类的包
创建srevice的实现类
实现接口的类。(Alt+Enter回车)
service是需要被容器扫描到的。所以这里要用注解@Service
实现接口的方法
注入stuMapper。下面有个红色的波浪线。提示无法注入,找不到StuMapper .这里暂时先不用管。
我们现在用的Mapper是通用的mapper,它帮我们封装了很多方法。
输入stuMapper然后点,点就点出来很多方法。
select相关的
controller创建
复制HelloController创建一个新的StuFooController
实现类加上事物的支持。
maven install
启动api测试
在这里报错了
没有找到注入的stuMapper
不是因为 这里的红线的问题。
api的启动类里面默认会把com.imooc包下的类,子包的相关的类都会被扫描到。但是对于我们的mapper来讲的话,也是需要去扫描的。是让MyBatis去扫描的。
所以我们需要再加上一个注释。@MapperScan
一定要注释是tk.mybatis.spring.annotation这个包下的。
指明通用mapper类的位置。我们只需要复制包名
再次运行测试
这样就启动成功了。
请求参数的id是放在路径上的。所以它是一种路径参数。
在后端的话,我们需要做到一一的映射。这里的id需要做到请求参数传递。
问号的方式传递参数 就不会报异常了。
在数据库表内加一条数据
刷新前端页面,查询到了刚才条件的那条数据
自己遇到的错误
改成8.0.17版本
java.sql.SQLNonTransientConnectionException: Could not create connection to database server. Attempted reconnect 3 times. Giving up. at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:110) ~[mysql-connector-java-8.0.17.jar:8.0.17] at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97) ~[mysql-connector-java-8.0.17.jar:8.0.17] at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:89) ~[mysql-connector-java-8.0.17.jar:8.0.17] at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:63) ~[mysql-connector-java-8.0.17.jar:8.0.17] at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:73) ~[mysql-connector-java-8.0.17.jar:8.0.17]
Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.、
驱动的类名改成:com.mysql.cj.jdbc.Driver
报错:The server time zone value
把数据库链接字符串后面加上:&serverTimezone=UTC
最终数据库链接字符串:
jdbc:mysql://localhost:3306/foodie-shop-dev?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=UTC
数据库链接地址修改
这个是代码生成器的项目里面用的数据库链接字符串
jdbc:mysql://localhost:3306/foodie-shop-dev?characterEncoding=UTF-8&autoReconnect=true&zeroDateTimeBehavior=convertToNull&useUnicode=true&useSSL=false&serverTimezone=UTC