userService是基础于ServiceImpl
而servicfeImpl中要传入一个继承于BaseMapper的类和一个实体类
这个继承于BaseMapper的类就是我们的userMapper,所以userMapper要集成BaseMapper
重点来了,
UserService中的我们去调用Impl实现类的saveOrUpdate方法,然后我们再往里看,
关键是右下角,调用了this的updateById和save方法,这个this是什么呢?
这个this就是ServiceImpl实现的IService,所以我们进去IService里面看看
发现它都需要调用getBaseMapper里的方法,所以我们进去getBaseMapper看看
比如说save,它调用的是getBaseMapper里的insert方法
我们进去到BaseMapper里,发现它是个接口
然后我们想想,是不是曾经实现还是继承过它,是的
我们的UserMapper继承了它,导致一个什么问题呢?
就是如果UserMapper里面写了注解,那么就会先运用这里的注解,而不是MybatisPlus自动给你生成的sql。
所以就导致了我一直出现一个问题
在插入新数据的时候,总是出现问题。
这是因为我的User类的属性写成了id
但是按理来说,mbp会自动帮我转换,因为我上面写了value属性,但还是一直报错。
后面才发现,是这条sql出现的问题
mbp先找运用UserMapper里的接口了,而这里面的#{fid}一直找不到,这就是最大的罪魁祸首!!!
所以用了MybatisPlus记得把Mapper文件里的注解注释掉!
其实插入的时候,一般是不需要传id过去的,
所以我们传的确实是一个User, 不过是一个id为空的User,类似这样,是一个JSON对象
传过去id为空,数据库那边直接给你按id递增就好了。
其实本质上就是这样。
不过,我们可以直接把sql改成这样
不要id,是一样的效果!