什么?循环查找数据库,效率太慢了!

在开发过程中,经常遇到需要把一个表里面的数据某个字段去另外一个表中查找的问题,这时候可能有人说了,我联表查询不久解决了嘛。是的,你联表查询确实效率高,很快啊,啪的一下就把两个表的数据结合查出来了。

然而,需求不断在变。。。一开始没有联表查询需求,你猜怎么着?新需求来了!我就要你还要查另外一个表,你怎么着吧。嘿,我改sql语句去,大不了更改查询,sql语句变了还是一条好汉。但是有时候更改sql语句太麻烦了咋办,这时候就有勇士提出,我循环这个表内容,再去另外一个表查一次!天!他好勇,循环查询数据库,可真有你的。。。

先来看看勇士的操作:

for (Customer customer  : list) {
            LambdaQueryWrapper<User> queryWrapper=new LambdaQueryWrapper();
            queryWrapper.eq(User::getName,customer.getName());
            User user = UserMapper.selectOne(queryWrapper);
        }

循环查询数据库,我直呼行家!这效率,人多估计能卡成飞机,数据库都给你干蹦了。有没有人来救救这个可怜的数据库!于是它来了,jdk8提供的方法list.stream( ).filter( )帮你解救数据库于水火。

list.stream( ).filter( )可以模拟数据库查询,从list集合里面查询出你想要的结果,你的数据库被解放了。让我们先看看用了它之后的情况如何:

List<User> userList=UserMapper.list(null);
for (Customer customer  : list) {
    User user = userList.stream().filter(u -> customer.getName().equals(u.getName())).findAny().orElse(null);
     }

如此之下,只需一次查询数据库获取全部User数据,再使用list.stream( ).filter( )方法模拟数据库查询就做到了。解救数据库,它做到了!!

除此之外它还有多种模拟查询方法,以下列举出一些:

用list.stream.filter的方式替换数据库查询,提高数据库查询效率

//filter为过滤,user代表userList中的一个User
//在集合中查询用户名为custer.getName( )的集合
List<User> userList = list.stream().filter(user -> custer.getName( ).equals(user.getUsername())).collect(Collectors.toList());
//.findAny()表示将其中任意一个返回;【注意:在Java 8 Stream中, findFirst()返回Stream中的第一个元素,而findAny()返回Stream中的任何元素。】
//.orElse(null)表示如果一个都没找到返回null。【orElse()中可以塞默认值。如果找不到就会返回orElse中你自己设置的默认值。】
User user1 = userList.stream().filter(user -> custer.getName( ).equals(user.getUserName())).findAny().orElse(null);
//在集合中查询出第一个用户密码为123456的用户
Optional<User> user = list.stream().filter(userTemp -> "123456".equals(userTemp.getPassword())).findFirst();

解救数据库,从我做起。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值