1.maven依赖
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.4.1</version>
</dependency>
2.调用实例
//查询(模糊,匹配)
@PostMapping("/listP")
public List<User> listP(@RequestBody User user){
LambdaQueryWrapper<User> lambdaQueryWrapper = new LambdaQueryWrapper<>();
//{name:"小米",age:18}
//查询user表里name字段包含”小米“一词,且age字段等于18的用户
lambdaQueryWrapper
// User::getName
// User user = new User();
// 调用对象User的get方法,这里调用的是getName:
// user.getName();
.like(User::getName,user.getName())
.eq(User::getAge,user.getAge());
return userService.list(lambdaQueryWrapper);
}
3参考
https://blog.csdn.net/weixin_41629964/article/details/122836988
4Java 泛型 <? super T> 中 super 怎么 理解?与 extends 有何不同?
java是单继承,所有继承的类构成一棵树。
假设A和B都在一颗继承树里(否则super,extend这些词没意义)。
A super B 表示A是B的父类或者祖先,在B的上面。
A extend B 表示A是B的子类或者子孙,在B下面。
由于树这个结构上下是不对称的,所以这两种表达区别很大。假设有两个泛型写在了函数定义里,作为函数形参(形参和实参有区别):
- 参数写成:T<? super B>,对于这个泛型,?代表容器里的元素类型,由于只规定了元素必须是B的超类,导致元素没有明确统一的“根”(除了Object这个必然的根),所以这个泛型你其实无法使用它,对吧,除了把元素强制转成Object。所以,对把参数写成这样形态的函数,你函数体内,只能对这个泛型做插入操作,而无法读
- 参数写成: T<? extends B>,由于指定了B为所有元素的“根”,你任何时候都可以安全的用B来使用容器里的元素,但是插入有问题,由于供奉B为祖先的子树有很多,不同子树并不兼容,由于实参可能来自于任何一颗子树,所以你的插入很可能破坏函数实参,所以,对这种写法的形参,禁止做插入操作,只做读取
链接 https://www.zhihu.com/question/20400700/answer/117464182