if (CollUtil.isNotEmpty(dxrBizIdList)) { StringBuilder ids = new StringBuilder(); for (String item : dxrBizIdList) { ids.append(item).append(","); //ids.append("'").append(item).append("',"); bigint

时间: 2024-04-06 21:33:09 浏览: 12
这段代码的作用是根据传入的dxrBizIdList列表生成一个SQL的查询条件,并添加到一个SQL字符串selectSql中,以便进行数据库查询操作。具体来说,这段代码会在dxrBizIdList列表非空的情况下,遍历dxrBizIdList列表中的每一个元素,将元素以逗号隔开的形式添加到StringBuilder对象ids中,最终将ids中的内容添加到selectSql中作为一个查询条件。其中,ids.append(item).append(",")用于将dxrBizIdList中的每个元素添加到ids中,并在元素之间添加逗号,这样生成的ids字符串就是一个以逗号隔开的ID列表。
相关问题

检查以下代码是否有问题: StringBuilder info = new StringBuilder(); if (CollectionUtils.isNotEmpty(adminCreateVO.getSalaryGroupResourceList())){ for (SalaryGroupResourceVO salaryGroupResourceVO : adminCreateVO.getSalaryGroupResourceList()) { StringBuilder salaryGroupName = new StringBuilder("【" + salaryGroupMap.get(salaryGroupResourceVO.getSalaryGroupId()) + "】"); for (SalaryGroupIdentityVO resourceIdentity : salaryGroupResourceVO.getResourceIdentities()) { if (!Objects.equals(resourceIdentity.getName(), SalaryGlobalConstants.PAYROLL_GROUP_MANAGEMENT_SALARY_APPROVAL)){ salaryGroupName.append(resourceIdentity.getName()).append("、"); } } info.append(salaryGroupName.substring(0, salaryGroupName.length() - 1)).append(";"); } }

代码看起来没有明显的语法错误,但可能存在逻辑上的问题。以下是一些需要注意的地方: 1. `CollectionUtils.isNotEmpty()`是Apache Commons Collections库中的方法,用于检查集合是否不为空。请确保你已经导入了正确的库,并正确使用该方法。 2. 在循环中,你使用了`salaryGroupMap.get(salaryGroupResourceVO.getSalaryGroupId())`来获取`salaryGroupId`对应的值。请确保`salaryGroupMap`已经被正确初始化,并且包含了所需的键值对。 3. 在`salaryGroupName.append(resourceIdentity.getName()).append("、")`这一行,你将每个`resourceIdentity.getName()`都添加到了`salaryGroupName`中,并在后面添加了一个逗号。但请注意,在最后一个元素后面不需要添加逗号。因此,在使用`info.append(salaryGroupName.substring(0, salaryGroupName.length() - 1)).append(";")`之前,你应该检查一下`salaryGroupName`的长度是否大于1,以避免出现空指针异常。 希望这些提示对你有帮助!如果你有任何其他问题,请随时提问。

两个集合的数据有上万条,导出内存溢出,请将下面的代码优化 for (int i = 0; i <ls.size() ; i++) { Map<String,Object> sb1=new HashMap<>(); Map<String,Object> sb2=new HashMap<>(); boolean sbboolean1=false; boolean sbboolean2=false; for (int j = 0; j <list2.size() ; j++) { if(StringUtils.isNotEmpty(ls.get(i).getSalesorder())&&StringUtils.isNotEmpty(list2.get(j).getSalesorder())){ if(ls.get(i).getSalesorder().trim().equals(list2.get(j).getSalesorder().trim())){ if(StringUtils.isNotEmpty(list2.get(j).getDeliveryresponse())){ sbboolean1=true; sb1.put(list2.get(j).getDeliveryresponse().trim(),null); } if(StringUtils.isNotEmpty(list2.get(j).getOrderdate())){ sbboolean2=true; sb2.put(list2.get(j).getOrderdate().trim(),null); } } } } if(sbboolean1){ StringBuilder sbdate1=new StringBuilder(); for (String s:sb1.keySet()) { sbdate1.append(s+" "); } ls.get(i).setLowmaterialstatusb(sbdate1.toString()); } if(sbboolean2){ StringBuilder sbdate2=new StringBuilder(); for (String s:sb2.keySet()) { sbdate2.append(s+" "); } ls.get(i).setLowmaterialstatus(sbdate2.toString()); } }

这段代码可以进行以下优化: 1. 避免在循环中频繁调用 `ls.get(i)` 和 `list2.get(j)` 方法,可以先将它们的值存储在变量中: ``` for (int i = 0; i < ls.size(); i++) { Map<String, Object> sb1 = new HashMap<>(); Map<String, Object> sb2 = new HashMap<>(); boolean sbboolean1 = false; boolean sbboolean2 = false; Object salesorder1 = ls.get(i).getSalesorder(); if (StringUtils.isNotEmpty(salesorder1)) { String salesorder1Trim = salesorder1.toString().trim(); for (int j = 0; j < list2.size(); j++) { Object salesorder2 = list2.get(j).getSalesorder(); if (StringUtils.isNotEmpty(salesorder2)) { String salesorder2Trim = salesorder2.toString().trim(); if (salesorder1Trim.equals(salesorder2Trim)) { Object deliveryresponse = list2.get(j).getDeliveryresponse(); if (StringUtils.isNotEmpty(deliveryresponse)) { sbboolean1 = true; sb1.put(deliveryresponse.toString().trim(), null); } Object orderdate = list2.get(j).getOrderdate(); if (StringUtils.isNotEmpty(orderdate)) { sbboolean2 = true; sb2.put(orderdate.toString().trim(), null); } } } } } // ... } ``` 2. 如果 `sb1` 和 `sb2` 中存储的值只需要是键的集合,可以使用 `HashSet` 代替 `HashMap`,避免在循环中频繁创建和销毁 value 对象: ``` for (int i = 0; i < ls.size(); i++) { Set<String> sb1 = new HashSet<>(); Set<String> sb2 = new HashSet<>(); boolean sbboolean1 = false; boolean sbboolean2 = false; Object salesorder1 = ls.get(i).getSalesorder(); if (StringUtils.isNotEmpty(salesorder1)) { String salesorder1Trim = salesorder1.toString().trim(); for (int j = 0; j < list2.size(); j++) { Object salesorder2 = list2.get(j).getSalesorder(); if (StringUtils.isNotEmpty(salesorder2)) { String salesorder2Trim = salesorder2.toString().trim(); if (salesorder1Trim.equals(salesorder2Trim)) { Object deliveryresponse = list2.get(j).getDeliveryresponse(); if (StringUtils.isNotEmpty(deliveryresponse)) { sbboolean1 = true; sb1.add(deliveryresponse.toString().trim()); } Object orderdate = list2.get(j).getOrderdate(); if (StringUtils.isNotEmpty(orderdate)) { sbboolean2 = true; sb2.add(orderdate.toString().trim()); } } } } } // ... } ``` 3. 如果需要把 `sb1` 和 `sb2` 中的值拼接成字符串并赋值给对象的属性,可以直接使用 `String.join()` 方法,避免使用 `StringBuilder`: ``` for (int i = 0; i < ls.size(); i++) { Set<String> sb1 = new HashSet<>(); Set<String> sb2 = new HashSet<>(); boolean sbboolean1 = false; boolean sbboolean2 = false; Object salesorder1 = ls.get(i).getSalesorder(); if (StringUtils.isNotEmpty(salesorder1)) { String salesorder1Trim = salesorder1.toString().trim(); for (int j = 0; j < list2.size(); j++) { Object salesorder2 = list2.get(j).getSalesorder(); if (StringUtils.isNotEmpty(salesorder2)) { String salesorder2Trim = salesorder2.toString().trim(); if (salesorder1Trim.equals(salesorder2Trim)) { Object deliveryresponse = list2.get(j).getDeliveryresponse(); if (StringUtils.isNotEmpty(deliveryresponse)) { sbboolean1 = true; sb1.add(deliveryresponse.toString().trim()); } Object orderdate = list2.get(j).getOrderdate(); if (StringUtils.isNotEmpty(orderdate)) { sbboolean2 = true; sb2.add(orderdate.toString().trim()); } } } } } if (sbboolean1) { ls.get(i).setLowmaterialstatusb(String.join(" ", sb1)); } if (sbboolean2) { ls.get(i).setLowmaterialstatus(String.join(" ", sb2)); } } ```

相关推荐

优化这段java代码: private void dealWitchCaseNo(Map<String, String[]> paramsMap,User user) { try { if(paramsMap.containsKey("case_no_year") || paramsMap.containsKey("case_no_middle") || paramsMap.containsKey("case_no_tail")){ StringBuilder caseNo = new StringBuilder(); StringBuilder caseNoSource = new StringBuilder(); String[] yearArray = paramsMap.get("case_no_year"); String[] daiZiArray = paramsMap.get("case_no_middle"); String[] xhArray = paramsMap.get("case_no_tail"); //标准案号查询 if(ArrayUtil.isNotEmpty(yearArray)&&ArrayUtil.isNotEmpty(daiZiArray)&&ArrayUtil.isNotEmpty(xhArray)){ caseNo.append(yearArray[0]+"年最高法"+daiZiArray[0]+"字第"+xhArray[0]+"号"); caseNoSource.append("("+yearArray[0]+")最高法"+daiZiArray[0]+xhArray[0]+"号"); }else{ //模糊查询 if(ArrayUtil.isNotEmpty(yearArray)){ caseNo.append(yearArray[0]); } if(ArrayUtil.isNotEmpty(daiZiArray)){ if(ArrayUtil.isNotEmpty(yearArray)){ caseNo.append("年最高法"+daiZiArray[0]); caseNoSource.append(yearArray[0]+")最高法"+daiZiArray[0]); }else if(ArrayUtil.isNotEmpty(xhArray)){ caseNo.append(daiZiArray[0]+"字第"); caseNoSource.append(daiZiArray[0]+xhArray[0]); }else { caseNo.append(daiZiArray[0]); } saveUsuallyUse(daiZiArray[0], user); } if(ArrayUtil.isNotEmpty(xhArray)){ caseNo.append(xhArray[0]); } } paramsMap.remove("case_no_year"); paramsMap.remove("case_no_middle"); paramsMap.remove("case_no_tail"); if(caseNo.length()>0) { String condition = ""; if (ArrayUtil.isNotEmpty(paramsMap.get("condition"))) { condition = paramsMap.get("condition")[0] + " and case_no like '%" + caseNo.toString() + "%'"; if(caseNoSource.length()>0) condition = paramsMap.get("condition")[0] + " and (case_no like '%" + caseNo.toString() + "%' or case_no like '%" + caseNoSource.toString() + "%')"; } else { condition = " and case_no like '" + caseNo.toString() + "' "; if(caseNoSource.length()>0) condition = " and (case_no like '" + caseNo.toString() + "' or case_no like '%" + caseNoSource.toString() + "%')"; } paramsMap.put("condition",new String[]{condition}; } } } catch (Exception e) { e.printStackTrace(); } }

@Transactional(rollbackFor = Exception.class) public void IntendedSignHandle(IntendedSignReq intendedSignReq, Map<String, IntentionEquResp> intentionEquRespMap, SaleStateEnum currentSaleStateEnum, SaleStateEnum goalSaleStateEnum) { StringBuilder message = new StringBuilder(); List<EquMarketablePrice> updateMarketablePriceList = new ArrayList<>(); for (String equNo : intendedSignReq.getEquNoList()) { Optional.ofNullable(intentionEquRespMap.get(equNo)).ifPresent(intentionEquResp -> { // 构建更新对象 if (intentionEquResp.getSaleState().equals(currentSaleStateEnum.getCode())) { EquMarketablePrice updateEquMarketablePrice = new EquMarketablePrice(); updateEquMarketablePrice.setId(intentionEquResp.getId()); updateEquMarketablePrice.setSaleState(goalSaleStateEnum.getCode()); updateEquMarketablePrice.setEditBy(intendedSignReq.getOperatorAd()); updateEquMarketablePrice.setEditByName(intendedSignReq.getOperatorName()); updateMarketablePriceList.add(updateEquMarketablePrice); } else { message.append(String.format("[%s] 当前意向状态[%s] 非[%s]状态,无法标记[%s]状态,请与资产方向确认", equNo, SaleStateEnum.getDescByCode(intentionEquResp.getSaleState()), currentSaleStateEnum.getDesc(), goalSaleStateEnum.getDesc())).append("\n"); } }); } if (CollectionUtils.isNotEmpty(updateMarketablePriceList)) { equMarketablePriceService.updateBatchById(updateMarketablePriceList, Constant.ONE_HUNDRED); } TransactionSynchronizationManager.registerSynchronization(new TransactionSynchronizationAdapter() { @Override public void afterCommit() { if (StringUtils.isBlank(message) ) { return; } String errorMessage = message.toString(); log.info(errorMessage); if (Boolean.TRUE.equals(intendedSignSwitch)) { alarmService.alarm("意向标记失败", errorMessage); } } }); } 允许报这个错java.lang.IllegalStateException: Transaction synchronization is not active

public static String format(final String strPattern, final Object... argArray) { if (StringUtils.isEmpty(strPattern) || StringUtils.isEmpty(argArray)) { return strPattern; } final int strPatternLength = strPattern.length(); // 初始化定义好的长度以获得更好的性能 StringBuilder sbuf = new StringBuilder(strPatternLength + 50); int handledPosition = 0; int delimIndex;// 占位符所在位置 for (int argIndex = 0; argIndex < argArray.length; argIndex++) { delimIndex = strPattern.indexOf(EMPTY_JSON, handledPosition); if (delimIndex == -1) { if (handledPosition == 0) { return strPattern; } else { // 字符串模板剩余部分不再包含占位符,加入剩余部分后返回结果 sbuf.append(strPattern, handledPosition, strPatternLength); return sbuf.toString(); } } else { if (delimIndex > 0 && strPattern.charAt(delimIndex - 1) == C_BACKSLASH) { if (delimIndex > 1 && strPattern.charAt(delimIndex - 2) == C_BACKSLASH) { // 转义符之前还有一个转义符,占位符依旧有效 sbuf.append(strPattern, handledPosition, delimIndex - 1); sbuf.append(Convert.utf8Str(argArray[argIndex])); handledPosition = delimIndex + 2; } else { // 占位符被转义 argIndex--; sbuf.append(strPattern, handledPosition, delimIndex - 1); sbuf.append(C_DELIM_START); handledPosition = delimIndex + 1; } } else { // 正常占位符 sbuf.append(strPattern, handledPosition, delimIndex); sbuf.append(Convert.utf8Str(argArray[argIndex])); handledPosition = delimIndex + 2; } } } // 加入最后一个占位符后所有的字符 sbuf.append(strPattern, handledPosition, strPattern.length()); return sbuf.toString(); }优化这段代码

最新推荐

recommend-type

HP-Socket编译-Linux

HP-Socket编译-Linux
recommend-type

JavaScript_生活在Discord上的开源社区列表.zip

JavaScript
recommend-type

JavaScript_MultiOn API.zip

JavaScript
recommend-type

JavaScript_简单和完整的React DOM测试工具,鼓励良好的测试实践.zip

JavaScript
recommend-type

JavaScript_成为一个Nodejs开发者.zip

JavaScript
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

可见光定位LED及其供电硬件具体型号,广角镜头和探测器,实验设计具体流程步骤,

1. 可见光定位LED型号:一般可使用5mm或3mm的普通白色LED,也可以选择专门用于定位的LED,例如OSRAM公司的SFH 4715AS或Vishay公司的VLMU3500-385-120。 2. 供电硬件型号:可以使用常见的直流电源供电,也可以选择专门的LED驱动器,例如Meanwell公司的ELG-75-C或ELG-150-C系列。 3. 广角镜头和探测器型号:一般可采用广角透镜和CMOS摄像头或光电二极管探测器,例如Omron公司的B5W-LA或Murata公司的IRS-B210ST01。 4. 实验设计流程步骤: 1)确定实验目的和研究对象,例如车辆或机器人的定位和导航。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。