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

litedata 逻辑

上级 6014a1f9
server: server:
port: 8086 port: 8086
ibiz:
filePath: /app/file/
#nacos配置中心 #nacos配置中心
spring: spring:
cloud: cloud:
......
...@@ -58,6 +58,13 @@ ...@@ -58,6 +58,13 @@
<artifactId>mybatis-plus-boot-starter</artifactId> <artifactId>mybatis-plus-boot-starter</artifactId>
</dependency> </dependency>
<!-- MyBatis游标查询 -->
<dependency>
<groupId>org.springframework.batch</groupId>
<artifactId>spring-batch-core</artifactId>
<version>4.1.2.RELEASE</version>
</dependency>
<!-- MySQL数据库 --> <!-- MySQL数据库 -->
<dependency> <dependency>
<groupId>mysql</groupId> <groupId>mysql</groupId>
......
...@@ -4,11 +4,12 @@ import cn.ibizlab.core.lite.extensions.domain.EntityObj; ...@@ -4,11 +4,12 @@ import cn.ibizlab.core.lite.extensions.domain.EntityObj;
import com.baomidou.mybatisplus.core.conditions.Wrapper; import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Param; import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import java.util.List; import java.util.List;
public interface DbEntityMapper extends BaseMapper<EntityObj>{ public interface DbEntityMapper extends BaseMapper<EntityObj>{
List<EntityObj> search(@Param("sql") String sql,@Param("ew") Wrapper<EntityObj> wrapper); List<EntityObj> search(@Param("sql") String sql, @Param("ew") Wrapper<EntityObj> wrapper);
Integer searchCount(@Param("sql") String sql, @Param("ew") Wrapper<EntityObj> wrapper);
} }
\ No newline at end of file
...@@ -45,6 +45,7 @@ public class DstDataSourceExService extends DstDataSourceServiceImpl { ...@@ -45,6 +45,7 @@ public class DstDataSourceExService extends DstDataSourceServiceImpl {
@Resource @Resource
public DstLiquibaseService dstLiquibaseService; public DstLiquibaseService dstLiquibaseService;
/** /**
* [BuildDS:buildDS] 行为扩展 * [BuildDS:buildDS] 行为扩展
* @param dstDataSource * @param dstDataSource
...@@ -54,34 +55,39 @@ public class DstDataSourceExService extends DstDataSourceServiceImpl { ...@@ -54,34 +55,39 @@ public class DstDataSourceExService extends DstDataSourceServiceImpl {
@Transactional @Transactional
public DstDataSource buildDS(DstDataSource dstDataSource) { public DstDataSource buildDS(DstDataSource dstDataSource) {
if(!(StringUtils.isEmpty(dstDataSource.getDsCfg()))) if(dstDataSource!=null&&(!StringUtils.isEmpty(dstDataSource.getDsCfg())))
{ {
synchronized (lock) synchronized (lock)
{ {
if (check.containsKey(dstDataSource.getDsName())) if (check.containsKey(dstDataSource.getDsName()))
return super.buildDS(dstDataSource); return super.buildDS(dstDataSource);
DataSourceProperty dataSourceProperty = new DataSourceProperty();
DynamicRoutingDataSource ds = dataSource; if(!"mongodb".equalsIgnoreCase(dstDataSource.getDsType()))
List<Setting> settings = JSONArray.parseArray(dstDataSource.getDsCfg(), Setting.class);
for (Setting setting : settings)
{ {
if (setting.getProperty().equalsIgnoreCase("driver-class-name")) DataSourceProperty dataSourceProperty = new DataSourceProperty();
dataSourceProperty.setDriverClassName(setting.getValue()); DynamicRoutingDataSource ds = dataSource;
else if (setting.getProperty().equalsIgnoreCase("username")) List<Setting> settings = JSONArray.parseArray(dstDataSource.getDsCfg(), Setting.class);
dataSourceProperty.setUsername(setting.getValue()); for (Setting setting : settings)
else if (setting.getProperty().equalsIgnoreCase("password")) {
dataSourceProperty.setPassword(setting.getValue()); if (setting.getProperty().equalsIgnoreCase("driver-class-name"))
else if (setting.getProperty().equalsIgnoreCase("url")) dataSourceProperty.setDriverClassName(setting.getValue());
dataSourceProperty.setUrl(setting.getValue()); else if (setting.getProperty().equalsIgnoreCase("username"))
else if (setting.getProperty().equalsIgnoreCase("defaultSchema")) dataSourceProperty.setUsername(setting.getValue());
dataSourceProperty.setSchema(setting.getValue()); else if (setting.getProperty().equalsIgnoreCase("password"))
dataSourceProperty.setPassword(setting.getValue());
else if (setting.getProperty().equalsIgnoreCase("url"))
dataSourceProperty.setUrl(setting.getValue());
else if (setting.getProperty().equalsIgnoreCase("defaultSchema"))
dataSourceProperty.setSchema(setting.getValue());
}
dataSourceProperty.getDruid().setFilters("stat,log4j2");
DataSource dataSource = druidDataSourceCreator.createDataSource(dataSourceProperty);
ds.addDataSource(dstDataSource.getDsName(), dataSource);
} }
dataSourceProperty.getDruid().setFilters("stat,log4j2"); check.put(dstDataSource.getDsName(), StringUtils.isEmpty(dstDataSource.getDsType())?"mysql":dstDataSource.getDsType());
DataSource dataSource = druidDataSourceCreator.createDataSource(dataSourceProperty);
ds.addDataSource(dstDataSource.getDsName(), dataSource);
check.put(dstDataSource.getDsName(), 1);
} }
} }
...@@ -97,25 +103,24 @@ public class DstDataSourceExService extends DstDataSourceServiceImpl { ...@@ -97,25 +103,24 @@ public class DstDataSourceExService extends DstDataSourceServiceImpl {
private DataSourceCreator druidDataSourceCreator; private DataSourceCreator druidDataSourceCreator;
private HashMap<String,Integer> check=new HashMap<>(); private HashMap<String,String> check=new HashMap<>();
private Object lock=new Object(); private Object lock=new Object();
public void initDataSource(String dsName) public synchronized String initDataSource(String dsName)
{ {
DstDataSource dstDataSource=null;
synchronized (lock) synchronized (lock)
{ {
if (check.containsKey(dsName)) if (check.containsKey(dsName))
return; return check.get(dsName);
dstDataSource=this.getOne(Wrappers.<DstDataSource>lambdaQuery().eq(DstDataSource::getDsId,dsName).or().eq(DstDataSource::getDsName,dsName),false);
if(dstDataSource!=null) dstDataSource.setDsName(dsName);
} }
buildDS(dstDataSource);
DstDataSource dstDataSource=this.getOne(Wrappers.<DstDataSource>lambdaQuery().eq(DstDataSource::getDsId,dsName).or().eq(DstDataSource::getDsName,dsName),false); synchronized (lock)
if(dstDataSource!=null)
{ {
dstDataSource.setDsName(dsName); return StringUtils.isEmpty(check.get(dsName))?"mysql":check.get(dsName);
buildDS(dstDataSource);
} }
} }
@Override @Override
...@@ -127,12 +132,14 @@ public class DstDataSourceExService extends DstDataSourceServiceImpl { ...@@ -127,12 +132,14 @@ public class DstDataSourceExService extends DstDataSourceServiceImpl {
DynamicRoutingDataSource ds = (DynamicRoutingDataSource) dataSource; DynamicRoutingDataSource ds = (DynamicRoutingDataSource) dataSource;
if (check.containsKey(et.getDsId())) if (check.containsKey(et.getDsId()))
{ {
ds.removeDataSource(et.getDsId()); if(!"mongodb".equalsIgnoreCase(check.get(et.getDsId())))
ds.removeDataSource(et.getDsId());
check.remove(et.getDsId()); check.remove(et.getDsId());
} }
if (check.containsKey(et.getDsName())) if (check.containsKey(et.getDsName()))
{ {
ds.removeDataSource(et.getDsName()); if(!"mongodb".equalsIgnoreCase(check.get(et.getDsName())))
ds.removeDataSource(et.getDsName());
check.remove(et.getDsName()); check.remove(et.getDsName());
} }
} }
...@@ -140,6 +147,7 @@ public class DstDataSourceExService extends DstDataSourceServiceImpl { ...@@ -140,6 +147,7 @@ public class DstDataSourceExService extends DstDataSourceServiceImpl {
return true; return true;
} }
@Override @Override
@Transactional @Transactional
public DstDataSource initDS(DstDataSource et) { public DstDataSource initDS(DstDataSource et) {
......
...@@ -22,26 +22,38 @@ import java.util.Map; ...@@ -22,26 +22,38 @@ import java.util.Map;
@JsonIgnoreProperties(value = "handler") @JsonIgnoreProperties(value = "handler")
public class EntityModel { public class EntityModel {
@JsonIgnore
@JSONField(serialize = false)
public String getEntityId() { public String getEntityId() {
return getEntity().getEntityId(); return getEntity().getEntityId();
} }
@JsonIgnore
@JSONField(serialize = false)
public String getCodeName() { public String getCodeName() {
return getEntity().getCodeName(); return getEntity().getCodeName();
} }
@JsonIgnore
@JSONField(serialize = false)
public String getEntityName() { public String getEntityName() {
return getEntity().getEntityName(); return getEntity().getEntityName();
} }
@JsonIgnore
@JSONField(serialize = false)
public String getTableName() { public String getTableName() {
return getEntity().getTableName(); return getEntity().getTableName();
} }
@JsonIgnore
@JSONField(serialize = false)
public String getLogicName() { public String getLogicName() {
return getEntity().getLogicName(); return getEntity().getLogicName();
} }
@JsonIgnore
@JSONField(serialize = false)
public String getSystemId() { public String getSystemId() {
return getEntity().getSystemId(); return getEntity().getSystemId();
} }
...@@ -192,18 +204,12 @@ public class EntityModel { ...@@ -192,18 +204,12 @@ public class EntityModel {
String columnExp=fieldModel.getColumnExp(); String columnExp=fieldModel.getColumnExp();
if(StringUtils.isEmpty(columnExp)) if(StringUtils.isEmpty(columnExp))
continue; continue;
// if(fieldModel.isPhysicalField())
// continue;
if(!StringUtils.isEmpty(columnSet)){ if(!StringUtils.isEmpty(columnSet)){
columnSet=columnSet+","; columnSet=columnSet+",";
} }
columnSet=columnSet+columnExp; columnSet=columnSet+columnExp;
} }
// if(!StringUtils.isEmpty(columnSet)){
// columnSet=columnSet+",";
// }
//columnSet=columnSet+"t.*";
return "select "+columnSet+" from "+this.getTableName()+" t "; return "select "+columnSet+" from "+this.getTableName()+" t ";
} }
else if("CORE".equalsIgnoreCase(dataSet)) else if("CORE".equalsIgnoreCase(dataSet))
...@@ -219,6 +225,10 @@ public class EntityModel { ...@@ -219,6 +225,10 @@ public class EntityModel {
return "select "+columnSet+" from "+this.getTableName()+" "; return "select "+columnSet+" from "+this.getTableName()+" ";
} }
else if("COUNT".equalsIgnoreCase(dataSet))
{
return "select count(1) from "+this.getTableName()+" ";
}
else else
{ {
if(dataSets!=null) if(dataSets!=null)
...@@ -229,6 +239,8 @@ public class EntityModel { ...@@ -229,6 +239,8 @@ public class EntityModel {
return ""; return "";
} }
@JsonIgnore
@JSONField(serialize = false)
public String getDsName() public String getDsName()
{ {
String dsName=this.getEntity().getDsId(); String dsName=this.getEntity().getDsId();
...@@ -242,18 +254,7 @@ public class EntityModel { ...@@ -242,18 +254,7 @@ public class EntityModel {
public String getExtParams(String key) public String getExtParams(String key)
{ {
if(!(StringUtils.isEmpty(this.getEntity().getExtParams()))) return Setting.getValue(this.getEntity().getExtParams(),key);
{
List<Setting> settings=JSONArray.parseArray(this.getEntity().getExtParams(),Setting.class);
for(Setting setting:settings)
{
if(key.equals(setting.getValue()))
{
return setting.getValue();
}
}
}
return null;
} }
......
...@@ -166,4 +166,13 @@ public class EntityObj extends DataObj<String,Object> { ...@@ -166,4 +166,13 @@ public class EntityObj extends DataObj<String,Object> {
}); });
} }
} }
public boolean isDelete()
{
if(!this.getEntityModel().isLogicValid())
return false;
if(this.getEntityModel().getLogicVal().equals(this.get(this.getEntityModel().getLogicValidField().getColumnName())))
return false;
return true;
}
} }
...@@ -3,12 +3,16 @@ package cn.ibizlab.core.lite.extensions.domain; ...@@ -3,12 +3,16 @@ package cn.ibizlab.core.lite.extensions.domain;
import cn.ibizlab.core.lite.extensions.model.DataModel; import cn.ibizlab.core.lite.extensions.model.DataModel;
import cn.ibizlab.core.lite.extensions.model.Property; import cn.ibizlab.core.lite.extensions.model.Property;
import cn.ibizlab.util.helper.DataObject; import cn.ibizlab.util.helper.DataObject;
import cn.ibizlab.util.helper.RuleUtils;
import com.alibaba.fastjson.annotation.JSONField; import com.alibaba.fastjson.annotation.JSONField;
import com.fasterxml.jackson.annotation.JsonIgnore; import com.fasterxml.jackson.annotation.JsonIgnore;
import org.springframework.util.StringUtils; import org.springframework.util.StringUtils;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.sql.Timestamp; import java.sql.Timestamp;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Calendar;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
...@@ -269,4 +273,146 @@ public class ModelObj extends DataObj<String,Object> { ...@@ -269,4 +273,146 @@ public class ModelObj extends DataObj<String,Object> {
return this; return this;
} }
public Object $(String key)
{
if(key.toString().indexOf(".")>0)
{
String[] epair=key.toString().split("[.]");
if(epair.length>=2)
{
String name=epair[0];
String column=epair[1];
Property property=this.getDataModel().findObjectProperty(name,"UP");
if(property!=null)
return this.getEntity(name).get(column);
property=this.getDataModel().findObjectProperty(name,"DOWN");
if(property!=null)
{
return this.getNested(property.getOwnerDataModel().getDataModelName()).get(key);
}
if(this.getParent()!=null)
return this.getParent().$(key);
}
}
return get(key);
}
public Double $D(String key)
{
Object val=this.get(key);
if(val==null)
return 0d;
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 boolean IF(String cond)
{
String[] arr=cond.split("\\s+");
String option="";
String members="";
String exp="";
if(arr.length>=2)
{
members=arr[0];
option=arr[1];
}
Object val=null;
String[] ms=members.split("[.]");
if(ms.length>=2&&(!StringUtils.isEmpty(ms[0])))
{
EntityObj sub=this.getEntity(ms[0]);
if(sub.isDelete())
return false;
if(sub!=null)
{
val=sub.get(ms[1]);
}
}
if(arr.length>=3)
{
exp=arr[2];
if(exp.startsWith("%"))
{
return RuleUtils.test(val, option, execFunc(exp));
}
}
return RuleUtils.test(val,option, exp);
}
private Object execFunc(String exp)
{
exp=exp.replace("%", "").trim();
if(exp.startsWith("DAY("))
{
Calendar calendar = Calendar.getInstance();
String quStr=exp.substring(exp.indexOf("(")+1,exp.indexOf(")"));
quStr=quStr.replace("+","").trim();
int day=0;
if(!StringUtils.isEmpty(quStr)){
day= Integer.parseInt(quStr);
}
calendar.add(Calendar.DATE, day);
return new Timestamp(calendar.getTime().getTime());
}
else if(exp.endsWith(")"))
{
String quStr=exp.substring(exp.indexOf("(")+1,exp.indexOf(")"));
exp = exp.substring(0,exp.indexOf("(")).trim();
quStr=quStr.replace("+","").trim();
Integer day=0;
if(!StringUtils.isEmpty(quStr)){
day= Integer.parseInt(quStr);
}
Object val = this.get(exp);
if(val!=null)
{
if(val instanceof Timestamp)
{
Calendar calendar = Calendar.getInstance();
calendar.setTime((Timestamp)val);
calendar.add(Calendar.DATE, day);
return new Timestamp(calendar.getTime().getTime());
}
else if(val instanceof Integer)
{
return (int)val+day;
}
else if(val instanceof BigDecimal)
{
return ((BigDecimal)val).intValue()+day;
}
}
return val;
}
return null;
}
} }
...@@ -7,6 +7,8 @@ import com.fasterxml.jackson.annotation.JsonIgnore; ...@@ -7,6 +7,8 @@ import com.fasterxml.jackson.annotation.JsonIgnore;
import java.sql.Timestamp; import java.sql.Timestamp;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.LinkedHashSet;
import java.util.List;
public class NestedArray extends ArrayList<ModelObj> { public class NestedArray extends ArrayList<ModelObj> {
...@@ -64,4 +66,52 @@ public class NestedArray extends ArrayList<ModelObj> { ...@@ -64,4 +66,52 @@ public class NestedArray extends ArrayList<ModelObj> {
return last; return last;
} }
public List<Object> get(String key)
{
List<Object> list=new ArrayList<>();
if(key==null)
return null;
if(key.indexOf(".")>0)
{
String[] epair=key.toString().split("[.]");
if(epair.length>=2)
{
String name=epair[0];
String column=epair[1];
this.forEach(modelObj -> {
Object obj=modelObj.getEntity(name).get(column);
list.add(obj);
});
}
}
return list;
}
public List<Object> get(String key,String cond)
{
List<Object> list=new ArrayList<>();
if(key==null)
return null;
if(key.indexOf(".")>0)
{
String[] epair=key.toString().split("[.]");
if(epair.length>=2)
{
String name=epair[0];
String column=epair[1];
this.forEach(modelObj -> {
if(modelObj.IF(cond))
{
Object obj=modelObj.getEntity(name).get(column);
list.add(obj);
}
});
}
}
return list;
}
} }
package cn.ibizlab.core.lite.extensions.domain; package cn.ibizlab.core.lite.extensions.domain;
import com.alibaba.fastjson.JSONArray;
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.util.List;
@Getter @Getter
@Setter @Setter
...@@ -12,4 +16,21 @@ import lombok.experimental.Accessors; ...@@ -12,4 +16,21 @@ import lombok.experimental.Accessors;
public class Setting { public class Setting {
private String property; private String property;
private String value; private String value;
public static String getValue(String configString,String propertyName)
{
if(!(StringUtils.isEmpty(configString)))
{
List<Setting> settings= JSONArray.parseArray(configString,Setting.class);
for(Setting setting:settings)
{
if(propertyName.equals(setting.getProperty()))
{
return setting.getValue();
}
}
}
return "";
}
} }
...@@ -2,6 +2,8 @@ package cn.ibizlab.core.lite.extensions.model; ...@@ -2,6 +2,8 @@ package cn.ibizlab.core.lite.extensions.model;
import cn.ibizlab.core.lite.extensions.domain.EntityModel; import cn.ibizlab.core.lite.extensions.domain.EntityModel;
import cn.ibizlab.core.lite.extensions.domain.EntityObj; import cn.ibizlab.core.lite.extensions.domain.EntityObj;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.alibaba.fastjson.annotation.JSONField; import com.alibaba.fastjson.annotation.JSONField;
import com.fasterxml.jackson.annotation.JsonIgnore; import com.fasterxml.jackson.annotation.JsonIgnore;
import lombok.Getter; import lombok.Getter;
...@@ -20,6 +22,27 @@ import java.util.List; ...@@ -20,6 +22,27 @@ import java.util.List;
@NoArgsConstructor @NoArgsConstructor
@Accessors(chain = true) @Accessors(chain = true)
public class DataModel { public class DataModel {
@JsonIgnore
@JSONField(serialize = false)
private String modelString;
public String getModelString()
{
if(StringUtils.isEmpty(modelString))
{
modelString= JSONObject.toJSONString(this);
}
return modelString;
}
@JsonIgnore
@JSONField(serialize = false)
public DataModel clone()
{
DataModel clone = JSON.toJavaObject(JSONObject.parseObject(this.getModelString()),DataModel.class);
clone.setModelString(this.getModelString());
return clone;
}
@JsonIgnore @JsonIgnore
@JSONField(serialize = false) @JSONField(serialize = false)
...@@ -138,9 +161,6 @@ public class DataModel { ...@@ -138,9 +161,6 @@ public class DataModel {
for (Property property:this.getObjectProperties()) for (Property property:this.getObjectProperties())
if(name.equalsIgnoreCase(property.getPropertyName())) if(name.equalsIgnoreCase(property.getPropertyName()))
return property; return property;
for (Property property:this.getObjectProperties())
if(name.equalsIgnoreCase(property.getPropertyEntity()))
return property;
} }
return null; return null;
} }
...@@ -336,7 +356,8 @@ public class DataModel { ...@@ -336,7 +356,8 @@ public class DataModel {
@JSONField(serialize = false) @JSONField(serialize = false)
public LinkedHashSet<Property> getAllProperty() public LinkedHashSet<Property> getAllProperty()
{ {
LinkedHashSet<Property> properties=this.getObjectProperties(); LinkedHashSet<Property> properties=new LinkedHashSet<>();
properties.addAll(this.getObjectProperties());
if (this.getNestedDataModels() != null) { if (this.getNestedDataModels() != null) {
for (DataModel dm : this.getNestedDataModels()) { for (DataModel dm : this.getNestedDataModels()) {
......
...@@ -2,7 +2,7 @@ package cn.ibizlab.core.lite.extensions.service; ...@@ -2,7 +2,7 @@ package cn.ibizlab.core.lite.extensions.service;
import cn.ibizlab.core.lite.extensions.domain.EntityModel; import cn.ibizlab.core.lite.extensions.domain.EntityModel;
import cn.ibizlab.core.lite.extensions.domain.EntityObj; import cn.ibizlab.core.lite.extensions.domain.EntityObj;
import cn.ibizlab.core.lite.extensions.domain.ModelObj; import cn.ibizlab.core.lite.extensions.model.DataModel;
import cn.ibizlab.util.filter.QueryFilter; import cn.ibizlab.util.filter.QueryFilter;
import java.sql.Timestamp; import java.sql.Timestamp;
...@@ -12,15 +12,14 @@ public interface CommonEntityService { ...@@ -12,15 +12,14 @@ public interface CommonEntityService {
List<EntityObj> selectBase(EntityModel entityModel, QueryFilter filter); List<EntityObj> selectBase(EntityModel entityModel, QueryFilter filter);
List<EntityObj> selectCore(EntityModel entityModel, QueryFilter filter); List<EntityObj> selectCore(EntityModel entityModel, QueryFilter filter);
Integer selectCount(EntityModel entityModel, QueryFilter filter);
List<EntityObj> search(String dataSet, EntityModel entityModel, QueryFilter filter); List<EntityObj> search(String dataSet, EntityModel entityModel, QueryFilter filter);
List<EntityObj> search(String dsName, String sql, QueryFilter filter); List<EntityObj> search(String dsName, String sql, QueryFilter filter);
List<ModelObj> getModelObjs(String metaModelId, Timestamp lastModify);
ModelObj getModelObjs(String metaModelId, Object factKey); void processList(DataModel dataModel, Timestamp lastModify, LiteDataCallback callback);
ModelObj getModelObjs(String metaModelId, Object... factUniKey);
List<ModelObj> getModelObjs(String metaModelId, List<EntityObj> kEntityObjs);
} }
package cn.ibizlab.core.lite.extensions.service;
public interface LiteDataCallback<K> {
void total(Integer total);
boolean processData(K k);
}
package cn.ibizlab.core.lite.extensions.service;
import cn.ibizlab.core.extensions.service.DstDataSourceExService;
import cn.ibizlab.core.lite.extensions.domain.EntityModel;
import cn.ibizlab.core.lite.extensions.domain.EntityObj;
import cn.ibizlab.core.lite.extensions.domain.FieldModel;
import cn.ibizlab.core.lite.extensions.domain.ModelObj;
import cn.ibizlab.core.lite.extensions.model.DataModel;
import cn.ibizlab.core.lite.extensions.model.Property;
import cn.ibizlab.core.lite.service.IMetaModelService;
import cn.ibizlab.util.filter.QueryFilter;
import com.alibaba.fastjson.JSON;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.session.SqlSessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Service;
import java.sql.Timestamp;
import java.util.*;
@Slf4j
@Service
public class LiteDataService {
@Autowired
private DbEntityService dbEntityService;
@Autowired
private MongoEntityService mongoEntityService;
@Autowired
private IMetaModelService metaModelService;
@Autowired
@Lazy
private SqlSessionFactory sqlSessionFactory;
@Autowired
private DstDataSourceExService dstDataSourceService;
@Autowired
private LiteModelService liteModelService;
public CommonEntityService getEntityService(String dsId)
{
String dsType=dstDataSourceService.initDataSource(dsId);
if("mongodb".equalsIgnoreCase(dsType))
return mongoEntityService;
else
return dbEntityService;
}
public void processDataModel(String metaModelId,Timestamp lastModify,LiteDataCallback callback)
{
DataModel dataModel= JSON.toJavaObject(JSON.parseObject(metaModelService.get(metaModelId).getConfig()), DataModel.class);
EntityModel entityModel = dataModel.getFactEntityModel();
getEntityService(entityModel.getDsName()).processList(dataModel,lastModify,callback);
}
public ModelObj getModelObjs(String metaModelId, Set<String> fillPropertys, Object factKey) {
DataModel dataModel = liteModelService.getDataModel(metaModelId);
List<EntityObj> kEntityObjs = new ArrayList<>();
kEntityObjs.add(new EntityObj().set(dataModel.getFactEntityModel().getKeyField().getColumnName(), factKey));
List<ModelObj> list = getModelObjs(dataModel, fillPropertys, kEntityObjs);
if (list.size() > 0)
return list.get(0);
return null;
}
public ModelObj getModelObjs(String metaModelId, Set<String> fillPropertys, Object... factUniKey) {
DataModel dataModel = liteModelService.getDataModel(metaModelId);
List<EntityObj> kEntityObjs = new ArrayList<>();
EntityObj entityObj = new EntityObj();
List<FieldModel> uniKeys = dataModel.getFactEntityModel().getUnionKeyFields();
for (int i = 0; i < uniKeys.size(); i++)
entityObj.set(uniKeys.get(i).getColumnName(), factUniKey[i]);
kEntityObjs.add(entityObj);
List<ModelObj> list = getModelObjs(dataModel, fillPropertys, kEntityObjs);
if (list.size() > 0)
return list.get(0);
return null;
}
public List<ModelObj> getModelObjs(String metaModelId, Set<String> fillPropertys, List<EntityObj> kEntityObjs) {
DataModel dataModel = liteModelService.getDataModel(metaModelId);
return getModelObjs(dataModel, fillPropertys, kEntityObjs);
}
public List<ModelObj> getModelObjs(DataModel dataModel, Set<String> fillPropertys, List<EntityObj> kEntityObjs) {
EntityModel entityModel = dataModel.getFactEntityModel();
List<ModelObj> rt = 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(getEntityService(entityModel.getDsName()).selectBase(entityModel, QueryFilter.createQuery().cust(dataModel.lookup(list)))));
factEntityList.forEach(entityObj ->
rt.add(new ModelObj().setDataModel(dataModel).setFactEntity(entityObj.setProperty(dataModel.getFactPorperty()))));
fillEntityObj(dataModel, fillPropertys, rt);
dataModel.getNestedDataModels().forEach(subModel ->
this.getModelObjs(subModel, fillPropertys, factEntityList).forEach(subObj -> subObj.findParent(rt)));
rt.forEach(modelObj -> modelObj.getTimestamp());
return rt;
}
public void fillEntityObj(DataModel dataModel, Set<String> fillPropertys, List<ModelObj> modelObjs) {
if (dataModel.getObjectProperties().size() > 1) {
for (Property property : dataModel.getObjectProperties()) {
if (property.getPropertyName().equals(dataModel.getFactPorperty().getPropertyName()))
continue;
EntityModel entityModel = property.getEntityModel();
List<EntityObj> entityObjs = new ArrayList<>();
if (fillPropertys == null || fillPropertys.size() == 0 || fillPropertys.contains(property.getPropertyName()))
splitList(modelObjs, 1000).forEach(list -> entityObjs.addAll(getEntityService(entityModel.getDsName()).selectBase(entityModel, QueryFilter.createQuery().cust(property.lookup(list)))));
entityObjs.forEach(entityObj -> {
entityObj.setProperty(property);
entityObj.findModel(modelObjs);
});
}
}
}
private <T> List<List<T>> splitList(List<T> list, int groupSize) {
int length = list.size();
// 计算可以分成多少组
int num = (length + groupSize - 1) / groupSize; // TODO
List<List<T>> newList = new ArrayList<>(num);
for (int i = 0; i < num; i++) {
// 开始位置
int fromIndex = i * groupSize;
// 结束位置
int toIndex = (i + 1) * groupSize < length ? (i + 1) * groupSize : length;
newList.add(list.subList(fromIndex, toIndex));
}
return newList;
}
}
...@@ -177,7 +177,10 @@ public class LiteModelService { ...@@ -177,7 +177,10 @@ public class LiteModelService {
public DataModel getDataModel(String dataModelId) public DataModel getDataModel(String dataModelId)
{ {
return JSON.toJavaObject(JSON.parseObject(metaModelService.get(dataModelId).getConfig()),DataModel.class); String cfg=metaModelService.get(dataModelId).getConfig();
DataModel dataModel = JSON.toJavaObject(JSON.parseObject(metaModelService.get(dataModelId).getConfig()),DataModel.class);
dataModel.setModelString(cfg);
return dataModel;
} }
public DataModel getDataModel(String rootDataModelId,String subDataModelName) public DataModel getDataModel(String rootDataModelId,String subDataModelName)
......
...@@ -2,12 +2,13 @@ package cn.ibizlab.core.lite.extensions.service; ...@@ -2,12 +2,13 @@ package cn.ibizlab.core.lite.extensions.service;
import cn.ibizlab.core.lite.extensions.domain.EntityModel; import cn.ibizlab.core.lite.extensions.domain.EntityModel;
import cn.ibizlab.core.lite.extensions.domain.EntityObj; import cn.ibizlab.core.lite.extensions.domain.EntityObj;
import cn.ibizlab.core.lite.extensions.domain.ModelObj; import cn.ibizlab.core.lite.extensions.model.DataModel;
import cn.ibizlab.util.filter.QueryFilter; import cn.ibizlab.util.filter.QueryFilter;
import org.springframework.stereotype.Service; 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{
...@@ -23,32 +24,25 @@ public class MongoEntityService implements CommonEntityService{ ...@@ -23,32 +24,25 @@ public class MongoEntityService implements CommonEntityService{
} }
@Override @Override
public List<EntityObj> search(String dataSet, EntityModel entityModel, QueryFilter filter) { public Integer selectCount(EntityModel entityModel, QueryFilter filter) {
return null; return null;
} }
@Override
public List<EntityObj> search(String dsName, String sql, QueryFilter filter) {
return null;
}
@Override @Override
public List<ModelObj> getModelObjs(String metaModelId, Timestamp lastModify) { public List<EntityObj> search(String dataSet, EntityModel entityModel, QueryFilter filter) {
return null; return null;
} }
@Override @Override
public ModelObj getModelObjs(String metaModelId, Object factKey) { public List<EntityObj> search(String dsName, String sql, QueryFilter filter) {
return null; return null;
} }
@Override
public ModelObj getModelObjs(String metaModelId, Object... factUniKey) {
return null;
}
@Override @Override
public List<ModelObj> getModelObjs(String metaModelId, List<EntityObj> kEntityObjs) { public void processList(DataModel dataModel, Timestamp lastModify, LiteDataCallback callback) {
return null;
} }
} }
...@@ -3,10 +3,17 @@ ...@@ -3,10 +3,17 @@
<mapper namespace="cn.ibizlab.core.extensions.mapper.DbEntityMapper"> <mapper namespace="cn.ibizlab.core.extensions.mapper.DbEntityMapper">
<!--数据集合[Default]--> <!--数据集合[Default]-->
<select id="search" parameterType="cn.ibizlab.core.lite.extensions.filter.DbEntitySearchContext" resultType="cn.ibizlab.core.lite.extensions.domain.EntityObj"> <select id="search" parameterType="cn.ibizlab.core.lite.extensions.filter.DbEntitySearchContext" resultType="cn.ibizlab.core.lite.extensions.domain.EntityObj">
${sql} ${sql}
<where><if test="ew!=null and ew.sqlSegment!=null and !ew.emptyOfWhere">${ew.sqlSegment}</if></where> <where><if test="ew!=null and ew.sqlSegment!=null and !ew.emptyOfWhere">${ew.sqlSegment}</if></where>
<if test="ew!=null and ew.sqlSegment!=null and ew.emptyOfWhere">${ew.sqlSegment}</if> <if test="ew!=null and ew.sqlSegment!=null and ew.emptyOfWhere">${ew.sqlSegment}</if>
</select> </select>
<select id="searchCount" parameterType="cn.ibizlab.core.lite.extensions.filter.DbEntitySearchContext" resultType="Integer">
${sql}
<where><if test="ew!=null and ew.sqlSegment!=null and !ew.emptyOfWhere">${ew.sqlSegment}</if></where>
<if test="ew!=null and ew.sqlSegment!=null and ew.emptyOfWhere">${ew.sqlSegment}</if>
</select>
</mapper> </mapper>
...@@ -9,6 +9,7 @@ import cn.ibizlab.core.lite.extensions.model.DataModel; ...@@ -9,6 +9,7 @@ import cn.ibizlab.core.lite.extensions.model.DataModel;
import cn.ibizlab.core.lite.extensions.model.Property; import cn.ibizlab.core.lite.extensions.model.Property;
import cn.ibizlab.core.lite.extensions.service.DbEntityService; import cn.ibizlab.core.lite.extensions.service.DbEntityService;
import cn.ibizlab.core.lite.extensions.service.LiteCoreService; import cn.ibizlab.core.lite.extensions.service.LiteCoreService;
import cn.ibizlab.core.lite.extensions.service.LiteDataService;
import cn.ibizlab.core.lite.extensions.service.LiteModelService; import cn.ibizlab.core.lite.extensions.service.LiteModelService;
import cn.ibizlab.core.lite.service.IDstComponentService; import cn.ibizlab.core.lite.service.IDstComponentService;
import cn.ibizlab.core.lite.service.IDstConfigService; import cn.ibizlab.core.lite.service.IDstConfigService;
...@@ -55,17 +56,19 @@ public class LiteCoreResource { ...@@ -55,17 +56,19 @@ public class LiteCoreResource {
@Lazy @Lazy
LiteCoreService liteCoreService; LiteCoreService liteCoreService;
@Autowired
private LiteDataService liteDataService;
@Autowired @Autowired
private DbEntityService dbEntityService; private DbEntityService dbEntityService;
@RequestMapping(method = RequestMethod.GET, value = "/lite/test/{modelid}") @RequestMapping(method = RequestMethod.GET, value = "/dst/test/{modelid}/data/{key}")
public ResponseEntity<List<ModelObj>> getstr(@PathVariable(name="modelid",required = false) String modelid) public ResponseEntity<ModelObj> getstr(@PathVariable(name="modelid",required = false) String modelid,@PathVariable(name="key",required = false) String key)
{ {
if(StringUtils.isEmpty(modelid)) if(StringUtils.isEmpty(modelid))
modelid="dataModelff8080816a8b510c016a8c2f18b10001"; modelid="dataModelff8080816a8b510c016a8c2f18b10001";
List<ModelObj> list=dbEntityService.getModelObjs(modelid, DataObject.getBeginDate()); return ResponseEntity.ok(liteDataService.getModelObjs(modelid, null,key));
return ResponseEntity.ok(list);
} }
......
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册