不要循环查询数据库

在编码过程中要避免在循环中查询数据库,能一次查询的就不要多次查询。下面两个代码块是完全等效的。代码块一写起来简单,但却在循环中多次查询数据库,该代码执行时间为8毫秒。代码二写起来麻烦甚至还多了个双重循环,但只查询一次数据库,该代码执行时间为2毫秒。

代码块一:

for (Device dev : list) {
String dmi = dev.getDeviceModelId();
if (StringUtils.isBlank(dmi)){
continue;
}
DeviceModel dm = this.deviceModelManager.get(dmi); //查询数据库
dev.setDeviceModel(dm);
}


代码块二:

List<String> deviceModelIdList = new ArrayList<String>();
for (Device dev : list) {
String dmi = dev.getDeviceModelId();
if (StringUtils.isBlank(dmi)){
continue;
}
deviceModelIdList.add(dmi);
}
List<DeviceModel> deviceModelList = this.deviceModelManager.find(new NameValuePair("id", MatchMode.IN, deviceModelIdList)); //查询数据库
for (Device dev : list) {
for(DeviceModel model : deviceModelList){
if(model.getId().equals(dev.getDeviceModelId())){
dev.setDeviceModel(model);
}
}
}



  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值