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

field

上级 d878a2b3
...@@ -6,6 +6,7 @@ import cn.ibizlab.core.extensions.cql.ExecResult; ...@@ -6,6 +6,7 @@ import cn.ibizlab.core.extensions.cql.ExecResult;
import cn.ibizlab.core.extensions.domain.BaseRequest; import cn.ibizlab.core.extensions.domain.BaseRequest;
import cn.ibizlab.core.extensions.domain.ResultsMQMsg; import cn.ibizlab.core.extensions.domain.ResultsMQMsg;
import cn.ibizlab.core.extensions.util.DefaultMQProducerService; import cn.ibizlab.core.extensions.util.DefaultMQProducerService;
import cn.ibizlab.core.lite.extensions.domain.FieldObj;
import cn.ibizlab.core.lite.extensions.domain.ModelObj; import cn.ibizlab.core.lite.extensions.domain.ModelObj;
import cn.ibizlab.core.rule.domain.ExecLog; import cn.ibizlab.core.rule.domain.ExecLog;
import cn.ibizlab.core.rule.service.IExecLogService; import cn.ibizlab.core.rule.service.IExecLogService;
...@@ -43,8 +44,9 @@ public class AnalyseEntityServiceImpl extends BaseEntityServiceImpl { ...@@ -43,8 +44,9 @@ public class AnalyseEntityServiceImpl extends BaseEntityServiceImpl {
private cn.ibizlab.util.client.IBZDictFeignClient ibzDictFeignClient; private cn.ibizlab.util.client.IBZDictFeignClient ibzDictFeignClient;
@Override @Override
public void saveResult(ModelObj param, String RULEID, String RULECODE, String RULENAME, String RU_EXECRESULTNAME, Object BUSINESSCAT, Integer RETVALUE, public void saveResult(ModelObj param, String RULEID,String RULECODE, String RULENAME, String RU_EXECRESULTNAME, FieldObj BUSINESSCAT,
Object KEYVALUEFIELD, Object DOMAINSFIELD, Object DIMFIELD, Object METRICFIELD, Object TIMEFIELD, Object EXT1FIELD, Object EXT2FIELD) Integer RETVALUE, FieldObj KEYVALUEFIELD, FieldObj DOMAINSFIELD,FieldObj DIMFIELD,
FieldObj METRICFIELD, FieldObj TIMEFIELD, FieldObj EXT1FIELD, FieldObj EXT2FIELD)
{ {
if(0==RETVALUE) if(0==RETVALUE)
return; return;
...@@ -55,45 +57,48 @@ public class AnalyseEntityServiceImpl extends BaseEntityServiceImpl { ...@@ -55,45 +57,48 @@ public class AnalyseEntityServiceImpl extends BaseEntityServiceImpl {
result.setRulename(RULENAME); result.setRulename(RULENAME);
result.setRuexecresultname(RU_EXECRESULTNAME); result.setRuexecresultname(RU_EXECRESULTNAME);
result.setRetvalue(RETVALUE); result.setRetvalue(RETVALUE);
result.setKeyvaluefield(DataObject.getStringValue(valueOf(KEYVALUEFIELD),param.getRowKey()));
//result.setSystemId(DataObject.getStringValue(param.get("systemid"),null)); if(DOMAINSFIELD==null)
result.setBusinesscat(DataObject.getStringValue(valueOf(BUSINESSCAT),null)); DOMAINSFIELD=param.getEmpty();
if(METRICFIELD!=null) { if(BUSINESSCAT==null)
Object val = METRICFIELD; BUSINESSCAT=param.getEmpty();
if ( (val instanceof BigDecimal)) if(METRICFIELD==null)
result.setMetricfield(((BigDecimal) val).doubleValue()); METRICFIELD=param.getEmpty();
else if ( (val instanceof Double)) if(TIMEFIELD==null)
result.setMetricfield(new BigDecimal((Double) val).doubleValue()); TIMEFIELD=param.getEmpty();
else if ( (val instanceof Float)) if(EXT1FIELD==null)
result.setMetricfield(new BigDecimal(((Float) val).doubleValue()).doubleValue()); EXT1FIELD=param.getEmpty();
else if ( (val instanceof Integer)) if(EXT2FIELD==null)
result.setMetricfield(new BigDecimal((int)val).doubleValue()); EXT2FIELD=param.getEmpty();
else
result.setMetricfield(1d); result.setKeyvaluefield(param.getRowKey());
}
else result.setBusinesscat(BUSINESSCAT.getValue(String.class,null));
result.setMetricfield(1d);
Object timefield=valueOf(TIMEFIELD); result.setMetricfield(METRICFIELD.getDecimal().doubleValue());
if(timefield!=null&&timefield instanceof Timestamp)
result.setTimefield(ExecResult.time2LocalDate(((Timestamp)TIMEFIELD))); Timestamp timefield=TIMEFIELD.getValue(Timestamp.class,null);
if(EXT1FIELD!=null) { if(timefield!=null)
String ext1=valuesOf(EXT1FIELD); result.setTimefield(ExecResult.time2LocalDate(timefield));
if(ext1!=null&&ext1.length()>330)
String ext1=EXT1FIELD.getValues();
if(ext1.length()>330)
ext1=ext1.substring(0,330)+"..."; ext1=ext1.substring(0,330)+"...";
if(!StringUtils.isEmpty(ext1))
result.setExt1field(ext1); result.setExt1field(ext1);
}
if(EXT2FIELD!=null) {
String ext2=valuesOf(EXT2FIELD); String ext2=EXT2FIELD.getValues();
if(ext2!=null&&ext2.length()>330) if(ext2.length()>330)
ext2=ext2.substring(0,330)+"..."; ext2=ext2.substring(0,330)+"...";
if(!StringUtils.isEmpty(ext2))
result.setExt2field(ext2); result.setExt2field(ext2);
}
if(DOMAINSFIELD!=null) result.setDomainsfield(DOMAINSFIELD.getValue(String.class, ""));
{
result.setDomainsfield(DataObject.getStringValue(valueOf(DOMAINSFIELD), ""));
}
if((!StringUtils.isEmpty(result.getRuleid()))&&(!StringUtils.isEmpty(result.getDomainsfield()))&&(!StringUtils.isEmpty(result.getKeyvaluefield()))&&(!ObjectUtils.isEmpty(result.getTimefield()))) { if((!StringUtils.isEmpty(result.getRuleid()))&&(!StringUtils.isEmpty(result.getDomainsfield()))&&(!StringUtils.isEmpty(result.getKeyvaluefield()))&&(!ObjectUtils.isEmpty(result.getTimefield()))) {
result.setUpdatedate(ExecResult.nowLocalDate()); result.setUpdatedate(ExecResult.nowLocalDate());
...@@ -102,8 +107,8 @@ public class AnalyseEntityServiceImpl extends BaseEntityServiceImpl { ...@@ -102,8 +107,8 @@ public class AnalyseEntityServiceImpl extends BaseEntityServiceImpl {
if(dims!=null) { if(dims!=null) {
ArrayList<ExecResult> results = new ArrayList<>(); ArrayList<ExecResult> results = new ArrayList<>();
for (DADimension dim : dims) { for (DADimension dim : dims) {
Object codevalue=param.$(dim.getField()); String codevalue=param.$(dim.getField()).getValue(String.class,"");
if(!ObjectUtils.isEmpty(codevalue)) if(!StringUtils.isEmpty(codevalue))
{ {
String dictname=dim.getDict(); String dictname=dim.getDict();
Object val=codevalue; Object val=codevalue;
...@@ -118,7 +123,7 @@ public class AnalyseEntityServiceImpl extends BaseEntityServiceImpl { ...@@ -118,7 +123,7 @@ public class AnalyseEntityServiceImpl extends BaseEntityServiceImpl {
{ {
ExecResult result2 = new ExecResult(); ExecResult result2 = new ExecResult();
CachedBeanCopier.copy(result, result2); CachedBeanCopier.copy(result, result2);
result2.setDimfield(valuesOf(code.getValue())); result2.setDimfield(code.getValue().toString());
saveResults.add(result2); saveResults.add(result2);
//非逐层核算或无父代码项退出 //非逐层核算或无父代码项退出
if(dim.getRecursive() == 0 || StringUtils.isEmpty(code.getParent())) if(dim.getRecursive() == 0 || StringUtils.isEmpty(code.getParent()))
...@@ -135,7 +140,7 @@ public class AnalyseEntityServiceImpl extends BaseEntityServiceImpl { ...@@ -135,7 +140,7 @@ public class AnalyseEntityServiceImpl extends BaseEntityServiceImpl {
} }
}else{ }else{
//维度未指定代码表时,只保存一条数据 //维度未指定代码表时,只保存一条数据
result.setDimfield(valuesOf(codevalue)); result.setDimfield(codevalue);
saveResults.add(result); saveResults.add(result);
} }
} }
......
package cn.ibizlab.core.extensions.service; package cn.ibizlab.core.extensions.service;
import cn.ibizlab.core.extensions.domain.BaseRequest; import cn.ibizlab.core.extensions.domain.BaseRequest;
import cn.ibizlab.core.lite.extensions.domain.FieldObj;
import cn.ibizlab.core.lite.extensions.domain.ModelObj; import cn.ibizlab.core.lite.extensions.domain.ModelObj;
import cn.ibizlab.core.rule.domain.ExecLog; import cn.ibizlab.core.rule.domain.ExecLog;
import cn.ibizlab.util.errors.BadRequestAlertException; import cn.ibizlab.util.errors.BadRequestAlertException;
...@@ -14,5 +15,6 @@ public interface BaseEntityService { ...@@ -14,5 +15,6 @@ public interface BaseEntityService {
void reset(String keyContainer); void reset(String keyContainer);
ExecLog processAll(BaseRequest msg); ExecLog processAll(BaseRequest msg);
void saveResult(ModelObj param, String RULEID, String RULECODE, String RULENAME, String RU_EXECRESULTNAME, Object BUSINESSCAT, Integer RETVALUE, Object KEYVALUEFIELD, Object DOMAINSFIELD,Object DIMFIELD, Object METRICFIELD, Object TIMEFIELD, Object EXT1FIELD, Object EXT2FIELD); void saveResult(ModelObj param, String RULEID, String RULECODE, String RULENAME, String RU_EXECRESULTNAME, FieldObj BUSINESSCAT, Integer RETVALUE, FieldObj KEYVALUEFIELD, FieldObj DOMAINSFIELD, FieldObj DIMFIELD,
FieldObj METRICFIELD, FieldObj TIMEFIELD, FieldObj EXT1FIELD, FieldObj EXT2FIELD);
} }
\ No newline at end of file
package cn.ibizlab.core.extensions.service; package cn.ibizlab.core.extensions.service;
import cn.ibizlab.core.extensions.domain.BaseRequest; import cn.ibizlab.core.extensions.domain.BaseRequest;
import cn.ibizlab.core.lite.extensions.domain.FieldObj;
import cn.ibizlab.core.lite.extensions.domain.ModelObj; import cn.ibizlab.core.lite.extensions.domain.ModelObj;
import cn.ibizlab.core.rule.domain.ExecLog; import cn.ibizlab.core.rule.domain.ExecLog;
import cn.ibizlab.core.rule.domain.ExecResult; import cn.ibizlab.core.rule.domain.ExecResult;
...@@ -55,49 +56,66 @@ public class BaseEntityServiceImpl implements BaseEntityService ...@@ -55,49 +56,66 @@ public class BaseEntityServiceImpl implements BaseEntityService
} }
public void saveResult(ModelObj param, String RULEID,String RULECODE, String RULENAME, String RU_EXECRESULTNAME, Object BUSINESSCAT, Integer RETVALUE, public void saveResult(ModelObj param, String RULEID,String RULECODE, String RULENAME, String RU_EXECRESULTNAME, FieldObj BUSINESSCAT, Integer RETVALUE, FieldObj KEYVALUEFIELD, FieldObj DOMAINSFIELD,FieldObj DIMFIELD,
Object KEYVALUEFIELD, Object DOMAINSFIELD,Object DIMFIELD, Object METRICFIELD, Object TIMEFIELD, Object EXT1FIELD, Object EXT2FIELD) FieldObj METRICFIELD, FieldObj TIMEFIELD, FieldObj EXT1FIELD, FieldObj EXT2FIELD)
{ {
ExecResult result=new ExecResult(); ExecResult result=new ExecResult();
result.setRuleId(RULEID); result.setRuleId(RULEID);
result.setRuleName(RULENAME); result.setRuleName(RULENAME);
result.setName(RU_EXECRESULTNAME); result.setName(RU_EXECRESULTNAME);
result.setRetValue(RETVALUE); result.setRetValue(RETVALUE);
result.setKeyValueField(DataObject.getStringValue(valueOf(KEYVALUEFIELD),param.getRowKey()));
if(KEYVALUEFIELD==null)
KEYVALUEFIELD=param.getEmpty();
if(DIMFIELD==null)
DIMFIELD=param.getEmpty();
result.setKeyValueField(KEYVALUEFIELD.getValue(param.getRowKey()));
if(1==RETVALUE) if(1==RETVALUE)
{ {
if(DOMAINSFIELD==null)
DOMAINSFIELD=param.getEmpty();
if(BUSINESSCAT==null)
BUSINESSCAT=param.getEmpty();
if(METRICFIELD==null)
METRICFIELD=param.getEmpty();
if(TIMEFIELD==null)
TIMEFIELD=param.getEmpty();
if(EXT1FIELD==null)
EXT1FIELD=param.getEmpty();
if(EXT2FIELD==null)
EXT2FIELD=param.getEmpty();
result.setSystemId(DataObject.getStringValue(param.get("systemid"),null)); result.setSystemId(DataObject.getStringValue(param.get("systemid"),null));
result.setBusinessCat(DataObject.getStringValue(valueOf(BUSINESSCAT),null)); if((!BUSINESSCAT.getDataModelName().equals(DIMFIELD.getDataModelName()))||BUSINESSCAT.isSingle()||DIMFIELD.isSingle())
if(METRICFIELD!=null) { result.setBusinessCat(BUSINESSCAT.getValue(String.class,null));
Object val = METRICFIELD;
if ( (val instanceof BigDecimal)) if((!METRICFIELD.getDataModelName().equals(DIMFIELD.getDataModelName()))||METRICFIELD.isSingle()||DIMFIELD.isSingle())
result.setMetricField(((BigDecimal) val)); result.setMetricField(METRICFIELD.getDecimal());
else if ( (val instanceof Double))
result.setMetricField(new BigDecimal((Double) val));
else if ( (val instanceof Float))
result.setMetricField(new BigDecimal(((Float) val).doubleValue()));
else if ( (val instanceof Integer))
result.setMetricField(new BigDecimal((int)val));
else
result.setMetricField(new BigDecimal(1));
}
else else
result.setMetricField(new BigDecimal(1)); result.setMetricField(new BigDecimal(1));
Object timefield=valueOf(TIMEFIELD);
if(timefield!=null&&timefield instanceof Timestamp) if((!TIMEFIELD.getDataModelName().equals(DIMFIELD.getDataModelName()))||TIMEFIELD.isSingle()||DIMFIELD.isSingle())
result.setTimeField((Timestamp)timefield); result.setTimeField(TIMEFIELD.getValue(Timestamp.class, null));
if(EXT1FIELD!=null) {
String ext1=valuesOf(EXT1FIELD); if((!DOMAINSFIELD.getDataModelName().equals(DIMFIELD.getDataModelName()))||DOMAINSFIELD.isSingle()||DIMFIELD.isSingle())
if(ext1!=null&&ext1.length()>330) result.setDomainsField(DOMAINSFIELD.getValue(String.class, null));
if((!EXT1FIELD.getDataModelName().equals(DIMFIELD.getDataModelName()))||EXT1FIELD.isSingle()||DIMFIELD.isSingle()) {
String ext1=EXT1FIELD.getValues();
if(ext1.length()>330)
ext1=ext1.substring(0,330)+"..."; ext1=ext1.substring(0,330)+"...";
if(!StringUtils.isEmpty(ext1))
result.setExt1Field(ext1); result.setExt1Field(ext1);
} }
if(EXT2FIELD!=null) {
String ext2=valuesOf(EXT2FIELD); if((!EXT2FIELD.getDataModelName().equals(DIMFIELD.getDataModelName()))||EXT2FIELD.isSingle()||DIMFIELD.isSingle()) {
if(ext2!=null&&ext2.length()>330) String ext2=EXT2FIELD.getValues();
if(ext2.length()>330)
ext2=ext2.substring(0,330)+"..."; ext2=ext2.substring(0,330)+"...";
if(!StringUtils.isEmpty(ext2))
result.setExt2Field(ext2); result.setExt2Field(ext2);
} }
} }
...@@ -115,75 +133,92 @@ public class BaseEntityServiceImpl implements BaseEntityService ...@@ -115,75 +133,92 @@ public class BaseEntityServiceImpl implements BaseEntityService
result.set(RuleEngineExService.Setting_ResultDataSource, resultDataSource); result.set(RuleEngineExService.Setting_ResultDataSource, resultDataSource);
result.set(RuleEngineExService.Setting_ResultTableName, resultTableName); result.set(RuleEngineExService.Setting_ResultTableName, resultTableName);
if(DIMFIELD == null){ if(DIMFIELD.isEmpty())
return; return;
}
List dims = null; List dims = null;
if(DIMFIELD instanceof List){ if(DIMFIELD.getValue() instanceof List){
dims = (List)DIMFIELD; dims = (List)DIMFIELD.getValue();
}else { }else {
dims = new ArrayList(); dims = new ArrayList();
dims.add(DataObject.getStringValue(DIMFIELD,null)); dims.add(DIMFIELD.getValue());
} }
for(Object obj : dims){ for(int i=0;i<dims.size();i++){
Object obj = dims.get(i);
result.setDimField(DataObject.getStringValue(obj,null)); result.setDimField(DataObject.getStringValue(obj,null));
if(StringUtils.isEmpty(result.getDimField())) if(StringUtils.isEmpty(result.getDimField()))
continue; continue;
ExecResult result2=new ExecResult(); ExecResult result2=null;
if(DIMFIELD.isMultiple())
{
result2=new ExecResult();
CachedBeanCopier.copy(result, result2); CachedBeanCopier.copy(result, result2);
result2.setId(result.getDefaultKey(true).toString()); }
else
result2=result;
if(KEYVALUEFIELD.getDataModelName().equals(DIMFIELD.getDataModelName())&&KEYVALUEFIELD.getCount()==DIMFIELD.getCount()&&DIMFIELD.isMultiple())
result2.setBusinessCat(KEYVALUEFIELD.getItemValue(i,String.class,param.getRowKey()));
if(result2.getRetValue()==1) if(result2.getRetValue()==1)
{ {
if(BUSINESSCAT.getDataModelName().equals(DIMFIELD.getDataModelName())&&BUSINESSCAT.getCount()==DIMFIELD.getCount()&&DIMFIELD.isMultiple())
result2.setBusinessCat(BUSINESSCAT.getItemValue(i,String.class,null));
if(METRICFIELD.getDataModelName().equals(DIMFIELD.getDataModelName())&&METRICFIELD.getCount()==DIMFIELD.getCount()&&DIMFIELD.isMultiple())
result2.setMetricField(METRICFIELD.getItemDecimal(i));
if(result2.getMetricField()==null)
continue;
if(TIMEFIELD.getDataModelName().equals(DIMFIELD.getDataModelName())&&TIMEFIELD.getCount()==DIMFIELD.getCount()&&DIMFIELD.isMultiple())
result2.setTimeField(TIMEFIELD.getItemValue(i,Timestamp.class, null));
if(result2.getTimeField()==null)
continue;
if(DOMAINSFIELD.getDataModelName().equals(DIMFIELD.getDataModelName())&&DOMAINSFIELD.getCount()==DIMFIELD.getCount()&&DIMFIELD.isMultiple())
result2.setDomainsField(DOMAINSFIELD.getItemValue(i,String.class,result2.getDimField()));
if(result2.getDomainsField()==null)
result2.setDomainsField(result2.getDimField());
if(EXT1FIELD.getDataModelName().equals(DIMFIELD.getDataModelName())&&EXT1FIELD.getCount()==DIMFIELD.getCount()&&DIMFIELD.isMultiple()) {
String ext1=EXT1FIELD.getItemValue(i,String.class,"");
if(ext1.length()>330)
ext1=ext1.substring(0,330)+"...";
if(!StringUtils.isEmpty(ext1))
result2.setExt1Field(ext1);
}
if(EXT2FIELD.getDataModelName().equals(DIMFIELD.getDataModelName())&&EXT2FIELD.getCount()==DIMFIELD.getCount()&&DIMFIELD.isMultiple()) {
String ext2=EXT2FIELD.getItemValue(i,String.class,"");
if(ext2.length()>330)
ext2=ext2.substring(0,330)+"...";
if(!StringUtils.isEmpty(ext2))
result2.setExt2Field(ext2);
}
result2.setId(result2.getDefaultKey(true).toString());
result2.setRuleId(RULECODE); result2.setRuleId(RULECODE);
result2.setDomainsField(DataObject.getStringValue(valueOf(DOMAINSFIELD),result.getDimField()));
ruExecResultService.saveAsync(result2); ruExecResultService.saveAsync(result2);
} }
else else
{ {
result2.setId(result2.getDefaultKey(true).toString());
ruExecResultService.deleteAsync(result2); ruExecResultService.deleteAsync(result2);
} }
} }
} }
protected Object valueOf(Object val)
{
Object rt=null;
if(val!=null && val instanceof List)
{
for(Object item:(List)val){
if(item!=null) {
if(rt==null|| RuleUtils.gt(rt,val))
rt = item;
}
}
}
else if(val!=null)
{
rt=val;
}
return rt;
}
protected String valuesOf(Object val)
{
String rt=null;
if(val!=null && val instanceof List)
{
for(Object item:(List)val){
if(item!=null) {
if(!StringUtils.isEmpty(rt))
rt=rt+",";
rt = rt+DataObject.getStringValue(item,"");
}
}
}
else
{
rt=DataObject.getStringValue(val,null);
}
return rt;
}
@Autowired @Autowired
private IExecResultService ruExecResultService; private IExecResultService ruExecResultService;
...@@ -530,4 +565,4 @@ public class BaseEntityServiceImpl implements BaseEntityService ...@@ -530,4 +565,4 @@ public class BaseEntityServiceImpl implements BaseEntityService
this.ruExecLogService.update(execlog); this.ruExecLogService.update(execlog);
return execlog; return execlog;
} }
} }
\ No newline at end of file \ No newline at end of file
package cn.ibizlab.core.lite.extensions.domain; package cn.ibizlab.core.lite.extensions.domain;
import cn.ibizlab.core.lite.extensions.model.DataModel;
import cn.ibizlab.core.lite.extensions.model.Property;
import cn.ibizlab.util.helper.DataObject;
import cn.ibizlab.util.helper.RuleUtils;
import com.alibaba.fastjson.annotation.JSONField;
import com.fasterxml.jackson.annotation.JsonIgnore;
import lombok.Getter; import lombok.Getter;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import lombok.Setter; import lombok.Setter;
import lombok.experimental.Accessors; import lombok.experimental.Accessors;
import org.springframework.util.StringUtils;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.sql.Timestamp;
import java.util.List;
@Getter @Getter
@Setter @Setter
@NoArgsConstructor @NoArgsConstructor
@Accessors(chain = true) @Accessors(chain = true)
public class FieldObj<T> { public class FieldObj {
public DataModel getDataModel()
{
if(property!=null)
return property.getOwnerDataModel();
return null;
}
@JsonIgnore
@JSONField(serialize = false)
public String getDataModelName()
{
if(getDataModel()!=null&&getDataModel().getDataModelName()!=null)
return getDataModel().getDataModelName();
else
return "";
}
@JsonIgnore
@JSONField(serialize = false)
private Property property;
public FieldObj setProperty(Property property)
{
this.property=property;
return this;
}
private String columnName; private String columnName;
private T obj; private Object value;
public <T> T getValue(T defaultVal)
{
return getValue(null,defaultVal);
}
public <T> T getValue(Class<T> type,T defaultVal)
{
T ret=defaultVal;
if(value==null)
return ret;
Object obj=null;
if((!(defaultVal instanceof List))&&(value instanceof List))
{
for(Object item:(List)value){
if(item!=null) {
if(obj==null|| RuleUtils.gt(obj,item))
obj = item;
}
}
if(obj==null)
return defaultVal;
}
else
{
obj=value;
}
if(type == null && defaultVal != null)
type = (Class<T>) defaultVal.getClass();
ret = DataObject.valueOf(type,obj);
if(ret==null)
return defaultVal;
return ret;
}
public <T> T getItemValue(int idx,Class<T> type,T defaultVal)
{
if(value instanceof List)
{
List list=(List)value;
if(list.size()>idx)
{
T ret=DataObject.valueOf(type,list.get(idx));
if(ret==null)
return defaultVal;
}
return defaultVal;
}
else
return getValue(type,defaultVal);
}
@JsonIgnore
@JSONField(serialize = false)
public String getValues()
{
String rt="";
if(value!=null && value instanceof List)
{
for(Object item:(List)value){
if(item!=null) {
if((!StringUtils.isEmpty(rt))&&(!rt.endsWith(",")))
rt=rt+",";
rt = rt+DataObject.getStringValue(item,"");
}
}
}
else
{
rt=DataObject.getStringValue(value,"");
}
return rt;
}
@JsonIgnore
@JSONField(serialize = false)
public Integer getCount()
{
return getCount(true);
}
@JsonIgnore
@JSONField(serialize = false)
public Integer getCount(boolean includeNull)
{
if(includeNull)
{
if(value instanceof List)
return ((List) value).size()==0?1:((List) value).size();
else
return 1;
}
if(value==null)
return 0;
else if(value instanceof List)
{
List list = (List)value;
int cnt=0;
for(Object item:list)
cnt+=StringUtils.isEmpty(DataObject.getStringValue(list.get(0),null))?0:1;
return cnt;
}
else
return StringUtils.isEmpty(value.toString())?0:1;
}
@JsonIgnore
@JSONField(serialize = false)
public Boolean isEmpty()
{
return getCount(false)==0;
}
@JsonIgnore
@JSONField(serialize = false)
public Boolean isNotEmpty()
{
return !isEmpty();
}
@JsonIgnore
@JSONField(serialize = false)
public Boolean isMultiple()
{
return getCount()>1;
}
@JsonIgnore
@JSONField(serialize = false)
public Boolean isSingle()
{
return !isMultiple();
}
@JsonIgnore
@JSONField(serialize = false)
public Boolean isSingleAndNotEmpty()
{
return isSingle()&&isNotEmpty();
}
@JsonIgnore
@JSONField(serialize = false)
public BigDecimal getDecimal()
{
BigDecimal decimal = new BigDecimal(1);
Object val = this.getValue(Object.class,null);
if(val == null)
decimal=(new BigDecimal(1));
else if ( (val instanceof BigDecimal))
decimal=(((BigDecimal) val));
else if (val instanceof Double)
decimal=(new BigDecimal((Double) val));
else if (val instanceof Float)
decimal=(new BigDecimal(((Float) val).doubleValue()));
else if (val instanceof Integer)
decimal=(new BigDecimal((int)val));
else if (val instanceof Long)
decimal=(new BigDecimal((Long)val));
if(decimal.intValue()>Integer.MAX_VALUE)
decimal=(new BigDecimal(1));
return decimal;
}
public BigDecimal getItemDecimal(int idx)
{
BigDecimal decimal = new BigDecimal(1);
Object val = this.getItemValue(idx,Object.class,null);
if(val == null)
decimal=(new BigDecimal(1));
else if ( (val instanceof BigDecimal))
decimal=(((BigDecimal) val));
else if (val instanceof Double)
decimal=(new BigDecimal((Double) val));
else if (val instanceof Float)
decimal=(new BigDecimal(((Float) val).doubleValue()));
else if (val instanceof Integer)
decimal=(new BigDecimal((int)val));
else if (val instanceof Long)
decimal=(new BigDecimal((Long)val));
if(decimal.intValue()>Integer.MAX_VALUE)
decimal=(new BigDecimal(1));
return decimal;
}
@Override
public String toString()
{
return getValues();
}
public static void main(String[] args)
{
FieldObj fieldObj=new FieldObj();
fieldObj.setValue(new BigDecimal(1));
Object t=fieldObj.getValue(Object.class,null);
System.out.println(t);
}
} }
...@@ -321,7 +321,7 @@ public class ModelObj extends DataObj<String,Object> { ...@@ -321,7 +321,7 @@ public class ModelObj extends DataObj<String,Object> {
public Object $(String key) public FieldObj $(String key)
{ {
if(key.toString().indexOf(".")>0) if(key.toString().indexOf(".")>0)
{ {
...@@ -331,13 +331,16 @@ public class ModelObj extends DataObj<String,Object> { ...@@ -331,13 +331,16 @@ public class ModelObj extends DataObj<String,Object> {
String name=epair[0]; String name=epair[0];
String column=epair[1]; String column=epair[1];
Property property=this.getDataModel().findObjectProperty(name,"UP"); Property property=this.getDataModel().findObjectProperty(name,"UP");
if(property!=null) if(property!=null) {
return this.getEntity(name).get(column); Object val=this.getEntity(name).get(column);
return new FieldObj().setValue(val).setProperty(property);
}
property=this.getDataModel().findObjectProperty(name,"DOWN"); property=this.getDataModel().findObjectProperty(name,"DOWN");
if(property!=null) if(property!=null)
{ {
return this.getNested(property.getOwnerDataModel().getDataModelName()).get(key); Object val=this.getNested(property.getOwnerDataModel().getDataModelName()).get(key);
return new FieldObj().setValue(val).setProperty(property);
} }
if(this.getParent()!=null) if(this.getParent()!=null)
...@@ -346,23 +349,31 @@ public class ModelObj extends DataObj<String,Object> { ...@@ -346,23 +349,31 @@ public class ModelObj extends DataObj<String,Object> {
} }
} }
return get(key); return new FieldObj().setValue(get(key)).setProperty(this.getDataModel().getFactPorperty());
} }
@JsonIgnore
@JSONField(serialize = false)
private FieldObj empty;
public Double $D(String key) @JsonIgnore
@JSONField(serialize = false)
public FieldObj getEmpty()
{ {
Object val=this.get(key); if(empty==null)
if(val==null) empty=new FieldObj().setValue(null).setProperty(this.getDataModel().getFactPorperty());
return 0d; return empty;
else if((val instanceof Integer)||(val instanceof Double)||(val instanceof Long)||(val instanceof BigDecimal)||(val instanceof BigInteger)||(val instanceof Float)) }
return (double)val;
return 1d; public FieldObj $S(String val)
{
return new FieldObj().setValue(val).setProperty(this.getDataModel().getFactPorperty());
} }
public boolean IF(String cond) public boolean IF(String cond)
{ {
String[] arr=cond.split("\\s+"); String[] arr=cond.split("\\s+");
......
...@@ -11,7 +11,7 @@ activation-group "<#if ruleid??>${ruleid}</#if>" ...@@ -11,7 +11,7 @@ activation-group "<#if ruleid??>${ruleid}</#if>"
${datamodelname}:ModelObj( <#if rulecond??>${rulecond}</#if> ) ${datamodelname}:ModelObj( <#if rulecond??>${rulecond}</#if> )
<#if (releationcond??)>${releationcond}</#if> <#if (releationcond??)>${releationcond}</#if>
then then
BaseService.saveResult(${datamodelname},"<#if ruleid??>${ruleid}</#if>","<#if rulecode??>${rulecode}</#if>","<#if rulename??>${rulename}</#if>","<#if memo??>${memo}</#if>",<#if hasbusinesscatfield>${businesscatfield}<#else>"${businesscat}"</#if>,1,${keyvaluefield},${domainsfield},${dimfield},${metricfield},${timefield},${ext1field},${ext2field}); BaseService.saveResult(${datamodelname},"<#if ruleid??>${ruleid}</#if>","<#if rulecode??>${rulecode}</#if>","<#if rulename??>${rulename}</#if>","<#if memo??>${memo}</#if>",<#if hasbusinesscatfield>${businesscatfield}<#else>$S("${businesscat}")</#if>,1,${keyvaluefield},${domainsfield},${dimfield},${metricfield},${timefield},${ext1field},${ext2field});
end end
rule "<#if ruleid??>${ruleid}_d</#if>" rule "<#if ruleid??>${ruleid}_d</#if>"
salience 0 salience 0
......
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册