提交 2fcc245e 编写于 作者: sq3536's avatar sq3536

控制查询

上级 37de354e
...@@ -8,6 +8,7 @@ import cn.ibizlab.core.rule.filter.RuleItemSearchContext; ...@@ -8,6 +8,7 @@ import cn.ibizlab.core.rule.filter.RuleItemSearchContext;
import cn.ibizlab.core.rule.service.IRuleItemService; import cn.ibizlab.core.rule.service.IRuleItemService;
import cn.ibizlab.core.rule.service.impl.RuleEngineServiceImpl; import cn.ibizlab.core.rule.service.impl.RuleEngineServiceImpl;
import cn.ibizlab.util.helper.CachedBeanCopier; import cn.ibizlab.util.helper.CachedBeanCopier;
import com.alibaba.fastjson.JSON;
import com.baomidou.mybatisplus.core.toolkit.IdWorker; import com.baomidou.mybatisplus.core.toolkit.IdWorker;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
...@@ -65,23 +66,35 @@ public class RuleEngineExService extends RuleEngineServiceImpl { ...@@ -65,23 +66,35 @@ public class RuleEngineExService extends RuleEngineServiceImpl {
msg.setId(IdWorker.getIdStr()); msg.setId(IdWorker.getIdStr());
msg.setModel(et.getModelName()); msg.setModel(et.getModelName());
java.sql.Timestamp starttime = new java.sql.Timestamp(System.currentTimeMillis()); java.sql.Timestamp starttime = new java.sql.Timestamp(System.currentTimeMillis());
msg.setDatas(dbEntityService.getModelObjs(et.getModelId(),et.getLastRuntime()));
List<String> rules = new ArrayList<>(); List<String> rules = new ArrayList<>();
HashSet<String> propertys=new HashSet<>();
ruleItemService.list(Wrappers.<RuleItem>lambdaQuery() ruleItemService.list(Wrappers.<RuleItem>lambdaQuery()
.select(RuleItem::getRuleId).eq(RuleItem::getModelId,et.getModelId()).ne(RuleItem::getGroup,"REP").like(RuleItem::getGroup,et.getGroup())) .eq(RuleItem::getModelId,et.getModelId()).ne(RuleItem::getGroup,"REP").like(RuleItem::getGroup,et.getGroup()))
.forEach(ruleItem -> { .forEach(ruleItem -> {
String path=rulePath + et.getGroup() + File.separator + ruleItem.getRuleId() + ".drl"; String path=rulePath + et.getGroup() + File.separator + ruleItem.getRuleId() + ".drl";
File file=new File(path); File file=new File(path);
if(!file.exists())
{
ruleItemService.buildRuleFile(ruleItem);
}
if(file.exists()) if(file.exists())
{ {
rules.add(path); rules.add(path);
} }
if((!StringUtils.isEmpty(ruleItem.getCond()))&&ruleItem.getCond().startsWith("["))
propertys.addAll(JSON.toJavaObject(JSON.parseArray(ruleItem.getCond()),LinkedHashSet.class));
}); });
msg.setRules(rules); msg.setRules(rules);
msg.setDatas(dbEntityService.getModelObjs(et.getModelId(),propertys,et.getLastRuntime()));
ExecLog execlog = baseEntityService.processAll(msg); ExecLog execlog = baseEntityService.processAll(msg);
if (execlog.getRetCode() != 0) if (execlog.getRetCode() != 0)
......
...@@ -138,13 +138,10 @@ public class RuleItemExService extends RuleItemServiceImpl { ...@@ -138,13 +138,10 @@ public class RuleItemExService extends RuleItemServiceImpl {
boolean b=false; boolean b=false;
for(String key : modelset.keySet()) { for(String key : modelset.keySet()) {
if(key.equalsIgnoreCase("datamodelname")) if(key.equalsIgnoreCase("datamodelname")||key.startsWith("EXIST")||key.startsWith("NOTEXIST"))
continue;
if(key.equalsIgnoreCase("EXIST"))
continue; continue;
b=true; b=true;
break; break;
} }
if(!b) if(!b)
{ {
...@@ -170,16 +167,21 @@ public class RuleItemExService extends RuleItemServiceImpl { ...@@ -170,16 +167,21 @@ public class RuleItemExService extends RuleItemServiceImpl {
} }
param.put("hasbusinesscatfield", hasBusinesscatField); param.put("hasbusinesscatfield", hasBusinesscatField);
JSONArray cond = new JSONArray(); LinkedHashSet<String> cond = new LinkedHashSet();
for(String key : modelset.keySet()) { for(String key : modelset.keySet()) {
if(key.equalsIgnoreCase("datamodelname")) if(key.equalsIgnoreCase("datamodelname"))
continue; continue;
if(key.equalsIgnoreCase("EXIST")) if(key.startsWith("EXIST")||key.startsWith("NOTEXIST")) {
DataModel sub=dataModel.findDataModel(modelset.get(key),"DOWN");
if(sub!=null)
cond.add(sub.getFactPorperty().getPropertyName());
continue; continue;
}
cond.add(key); cond.add(key);
} }
et.setCond(cond.toJSONString()); et.setCond(JSONArray.toJSONString(cond));
} }
...@@ -356,8 +358,10 @@ public class RuleItemExService extends RuleItemServiceImpl { ...@@ -356,8 +358,10 @@ public class RuleItemExService extends RuleItemServiceImpl {
{ {
strRelationResult=String.format("%s:ModelObj %s from %s.getNested(\"%s\")",relaEntity,strGroupCond,modelset.get("datamodelname"),relaEntity); strRelationResult=String.format("%s:ModelObj %s from %s.getNested(\"%s\")",relaEntity,strGroupCond,modelset.get("datamodelname"),relaEntity);
modelset.put("EXIST",relaEntity); modelset.put("EXIST",relaEntity);
modelset.put("EXIST-"+relaEntity,relaEntity);
} }
else if(relaConn.equals("not exists")){ else if(relaConn.equals("not exists")){
modelset.put("NOTEXIST-"+relaEntity,relaEntity);
strRelationResult=String.format("not(exists ModelObj %s from %s.getNested(\"%s\"))",strGroupCond,modelset.get("datamodelname"),relaEntity); strRelationResult=String.format("not(exists ModelObj %s from %s.getNested(\"%s\"))",strGroupCond,modelset.get("datamodelname"),relaEntity);
} }
} }
......
...@@ -8,6 +8,7 @@ import cn.ibizlab.util.filter.QueryFilter; ...@@ -8,6 +8,7 @@ import cn.ibizlab.util.filter.QueryFilter;
import java.sql.Timestamp; import java.sql.Timestamp;
import java.util.List; import java.util.List;
import java.util.Set;
public interface CommonEntityService { public interface CommonEntityService {
...@@ -21,10 +22,10 @@ public interface CommonEntityService { ...@@ -21,10 +22,10 @@ public interface CommonEntityService {
int saveResultBatch(List<ExecResult> var1); int saveResultBatch(List<ExecResult> var1);
int clearResultBatch(List<ExecResult> var1); int clearResultBatch(List<ExecResult> var1);
List<ModelObj> getModelObjs(String metaModelId, Timestamp lastModify); List<ModelObj> getModelObjs(String metaModelId, Set<String> fillPropertys, Timestamp lastModify);
ModelObj getModelObjs(String metaModelId, Object factKey); ModelObj getModelObjs(String metaModelId, Set<String> fillPropertys, Object factKey);
ModelObj getModelObjs(String metaModelId, Object... factUniKey); ModelObj getModelObjs(String metaModelId, Set<String> fillPropertys, Object... factUniKey);
List<ModelObj> getModelObjs(String metaModelId, List<EntityObj> kEntityObjs); List<ModelObj> getModelObjs(String metaModelId, Set<String> fillPropertys, List<EntityObj> kEntityObjs);
} }
...@@ -27,6 +27,7 @@ import java.io.Reader; ...@@ -27,6 +27,7 @@ import java.io.Reader;
import java.sql.Timestamp; import java.sql.Timestamp;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Set;
@Service @Service
@Primary @Primary
...@@ -160,7 +161,7 @@ public class DbEntityService extends ServiceImpl<DbEntityMapper, EntityObj> impl ...@@ -160,7 +161,7 @@ public class DbEntityService extends ServiceImpl<DbEntityMapper, EntityObj> impl
@Override @Override
public List<ModelObj> getModelObjs(String metaModelId, Timestamp lastModify) public List<ModelObj> getModelObjs(String metaModelId, Set<String> fillPropertys, Timestamp lastModify)
{ {
DataModel dataModel= JSON.toJavaObject(JSON.parseObject(metaModelService.get(metaModelId).getConfig()), DataModel.class); DataModel dataModel= JSON.toJavaObject(JSON.parseObject(metaModelService.get(metaModelId).getConfig()), DataModel.class);
EntityModel entityModel=dataModel.getFactEntityModel(); EntityModel entityModel=dataModel.getFactEntityModel();
...@@ -172,23 +173,23 @@ public class DbEntityService extends ServiceImpl<DbEntityMapper, EntityObj> impl ...@@ -172,23 +173,23 @@ public class DbEntityService extends ServiceImpl<DbEntityMapper, EntityObj> impl
List<EntityObj> kEntityObjs=this.selectCore(entityModel, filter); List<EntityObj> kEntityObjs=this.selectCore(entityModel, filter);
return getModelObjs(dataModel,kEntityObjs); return getModelObjs(dataModel,fillPropertys,kEntityObjs);
} }
@Override @Override
public ModelObj getModelObjs(String metaModelId, Object factKey) public ModelObj getModelObjs(String metaModelId, Set<String> fillPropertys, Object factKey)
{ {
DataModel dataModel= JSON.toJavaObject(JSON.parseObject(metaModelService.get(metaModelId).getConfig()), DataModel.class); DataModel dataModel= JSON.toJavaObject(JSON.parseObject(metaModelService.get(metaModelId).getConfig()), DataModel.class);
List<EntityObj> kEntityObjs = new ArrayList<>(); List<EntityObj> kEntityObjs = new ArrayList<>();
kEntityObjs.add(new EntityObj().set(dataModel.getFactEntityModel().getKeyField().getColumnName(),factKey)); kEntityObjs.add(new EntityObj().set(dataModel.getFactEntityModel().getKeyField().getColumnName(),factKey));
List<ModelObj> list = getModelObjs(dataModel,kEntityObjs); List<ModelObj> list = getModelObjs(dataModel,fillPropertys,kEntityObjs);
if(list.size()>0) if(list.size()>0)
return list.get(0); return list.get(0);
return null; return null;
} }
@Override @Override
public ModelObj getModelObjs(String metaModelId, Object... factUniKey) public ModelObj getModelObjs(String metaModelId, Set<String> fillPropertys, Object... factUniKey)
{ {
DataModel dataModel= JSON.toJavaObject(JSON.parseObject(metaModelService.get(metaModelId).getConfig()), DataModel.class); DataModel dataModel= JSON.toJavaObject(JSON.parseObject(metaModelService.get(metaModelId).getConfig()), DataModel.class);
List<EntityObj> kEntityObjs = new ArrayList<>(); List<EntityObj> kEntityObjs = new ArrayList<>();
...@@ -197,35 +198,36 @@ public class DbEntityService extends ServiceImpl<DbEntityMapper, EntityObj> impl ...@@ -197,35 +198,36 @@ public class DbEntityService extends ServiceImpl<DbEntityMapper, EntityObj> impl
for(int i=0;i<uniKeys.size();i++) for(int i=0;i<uniKeys.size();i++)
entityObj.set(uniKeys.get(i).getColumnName(),factUniKey[i]); entityObj.set(uniKeys.get(i).getColumnName(),factUniKey[i]);
kEntityObjs.add(entityObj); kEntityObjs.add(entityObj);
List<ModelObj> list = getModelObjs(dataModel,kEntityObjs); List<ModelObj> list = getModelObjs(dataModel,fillPropertys,kEntityObjs);
if(list.size()>0) if(list.size()>0)
return list.get(0); return list.get(0);
return null; return null;
} }
@Override @Override
public List<ModelObj> getModelObjs(String metaModelId, List<EntityObj> kEntityObjs) public List<ModelObj> getModelObjs(String metaModelId, Set<String> fillPropertys, List<EntityObj> kEntityObjs)
{ {
DataModel dataModel= JSON.toJavaObject(JSON.parseObject(metaModelService.get(metaModelId).getConfig()), DataModel.class); DataModel dataModel= JSON.toJavaObject(JSON.parseObject(metaModelService.get(metaModelId).getConfig()), DataModel.class);
return getModelObjs(dataModel,kEntityObjs); return getModelObjs(dataModel,fillPropertys,kEntityObjs);
} }
public List<ModelObj> getModelObjs(DataModel dataModel, List<EntityObj> kEntityObjs) public List<ModelObj> getModelObjs(DataModel dataModel, Set<String> fillPropertys, List<EntityObj> kEntityObjs)
{ {
EntityModel entityModel=dataModel.getFactEntityModel(); EntityModel entityModel=dataModel.getFactEntityModel();
List<ModelObj> rt=new ArrayList<>(); List<ModelObj> rt=new ArrayList<>();
List<EntityObj> factEntityList = new ArrayList<>(); List<EntityObj> factEntityList = new ArrayList<>();
if(fillPropertys==null||fillPropertys.size()==0||fillPropertys.contains(dataModel.getFactPorperty().getPropertyName()))
splitList(kEntityObjs,1000).forEach(list -> factEntityList.addAll(this.selectBase(entityModel, QueryFilter.createQuery().cust(dataModel.lookup(list))))); splitList(kEntityObjs,1000).forEach(list -> factEntityList.addAll(this.selectBase(entityModel, QueryFilter.createQuery().cust(dataModel.lookup(list)))));
factEntityList.forEach(entityObj-> factEntityList.forEach(entityObj->
rt.add(new ModelObj().setDataModel(dataModel).setFactEntity(entityObj.setProperty(dataModel.getFactPorperty())))); rt.add(new ModelObj().setDataModel(dataModel).setFactEntity(entityObj.setProperty(dataModel.getFactPorperty()))));
fillEntityObj(dataModel,rt); fillEntityObj(dataModel,fillPropertys,rt);
dataModel.getNestedDataModels().forEach(subModel-> dataModel.getNestedDataModels().forEach(subModel->
this.getModelObjs(subModel, factEntityList).forEach(subObj->subObj.findParent(rt))); this.getModelObjs(subModel,fillPropertys, factEntityList).forEach(subObj->subObj.findParent(rt)));
rt.forEach(modelObj -> modelObj.getTimestamp()); rt.forEach(modelObj -> modelObj.getTimestamp());
return rt; return rt;
} }
public void fillEntityObj(DataModel dataModel, List<ModelObj> modelObjs) public void fillEntityObj(DataModel dataModel, Set<String> fillPropertys, List<ModelObj> modelObjs)
{ {
if(dataModel.getObjectProperties().size()>1) if(dataModel.getObjectProperties().size()>1)
{ {
...@@ -235,6 +237,7 @@ public class DbEntityService extends ServiceImpl<DbEntityMapper, EntityObj> impl ...@@ -235,6 +237,7 @@ public class DbEntityService extends ServiceImpl<DbEntityMapper, EntityObj> impl
continue; continue;
EntityModel entityModel=property.getEntityModel(); EntityModel entityModel=property.getEntityModel();
List<EntityObj> entityObjs = new ArrayList<>(); List<EntityObj> entityObjs = new ArrayList<>();
if(fillPropertys==null||fillPropertys.size()==0||fillPropertys.contains(property.getPropertyName()))
splitList(modelObjs,1000).forEach(list -> entityObjs.addAll(this.selectBase(entityModel, QueryFilter.createQuery().cust(property.lookup(list))))); splitList(modelObjs,1000).forEach(list -> entityObjs.addAll(this.selectBase(entityModel, QueryFilter.createQuery().cust(property.lookup(list)))));
entityObjs.forEach(entityObj -> { entityObjs.forEach(entityObj -> {
......
...@@ -9,6 +9,7 @@ import org.springframework.stereotype.Service; ...@@ -9,6 +9,7 @@ import org.springframework.stereotype.Service;
import java.sql.Timestamp; import java.sql.Timestamp;
import java.util.List; import java.util.List;
import java.util.Set;
@Service @Service
public class MongoEntityService implements CommonEntityService{ public class MongoEntityService implements CommonEntityService{
...@@ -46,22 +47,22 @@ public class MongoEntityService implements CommonEntityService{ ...@@ -46,22 +47,22 @@ public class MongoEntityService implements CommonEntityService{
} }
@Override @Override
public List<ModelObj> getModelObjs(String metaModelId, Timestamp lastModify) { public List<ModelObj> getModelObjs(String metaModelId, Set<String> fillPropertys, Timestamp lastModify) {
return null; return null;
} }
@Override @Override
public ModelObj getModelObjs(String metaModelId, Object factKey) { public ModelObj getModelObjs(String metaModelId, Set<String> fillPropertys, Object factKey) {
return null; return null;
} }
@Override @Override
public ModelObj getModelObjs(String metaModelId, Object... factUniKey) { public ModelObj getModelObjs(String metaModelId, Set<String> fillPropertys, Object... factUniKey) {
return null; return null;
} }
@Override @Override
public List<ModelObj> getModelObjs(String metaModelId, List<EntityObj> kEntityObjs) { public List<ModelObj> getModelObjs(String metaModelId, Set<String> fillPropertys, List<EntityObj> kEntityObjs) {
return null; return null;
} }
} }
...@@ -48,7 +48,7 @@ public class DstCoreResource { ...@@ -48,7 +48,7 @@ public class DstCoreResource {
if(StringUtils.isEmpty(modelid)) if(StringUtils.isEmpty(modelid))
modelid="dataModelff8080816a8b510c016a8c2f18b10001"; modelid="dataModelff8080816a8b510c016a8c2f18b10001";
List<ModelObj> list=dbEntityService.getModelObjs(modelid, DataObject.getBeginDate()); List<ModelObj> list=dbEntityService.getModelObjs(modelid, null,DataObject.getBeginDate());
return ResponseEntity.ok(list); return ResponseEntity.ok(list);
} }
......
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册