科目余额工序取数表,取数公司通过配置表获取

This commit is contained in:
zhangzhiguo 2025-10-23 11:19:11 +08:00
parent 72e5464e3d
commit 696a84f1b9
2 changed files with 70 additions and 17 deletions

View File

@ -27,14 +27,14 @@ public class SubjectbalanceAutoData {
private static final String[] asseestypeArrays = new String[]{"0032","0017",""}; private static final String[] asseestypeArrays = new String[]{"0032","0017",""};
public static void getData() { public static void getData(Long periodId,boolean isAuto) {
String[] selectorsArray = new String[]{"beginlocal", "endlocal", "yeardebitfor", "yearcreditfor", "debitlocal", "creditlocal"}; String[] selectorsArray = new String[]{"beginlocal", "endlocal", "yeardebitfor", "yearcreditfor", "debitlocal", "creditlocal"};
QFilter filteraccountTable = new QFilter("number", QCP.equals, "0003"); QFilter filteraccountTable = new QFilter("number", QCP.equals, "0003");
DynamicObject accountTableLoad = BusinessDataServiceHelper.loadSingle("bd_accounttable", "id", new QFilter[]{filteraccountTable}); DynamicObject accountTableLoad = BusinessDataServiceHelper.loadSingle("bd_accounttable", "id", new QFilter[]{filteraccountTable});
// 查询核算组织 // 查询核算组织
QFilter number = new QFilter("fisaccounting", "=", "1"); /*QFilter number = new QFilter("fisaccounting", "=", "1");
QFilter structure = new QFilter("structure.longnumber", QCP.like, "10000000!10006431%"); QFilter structure = new QFilter("structure.longnumber", QCP.like, "10000000!10006431%");
QFilter isleaf = new QFilter("structure.isleaf", QCP.equals, true); QFilter isleaf = new QFilter("structure.isleaf", QCP.equals, true);
DynamicObject[] load = BusinessDataServiceHelper.load("bos_org", "id,structure.longnumber,structure.view", new QFilter[]{number, structure, isleaf}); DynamicObject[] load = BusinessDataServiceHelper.load("bos_org", "id,structure.longnumber,structure.view", new QFilter[]{number, structure, isleaf});
@ -59,6 +59,22 @@ public class SubjectbalanceAutoData {
orgNumberMap.put(dynamicObject.getString("number"), dynamicObject); orgNumberMap.put(dynamicObject.getString("number"), dynamicObject);
orgIds.add(dynamicObject.getLong("id")); orgIds.add(dynamicObject.getLong("id"));
} }
}*/
//通过配置表取公司
Map<String, DynamicObject> orgNumberMap = new HashMap<>();
List<Long> orgIds = new ArrayList<>();
DynamicObject[] companybelongs = BusinessDataServiceHelper.load("zcgj_companybelong", "id,zcgj_companyblentry.zcgj_org", new QFilter[]{});
for (DynamicObject companybelong : companybelongs) {
DynamicObjectCollection companyblentryCollection = companybelong.getDynamicObjectCollection("zcgj_companyblentry");
for (DynamicObject dynamicObject : companyblentryCollection) {
DynamicObject zcgjOrg = dynamicObject.getDynamicObject("zcgj_org");
if(zcgjOrg!=null){
long id = zcgjOrg.getLong("id");
orgIds.add(id);
orgNumberMap.put(zcgjOrg.getString("number"), zcgjOrg);
}
}
} }
// 查询组织下对应的当前期间数据 // 查询组织下对应的当前期间数据
@ -72,11 +88,14 @@ public class SubjectbalanceAutoData {
} }
// 标记旧数据为非最新 // 标记旧数据为非最新
List<Object[]> sqlparams = new ArrayList<>(); if(isAuto) { //使用自动执行时标记旧数据
Object[] sqlparam = new Object[]{false}; List<Object[]> sqlparams = new ArrayList<>();
sqlparams.add(sqlparam); Object[] sqlparam = new Object[]{false};
DB.executeBatch(DBRoute.of("fi"), sqlparams.add(sqlparam);
"update tk_zcgj_rpt_assistbalangx set fk_zcgj_isnew = ? ", sqlparams); DB.executeBatch(DBRoute.of("fi"),
"update tk_zcgj_rpt_assistbalangx set fk_zcgj_isnew = ? ", sqlparams);
}
for (String asseestype : asseestypeArrays) { for (String asseestype : asseestypeArrays) {
// 查询科目余额配置表 // 查询科目余额配置表
@ -102,17 +121,25 @@ public class SubjectbalanceAutoData {
DynamicObject orgObj = orgNumberMap.get(orgNumber); DynamicObject orgObj = orgNumberMap.get(orgNumber);
DynamicObject periodObj = orgByCurperiodMap.get(orgObj.getLong("id")); DynamicObject periodObj = orgByCurperiodMap.get(orgObj.getLong("id"));
DynamicObject curperiod = null; DynamicObject curperiod = null;
if (periodObj != null) { if(periodId==null){
curperiod = periodObj.getDynamicObject("curperiod"); if (periodObj != null) {
if (curperiod != null) { curperiod = periodObj.getDynamicObject("curperiod");
balanceQueryParamApi.setPeriodNumber(curperiod.getString("number")); // if (curperiod != null) {
balanceQueryParamApi.setPeriodNumber(curperiod.getString("number")); //
} else {
continue;
}
} else { } else {
continue; continue;
} }
} else { }else{
continue; QFilter idFilter = new QFilter("id", QCP.equals, periodId);
curperiod = BusinessDataServiceHelper.loadSingle("bd_period", "id,number", new QFilter[]{idFilter});
String periodNumber = curperiod.getString("number");
balanceQueryParamApi.setPeriodNumber(periodNumber); //
} }
List<String> groupBy = new ArrayList<>(); List<String> groupBy = new ArrayList<>();
if (!StringUtils.isEmpty(asseestype)) { if (!StringUtils.isEmpty(asseestype)) {
Map<String, List<Map<String, String>>> accountAssgrp = new HashMap<>(); Map<String, List<Map<String, String>>> accountAssgrp = new HashMap<>();
@ -161,7 +188,7 @@ public class SubjectbalanceAutoData {
assistbalance.set("zcgj_accounttable", accountTableLoad); assistbalance.set("zcgj_accounttable", accountTableLoad);
assistbalance.set("zcgj_account", record.getAccount()); assistbalance.set("zcgj_account", record.getAccount());
assistbalance.set("zcgj_period", curperiod); assistbalance.set("zcgj_period", curperiod);
assistbalance.set("zcgj_isnew", true); assistbalance.set("zcgj_isnew", isAuto);
assistbalance.set("zcgj_sourcetype", asseestype); assistbalance.set("zcgj_sourcetype", asseestype);
Map<String, AccountRecord.AssGrpItem> assgrp = record.getAssgrp(); Map<String, AccountRecord.AssGrpItem> assgrp = record.getAssgrp();
@ -186,9 +213,9 @@ public class SubjectbalanceAutoData {
try { try {
// 删除旧数据保证每个组织每个期间只保留一份最新的 // 删除旧数据保证每个组织每个期间只保留一份最新的
Long orgId = orgObj.getLong("id"); Long orgId = orgObj.getLong("id");
Long periodId = curperiod.getLong("id"); Long periodIddelete = curperiod.getLong("id");
QFilter orgFilter = new QFilter("zcgj_org", QCP.equals, orgId); QFilter orgFilter = new QFilter("zcgj_org", QCP.equals, orgId);
QFilter periodFilter = new QFilter("zcgj_period", QCP.equals, periodId); QFilter periodFilter = new QFilter("zcgj_period", QCP.equals, periodIddelete);
QFilter sourcetypeFilter = new QFilter("zcgj_sourcetype", QCP.equals, asseestype); QFilter sourcetypeFilter = new QFilter("zcgj_sourcetype", QCP.equals, asseestype);
QFilter isnewFilter = new QFilter("zcgj_isnew", QCP.equals, false); QFilter isnewFilter = new QFilter("zcgj_isnew", QCP.equals, false);
DeleteServiceHelper.delete("zcgj_rpt_assistbalancegx", new QFilter[]{orgFilter.and(periodFilter).and(sourcetypeFilter).and(isnewFilter)}); DeleteServiceHelper.delete("zcgj_rpt_assistbalancegx", new QFilter[]{orgFilter.and(periodFilter).and(sourcetypeFilter).and(isnewFilter)});

View File

@ -1,12 +1,19 @@
package zcgj.zcdev.zcdev.fs.plugin.form; package zcgj.zcdev.zcdev.fs.plugin.form;
import kd.bos.entity.filter.ControlFilters;
import kd.bos.form.control.events.ItemClickEvent; import kd.bos.form.control.events.ItemClickEvent;
import kd.bos.list.IListView;
import kd.bos.list.plugin.AbstractListPlugin; import kd.bos.list.plugin.AbstractListPlugin;
import kd.bos.logging.Log; import kd.bos.logging.Log;
import kd.bos.logging.LogFactory; import kd.bos.logging.LogFactory;
import kd.bos.orm.query.QFilter;
import kd.bos.servicehelper.operation.DeleteServiceHelper;
import kd.sdk.plugin.Plugin; import kd.sdk.plugin.Plugin;
import zcgj.zcdev.zcdev.fs.plugin.common.AssetsLiabilitiesbalanceAutoData;
import zcgj.zcdev.zcdev.fs.plugin.common.SubjectbalanceAutoData; import zcgj.zcdev.zcdev.fs.plugin.common.SubjectbalanceAutoData;
import java.util.List;
/** /**
* 核算维度余额取数表(矿山二开) * 核算维度余额取数表(矿山二开)
*/ */
@ -20,7 +27,26 @@ public class SubjectbalancePlugin extends AbstractListPlugin implements Plugin
String itemKey = evt.getItemKey(); String itemKey = evt.getItemKey();
if("zcgj_gatdata".equals(itemKey)) { if("zcgj_gatdata".equals(itemKey)) {
//科目余额表自动取数 //科目余额表自动取数
SubjectbalanceAutoData.getData();//其他 SubjectbalanceAutoData.getData(null,true);//其他
}else if("zcgj_gatdataperiod".equals(itemKey)) {
//获取列表查询参数
ControlFilters filters = ((IListView)this.getView()).getControlFilters();
List<Object> filter = filters.getFilter("zcgj_period.id");
if(filter.isEmpty()) {
this.getView().showMessage("请选择期间!");
}else{
for (Object periodId : filter) {
if(periodId instanceof String) {
SubjectbalanceAutoData.getData(Long.valueOf((String)periodId),false);//其他
}
}
//重新执行一下拉取最新的数据解决历史数据最新勾选问题
//AssetsLiabilitiesbalanceAutoData.getData(null);//其他
}
}else if("zcgj_deleteall".equals(itemKey)) {
int zcgjRptAssistbalanZcfz = DeleteServiceHelper.delete("zcgj_rpt_assistbalancegx", new QFilter[]{});
this.getView().showMessage("操作完成!");
} }
} }