
 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,是一样的效果!



















