@RunWith(SpringRunner.class)
@SpringBootTest
public class QueryWrapperTests {
@Autowired
private UserMapper mapper;
/**
-
-
根据根据 entity 条件,删除记录,QueryWrapper实体对象封装操作类(可以为 null)
-
下方获取到queryWrapper后删除的查询条件为name字段为null的and年龄大于等于12的and email字段不为null的
-
同理写法条件添加的方式就不做过多介绍了。
*/
@Test
public void delete() {
QueryWrapper queryWrapper = new QueryWrapper<>();
queryWrapper
.isNull(“name”)
.ge(“age”, 12)
.isNotNull(“email”);
int delete = mapper.delete(queryWrapper);
System.out.println("delete return count = " + delete);
}
/**
-
-
根据 entity 条件,查询一条记录,
-
这里和上方删除构造条件一样,只是seletOne返回的是一条实体记录,当出现多条时会报错
*/
@Test
public void selectOne() {
QueryWrapper queryWrapper = new QueryWrapper<>();
queryWrapper.eq(“name”, “lqf”);
User user = mapper.selectOne(queryWrapper);
System.out.println(user);
}
/**
-
-
根据 Wrapper 条件,查询总记录数
-
@param queryWrapper 实体对象
*/
@Test
public void selectCount() {
QueryWrapper queryWrapper = new QueryWrapper<>();
queryWrapper.eq(“name”, “lqf”);
Integer count = mapper.selectCount(queryWrapper);
System.out.println(count);
}
/**
-
-
根据 entity 条件,查询全部记录
-
@param queryWrapper 实体对象封装操作类(可以为 null)为null查询全部
*/
@Test
public void selectList() {
List list = mapper.selectList(null);
System.out.println(list);
}
/**
-
-
根据 Wrapper 条件,查询全部记录
-
@param queryWrapper 实体对象封装操作类(可以为 null)
*/
@Test
public void selectMaps() {
QueryWrapper queryWrapper = new QueryWrapper<>();
queryWrapper.isNotNull(“name”);
List<Map<String, Object>> maps = mapper.selectMaps(queryWrapper);
for (Map<String, Object> map : maps) {
System.out.println(map);
}
}
/**
-
打印结果
-
{name=lqf, id=1046282328366391406, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391407, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391408, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391409, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391410, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391411, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391412, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391413, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391414, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391415, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391416, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391417, age=12, email=lqf@163.com, status=false}
-
{name=lqf, id=1046282328366391418, age=12, email=lqf@163.com, status=false}
-
json类型的键值对模式
*/
/**
-
-
根据 entity 条件,查询全部记录(并翻页)
-
@param page 分页查询条件(可以为 RowBounds.DEFAULT)
-
@param queryWrapper 实体对象封装操作类(可以为 null)
*/
@Test
public void selectPage() {
Page page = new Page<>(1, 5);
QueryWrapper queryWrapper = new QueryWrapper<>();
IPage userIPage = mapper.selectPage(page, queryWrapper);
System.out.println(userIPage);
}
/**
-
打印结果
-
==> Preparing: SELECT COUNT(1) FROM user
-
==> Parameters:
-
<== Columns: COUNT(1)
-
<== Row: 100
-
==> Preparing: SELECT id,name,age,email,status FROM user LIMIT 0,5
-
==> Parameters:
小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
知其然不知其所以然,大厂常问面试技术如何复习?
1、热门面试题及答案大全
面试前做足功夫,让你面试成功率提升一截,这里一份热门350道一线互联网常问面试题及答案助你拿offer
2、多线程、高并发、缓存入门到实战项目pdf书籍
3、文中提到面试题答案整理
4、Java核心知识面试宝典
覆盖了JVM 、JAVA集合、JAVA多线程并发、JAVA基础、Spring原理、微服务、Netty与RPC、网络、日志、Zookeeper、Kafka、RabbitMQ、Hbase、MongoDB 、Cassandra、设计模式、负载均衡、数据库、一致性算法 、JAVA算法、数据结构、算法、分布式缓存、Hadoop、Spark、Storm的大量技术点且讲解的非常深入
模式、负载均衡、数据库、一致性算法 、JAVA算法、数据结构、算法、分布式缓存、Hadoop、Spark、Storm的大量技术点且讲解的非常深入**
[外链图片转存中…(img-AKTJzjMx-1711148962669)]
[外链图片转存中…(img-uyVU7gTd-1711148962669)]
[外链图片转存中…(img-1XfYzZBS-1711148962670)]