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

tableschema

上级 7e478f0b
......@@ -18,7 +18,9 @@ import net.ibizsys.model.dataentity.ds.IPSDEDataSetGroupParam;
import net.ibizsys.model.dataentity.ds.PSDEDataSetGroupParamImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cache.annotation.CacheEvict;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.cache.annotation.Caching;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Service;
import org.springframework.util.ObjectUtils;
......@@ -58,12 +60,9 @@ public class DynamicModelService {
return initDynamicSystem(system);
}
private IPSSystem initDynamicSystem(String system)
{
if(dynamicSystems==null)
dynamicSystems=new HashMap<>();
IPSSystem iPSSystem = null;
String strPSModelFolderPath=null;
if(Files.exists(Paths.get(getModelPath(),system,"model","PSSYSTEM.json"))) {
strPSModelFolderPath=Paths.get(getModelPath(),system,"model").toString();
......@@ -74,6 +73,14 @@ public class DynamicModelService {
if(allDynamicModel.containsKey(system))
strPSModelFolderPath = allDynamicModel.get(system).getDynamicModelPath();
}
return initDynamicSystem(system,strPSModelFolderPath);
}
private IPSSystem initDynamicSystem(String system, String strPSModelFolderPath)
{
if(dynamicSystems==null)
dynamicSystems=new HashMap<>();
IPSSystem iPSSystem = null;
if(StringUtils.isEmpty(strPSModelFolderPath))
throw new BadRequestAlertException("加载系统模型错误,未找到对应模型目录", "DynamicSystem", system);
......@@ -647,4 +654,52 @@ public class DynamicModelService {
}
private Map<String,Long> systemModifyMap=new HashMap<>();
@Caching( evict = {
@CacheEvict( value="syspssystem",allEntries = true),
@CacheEvict( value="meta-entities", key = "'system:'+#p0"),
@CacheEvict( value="meta-entities", key = "'system:keymap-'+#p0")
})
public void resetSystem(String system)
{
}
private IPSSystem reloadDynamicSystem(DstSystemModel system)
{
return initDynamicSystem(system.getPssystemid(),system.getDynamicModelPath());
}
public Map<String,Map<String,Long>> getAllDynamicModelVersion()
{
Map<String,Map<String,Long>> ret=new LinkedHashMap<>();
this.findAllDynamicModel().values().forEach(dstSystemModel -> {
if(ret.containsKey(dstSystemModel.getPssystemid()))
return;
if((!systemModifyMap.containsKey(dstSystemModel.getPssystemid()))||systemModifyMap.get(dstSystemModel.getPssystemid())<dstSystemModel.getLastModify())
{
reloadDynamicSystem(dstSystemModel);
this.getProxy().resetSystem(dstSystemModel.getPssystemid());
if(!dstSystemModel.getPssystemid().equals(dstSystemModel.getPssystemid().toLowerCase()))
this.getProxy().resetSystem(dstSystemModel.getPssystemid().toLowerCase());
}
systemModifyMap.put(dstSystemModel.getPssystemid(),dstSystemModel.getLastModify());
Map<String,Long> entities=new LinkedHashMap<>();
ret.put(dstSystemModel.getPssystemid(),entities);
try {
this.getEntities(dstSystemModel.getPssystemid()).values().forEach(metaEntityModel -> {
if(entities.containsKey(metaEntityModel.getEntityName()))
return;
entities.put(metaEntityModel.getEntityName(),dstSystemModel.getLastModify());
});
} catch (Exception exception) {
}
});
return ret;
}
}
......@@ -113,6 +113,19 @@ public class POSchema {
return this;
}
@JsonIgnore
@JSONField(serialize = false)
public Set<String> getForeignKey()
{
Set<String> fks=new HashSet<>();
if(foreignKeyConstraints!=null)
{
foreignKeyConstraints.forEach(fk->fks.add(fk.getConstraintName()));
}
return fks;
}
@JsonIgnore
@JSONField(serialize = false)
private Map<String,Column> columnMaps;
......@@ -633,7 +646,19 @@ public class POSchema {
put("h2", "mysql");
}};
public Segment getSegment(String tag)
{
if(segments!=null)
{
for(Segment script:segments)
{
String key=DataObject.getStringValue(script.getName(),"").concat(".").concat(DataObject.getStringValue(script.getVendorProvider(),""));
if(key.equals(tag))
return script;
}
}
return null;
}
public Segment getSegment(String name,String type)
{
......
......@@ -41,7 +41,11 @@ public class PojoOption extends DataObj
}
public String getSystem(){
return this.getStringValue("system_id",this.getStringValue("system_name",this.getStringValue("system")));
return this.getStringValue("system_id",this.getStringValue("system",this.getStringValue("system_name")));
}
public String getSystemName(){
return this.getStringValue("system_name",this.getStringValue("system",this.getStringValue("system_id")));
}
public String getPackage(){
......
......@@ -55,126 +55,126 @@ public interface IPersistentService {
default BaseData create(String datasource,String table,BaseData et,boolean bGet)
default BaseData create(String system,String table,String datasource,BaseData et,boolean bGet)
{
DSLink link=getDSLink(datasource);
return create(link,getSchema(link,table),et,bGet);
return create(link,getSchema(link,system,table),et,bGet);
}
default List<BaseData> createBatch(String datasource,String table,List<BaseData> list,boolean bGet)
default List<BaseData> createBatch(String system,String table,String datasource,List<BaseData> list,boolean bGet)
{
DSLink link=getDSLink(datasource);
return createBatch(link,getSchema(link,table),list,bGet);
return createBatch(link,getSchema(link,system,table),list,bGet);
}
default BaseData update(String datasource,String table,BaseData et,boolean bGet)
default BaseData update(String system,String table,String datasource,BaseData et,boolean bGet)
{
DSLink link=getDSLink(datasource);
return update(link,getSchema(link,table),et,bGet);
return update(link,getSchema(link,system,table),et,bGet);
}
default List<BaseData> updateBatch(String datasource,String table,List<BaseData> list,boolean bGet)
default List<BaseData> updateBatch(String system,String table,String datasource,List<BaseData> list,boolean bGet)
{
DSLink link=getDSLink(datasource);
return updateBatch(link,getSchema(link,table),list,bGet);
return updateBatch(link,getSchema(link,system,table),list,bGet);
}
default boolean remove(String datasource,String table,Serializable key)
default boolean remove(String system,String table,String datasource,Serializable key)
{
DSLink link=getDSLink(datasource);
return remove(link,getSchema(link,table),key);
return remove(link,getSchema(link,system,table),key);
}
default boolean removeBatch(String datasource,String table,List<Serializable> idList)
default boolean removeBatch(String system,String table,String datasource,List<Serializable> idList)
{
DSLink link=getDSLink(datasource);
return removeBatch(link,getSchema(link,table),idList);
return removeBatch(link,getSchema(link,system,table),idList);
}
default boolean removeByMap(String datasource,String table,BaseData et)
default boolean removeByMap(String system,String table,String datasource,BaseData et)
{
DSLink link=getDSLink(datasource);
return removeByMap(link,getSchema(link,table),et);
return removeByMap(link,getSchema(link,system,table),et);
}
default boolean removeByMapBatch(String datasource,String table,List<BaseData> list)
default boolean removeByMapBatch(String system,String table,String datasource,List<BaseData> list)
{
DSLink link=getDSLink(datasource);
return removeByMapBatch(link,getSchema(link,table),list);
return removeByMapBatch(link,getSchema(link,system,table),list);
}
default BaseData get(String datasource,String table,Serializable key)
default BaseData get(String system,String table,String datasource,Serializable key)
{
DSLink link=getDSLink(datasource);
return get(link,getSchema(link,table),key);
return get(link,getSchema(link,system,table),key);
}
default List<BaseData> getBatch(String datasource,String table,List<Serializable> idList)
default List<BaseData> getBatch(String system,String table,String datasource,List<Serializable> idList)
{
DSLink link=getDSLink(datasource);
return getBatch(link,getSchema(link,table),idList);
return getBatch(link,getSchema(link,system,table),idList);
}
default BaseData getByMap(String datasource,String table,BaseData et)
default BaseData getByMap(String system,String table,String datasource,BaseData et)
{
DSLink link=getDSLink(datasource);
return getByMap(link,getSchema(link,table),et);
return getByMap(link,getSchema(link,system,table),et);
}
default List<BaseData> getByMapBatch(String datasource,String table,List<BaseData> list)
default List<BaseData> getByMapBatch(String system,String table,String datasource,List<BaseData> list)
{
DSLink link=getDSLink(datasource);
return getByMapBatch(link,getSchema(link,table),list);
return getByMapBatch(link,getSchema(link,system,table),list);
}
default List<BaseData> getBatchKey(String datasource,String table,List<BaseData> list)
default List<BaseData> getBatchKey(String system,String table,String datasource,List<BaseData> list)
{
DSLink link=getDSLink(datasource);
return getBatchKey(link,getSchema(link,table),list);
return getBatchKey(link,getSchema(link,system,table),list);
}
default Long count(String datasource,String table,BaseData et)
default Long count(String system,String table,String datasource,BaseData et)
{
DSLink link=getDSLink(datasource);
return count(link,getSchema(link,table),et);
return count(link,getSchema(link,system,table),et);
}
default boolean checkKey(String datasource,String table,BaseData et)
default boolean checkKey(String system,String table,String datasource,BaseData et)
{
DSLink link=getDSLink(datasource);
return checkKey(link,getSchema(link,table),et);
return checkKey(link,getSchema(link,system,table),et);
}
default BaseData save(String datasource,String table,BaseData et,boolean bGet)
default BaseData save(String system,String table,String datasource,BaseData et,boolean bGet)
{
DSLink link=getDSLink(datasource);
return save(link,getSchema(link,table),et,bGet);
return save(link,getSchema(link,system,table),et,bGet);
}
default List<BaseData> saveBatch(String datasource,String table,List<BaseData> list,boolean bGet)
default List<BaseData> saveBatch(String system,String table,String datasource,List<BaseData> list,boolean bGet)
{
DSLink link=getDSLink(datasource);
return saveBatch(link,getSchema(link,table),list,bGet);
return saveBatch(link,getSchema(link,system,table),list,bGet);
}
default List<BaseData> select(String datasource,String table,BaseData et){
default List<BaseData> select(String system,String table,String datasource,BaseData et){
DSLink link=getDSLink(datasource);
return select(link,getSchema(link,table),et);
return select(link,getSchema(link,system,table),et);
}
default Page<BaseData> select(String datasource,String table,BaseData et,Pageable pageable){
default Page<BaseData> select(String system,String table,String datasource,BaseData et,Pageable pageable){
DSLink link=getDSLink(datasource);
return select(link,getSchema(link,table),et,pageable);
return select(link,getSchema(link,system,table),et,pageable);
}
default List<BaseData> query(String datasource,String table,String dataQuery,FilterData context){
default List<BaseData> query(String system,String table,String datasource,String dataQuery,FilterData context){
DSLink link=getDSLink(datasource);
return query(link,getSchema(link,table),dataQuery,context);
return query(link,getSchema(link,system,table),dataQuery,context);
}
default Page<BaseData> query(String datasource,String table,String dataQuery,FilterData context,Pageable pageable){
default Page<BaseData> query(String system,String table,String datasource,String dataQuery,FilterData context,Pageable pageable){
DSLink link=getDSLink(datasource);
return query(link,getSchema(link,table),dataQuery,context,pageable);
return query(link,getSchema(link,system,table),dataQuery,context,pageable);
}
default List<BaseData> selectRaw(String datasource,String table,String sql,FilterData context){
default List<BaseData> selectRaw(String system,String table,String datasource,String sql,FilterData context){
DSLink link=getDSLink(datasource);
return selectRaw(link,getSchema(link,table),sql,context);
return selectRaw(link,getSchema(link,system,table),sql,context);
}
default boolean execRaw(String datasource,String table,String sql,BaseData param){
default boolean execRaw(String system,String table,String datasource,String sql,BaseData param){
DSLink link=getDSLink(datasource);
return execRaw(link,getSchema(link,table),sql,param);
return execRaw(link,getSchema(link,system,table),sql,param);
}
default List<BaseData> fetch(String datasource,String table,String dataSet,FilterData context){
default List<BaseData> fetch(String system,String table,String datasource,String dataSet,FilterData context){
DSLink link=getDSLink(datasource);
return fetch(link,getSchema(link,table),dataSet,context);
return fetch(link,getSchema(link,system,table),dataSet,context);
}
default Page<BaseData> fetch(String datasource,String table,String dataSet,FilterData context,Pageable pageable){
default Page<BaseData> fetch(String system,String table,String datasource,String dataSet,FilterData context,Pageable pageable){
DSLink link=getDSLink(datasource);
return fetch(link,getSchema(link,table),dataSet,context,pageable);
return fetch(link,getSchema(link,system,table),dataSet,context,pageable);
}
DSLink getDSLink(String datasource);
POSchema getSchema(DSLink link,String table);
POSchema getSchema(DSLink link,String system,String table);
}
......@@ -2,17 +2,24 @@ package cn.ibizlab.core.data.service;
import cn.ibizlab.core.data.domain.DOModel;
import cn.ibizlab.core.data.lite.*;
import cn.ibizlab.core.data.model.DSLink;
import cn.ibizlab.core.data.model.POSchema;
import cn.ibizlab.core.data.model.PojoSchema;
import cn.ibizlab.core.data.model.TransUtils;
import cn.ibizlab.util.errors.BadRequestAlertException;
import cn.ibizlab.util.helper.DataObject;
import cn.ibizlab.util.helper.Inflector;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.alibaba.fastjson.TypeReference;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cache.annotation.CacheEvict;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.cache.annotation.Caching;
import org.springframework.context.annotation.Lazy;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Service;
import org.springframework.util.ObjectUtils;
import org.springframework.util.StringUtils;
......@@ -22,11 +29,11 @@ import java.io.File;
import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.StandardOpenOption;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.sql.Timestamp;
import java.util.*;
@Service
@Slf4j
......@@ -48,7 +55,7 @@ public class ModelService {
private IDOModelService doModelService;
@Autowired
private LiteModelFeignClient liteService;
private LiteModelFeignClient liteService1;
@Autowired
@Lazy
......@@ -68,39 +75,94 @@ public class ModelService {
{
Map<String,DstSystemModel> models=dynamicService.findAllDynamicModel();
try
{
List<DstSystemModel> liteSystems=liteService.getSysApps();
if(!ObjectUtils.isEmpty(liteSystems))
{
liteSystems.forEach(dstSystemModel->{
// try
// {
// List<DstSystemModel> liteSystems=liteService.getSysApps();
// if(!ObjectUtils.isEmpty(liteSystems))
// {
// liteSystems.forEach(dstSystemModel->{
// String system=dstSystemModel.getPssystemid();
// if(!models.containsKey(system))
// models.put(system, dstSystemModel);
// if ((!system.toLowerCase().equals(system))&&(!models.containsKey(system.toLowerCase())))
// models.put(system.toLowerCase(), dstSystemModel);
// });
// }
// }
// catch (Exception ex)
// {
// log.error("dst接口访问异常",ex);
// }
getLocalSystemModels().values().forEach(dstSystemModel->{
String system=dstSystemModel.getPssystemid();
if(!models.containsKey(system))
models.put(system, dstSystemModel);
if ((!system.toLowerCase().equals(system))&&(!models.containsKey(system.toLowerCase())))
models.put(system.toLowerCase(), dstSystemModel);
});
return models;
}
}
catch (Exception ex)
public Map<String, DstSystemModel> getLocalSystemModels()
{
log.error("dst接口访问异常",ex);
Map<String,DstSystemModel> models=null;
File modelDir=new File(getModelPath());
Path systemJSON=Paths.get(modelDir.getAbsolutePath(),"SYSTEM.json");
try {
if(!Files.exists(systemJSON))
models=LoadLocalSystemModels();
else
models=JSON.parseObject(new String(Files.readAllBytes(systemJSON), StandardCharsets.UTF_8), new TypeReference<LinkedHashMap<String, DstSystemModel>>(){});;
} catch (IOException e) {
throw new BadRequestAlertException("解析文件失败","DstSystemModel","SYSTEM.json");
}
return models;
}
public Map<String,DstSystemModel> LoadLocalSystemModels()
{
Map<String,DstSystemModel> models=new LinkedHashMap<>();
File modelDir=new File(getModelPath());
if(modelDir.exists())
{
for(File sysDir:modelDir.listFiles())
{
if(Files.exists(Paths.get(sysDir.getAbsolutePath(),"repo","domain")))
if(!sysDir.isDirectory())
continue;
File repoDir=new File(sysDir,"repo");
if(!repoDir.exists())
continue;
for(File entityDir:repoDir.listFiles())
{
String system=sysDir.getName();
DstSystemModel dstSystemModel=new DstSystemModel().setPssystemid(system).setPssystemname(system);
if(!models.containsKey(system))
models.put(system, dstSystemModel);
if ((!system.toLowerCase().equals(system))&&(!models.containsKey(system.toLowerCase())))
Path json=Paths.get(repoDir.getAbsolutePath(),"domain",repoDir.getName()+".json");
if(Files.exists(json))
{
try{
PojoSchema pojoSchema=PojoSchema.fromPath(json);
String system=pojoSchema.getSystem();
if(StringUtils.isEmpty(system))
system=sysDir.getName();
String systemName=pojoSchema.getOptions().getSystemName();
if(StringUtils.isEmpty(systemName))
systemName=system;
DstSystemModel dstSystemModel=new DstSystemModel().setPssystemid(system).setPssystemname(systemName).setLastModify(json.toFile().lastModified());
if((!models.containsKey(system.toLowerCase()))||(dstSystemModel.getLastModify()>models.get(system.toLowerCase()).getLastModify()))
models.put(system.toLowerCase(), dstSystemModel);
}catch (Exception ex){}
break;
}
}
}
if(models.size()>0)
{
try {
Files.write(Paths.get(modelDir.getAbsolutePath(),"SYSTEM.json"), JSON.toJSONBytes(models), StandardOpenOption.CREATE);
} catch (IOException e) {
}
}
}
......@@ -108,7 +170,6 @@ public class ModelService {
}
@Cacheable( value="meta-entities", key = "'system:keymap-'+#p0")
public Map<String,String> getEntitiyIdsBySystem(String system) throws Exception {
DstSystemModel dstSystemModel=proxy.getAllSystemModels().get(system);
......@@ -124,35 +185,35 @@ public class ModelService {
entities.put(entity.getKey(),id);
});
try{
List<MetaEntityModel> liteEntities=liteService.getEntityModel(system);
if(!ObjectUtils.isEmpty(liteEntities))
{
liteEntities.forEach(metaEntityModel->{
String id=metaEntityModel.getSystemId().concat(".domain.").concat(metaEntityModel.getEntityName());
if(!entities.containsKey(metaEntityModel.getCodeName()))
entities.put(metaEntityModel.getCodeName(),id);
if(!entities.containsKey(metaEntityModel.getCodeName().toLowerCase()))
entities.put(metaEntityModel.getCodeName().toLowerCase(),id);
if(!entities.containsKey(metaEntityModel.getEntityName())) {
entities.put(metaEntityModel.getEntityName(), id);
}
if(!entities.containsKey(metaEntityModel.getEntityName().toLowerCase())) {
entities.put(metaEntityModel.getEntityName().toLowerCase(), id);
}
String pluralize= Inflector.getInstance().pluralize(metaEntityModel.getCodeName()).toLowerCase();
if(!entities.containsKey(pluralize)) {
entities.put(pluralize, id);
}
});
}
}
catch (Exception ex)
{
log.error("dst接口访问异常",ex);
}
// try{
// List<MetaEntityModel> liteEntities=liteService.getEntityModel(system);
// if(!ObjectUtils.isEmpty(liteEntities))
// {
// liteEntities.forEach(metaEntityModel->{
// String id=metaEntityModel.getSystemId().concat(".domain.").concat(metaEntityModel.getEntityName());
//
// if(!entities.containsKey(metaEntityModel.getCodeName()))
// entities.put(metaEntityModel.getCodeName(),id);
// if(!entities.containsKey(metaEntityModel.getCodeName().toLowerCase()))
// entities.put(metaEntityModel.getCodeName().toLowerCase(),id);
// if(!entities.containsKey(metaEntityModel.getEntityName())) {
// entities.put(metaEntityModel.getEntityName(), id);
// }
// if(!entities.containsKey(metaEntityModel.getEntityName().toLowerCase())) {
// entities.put(metaEntityModel.getEntityName().toLowerCase(), id);
// }
// String pluralize= Inflector.getInstance().pluralize(metaEntityModel.getCodeName()).toLowerCase();
// if(!entities.containsKey(pluralize)) {
// entities.put(pluralize, id);
// }
//
// });
// }
// }
// catch (Exception ex)
// {
// log.error("dst接口访问异常",ex);
// }
File dir=Paths.get(getModelPath(),system,"repo","domain").toFile();
......@@ -203,16 +264,17 @@ public class ModelService {
try {
entityModel = dynamicService.getDynamicEntity(system,entity);
} catch (Exception exception) {
}
try{
if(entityModel==null)
entityModel = liteService.getProxyEntityModel(system,entity);
}
catch (Exception ex)
{
log.error("dst接口访问异常",ex);
exception.printStackTrace();
throw new BadRequestAlertException("未找到实体"+system+"."+entity,"loadDOModel","");
}
// try{
// if(entityModel==null)
// entityModel = liteService.getProxyEntityModel(system,entity);
// }
// catch (Exception ex)
// {
// log.error("dst接口访问异常",ex);
// }
return entityModel;
......@@ -221,10 +283,11 @@ public class ModelService {
public DOModel loadDOModel(String system,String entity)
{
EntityModel entityModel= proxy.getEntityModel(system,entity);
DOModel doModel=new DOModel();
if(entityModel!=null) {
PojoSchema schema = TransUtils.EntityModelModel2Schema(entityModel);
if (schema != null) {
DOModel doModel=new DOModel();
doModel.setSchema(schema);
for (String dsType : entityModel.getDsTypes()) {
POSchema poSchema = TransUtils.EntityModelModel2PO(entityModel, dsType);
......@@ -234,7 +297,8 @@ public class ModelService {
}
}
}
return doModel;
else throw new BadRequestAlertException("未找到实体"+system+"."+entity,"loadDOModel","");
return null;
}
......@@ -250,4 +314,143 @@ public class ModelService {
MODEL_PATH=this.getModelPath();
}
@Caching( evict = {
@CacheEvict( value="domodel",key = "'row:'+#p0" )
})
public void resetDOModel(String tag)
{
}
public void resetDOModel(String system,String entity)
{
try {
proxy.getEntitiyIdsBySystem(system).entrySet().forEach(entry->{
String standardSystem="";
String standardEntity="";
String[] args=entry.getValue().split("[.]");
standardSystem=args[0];
standardEntity=args[2];
if(entry.getKey().equals(standardEntity)||entry.getKey().equals(entity)) {
proxy.resetDOModel(system.concat(".domain.").concat(entry.getKey()));
if(!system.equals(system.toLowerCase()))
proxy.resetDOModel(system.toLowerCase().concat(".domain.").concat(entry.getKey()));
proxy.resetDOModel(standardSystem.concat(".domain.").concat(entry.getKey()));
if(!standardSystem.equals(standardSystem.toLowerCase()))
proxy.resetDOModel(standardSystem.toLowerCase().concat(".domain.").concat(entry.getKey()));
}
});
} catch (Exception exception) {
}
}
@Scheduled(cron="0 */1 * * * ?")
public synchronized void refreshDynamicModel()
{
dynamicService.getAllDynamicModelVersion().entrySet().forEach(entry->{
String system=entry.getKey();
entry.getValue().entrySet().forEach(item->{
String entity=item.getKey();
Long systemModify=item.getValue();
File json=Paths.get(this.getModelPath(),system,"repo",entity,"domain",entity+".json").toFile();
Long doModify=0L;
if(json.exists())
doModify=json.lastModified();
if(doModify<systemModify)
{
DOModel doModel = loadDOModel(system,entity);
if(doModify==0L)
log.info("新增模型[".concat(doModel.getName()).concat("]").concat(doModel.getTitle()));
else {
resetDOModel(system,entity);
log.info("刷新模型[".concat(doModel.getName()).concat("]").concat(doModel.getTitle()).concat(",").concat(doModify.toString()).concat("->").concat(systemModify.toString()));
}
PojoSchema schema = doModel.getSchema();
if(schema!=null)
{
if(doModel.getPoSchemas()!=null)
{
Path poPath = Paths.get(ModelService.MODEL_PATH,doModel.getSystemId(),"repo",doModel.getName(),"repository",doModel.getName()+".json");
try {
File dir=poPath.getParent().toFile();
if(!dir.exists())
dir.mkdirs();
Files.write(poPath, JSON.toJSONBytes(doModel.getPoSchemas()), StandardOpenOption.CREATE);
} catch (Exception e) {
throw new BadRequestAlertException("保存文件失败","POSchemas",poPath.toString());
}
doModel.getPoSchemas().values().forEach(poSchema->{
mergeTableSchema(doModel.getSystemId(),poSchema,systemModify);
});
}
schema.writeTo(Paths.get(ModelService.MODEL_PATH,doModel.getSystemId(),"repo",doModel.getName(),"domain",doModel.getName()+".json"));
}
}
});
});
}
public void mergeTableSchema(String system, POSchema poSchema, Long timestamp)
{
POSchema newSchema= JSONObject.parseObject(JSON.toJSONString(poSchema),POSchema.class);
File dir=Paths.get(ModelService.MODEL_PATH,system,"repo","_table",poSchema.getName().toUpperCase()).toFile();
if(!dir.exists())
dir.mkdirs();
Path json=Paths.get(ModelService.MODEL_PATH,system,"repo","_table",poSchema.getName().toUpperCase(),poSchema.getDsType().toLowerCase()+".json");
if(Files.exists(json)&&json.toFile().lastModified()>timestamp)
{
POSchema old=POSchema.fromPath(json);
if(old.getColumns()!=null)
{
old.getColumns().forEach(column -> {
POSchema.Column newColumn=newSchema.getColumn(column.getName());
if (newColumn==null)
{
newSchema.addColumn(JSON.parseObject(JSON.toJSONString(column),POSchema.Column.class));
}
else if(!ObjectUtils.isEmpty(column.getSearchModes()))
{
newColumn.putSearchModes(String.join(",",column.getSearchModes()));
}
});
}
if(old.getTransients()!=null)
{
old.getTransients().forEach(column -> {
POSchema.Column newColumn=newSchema.getColumn(column.getName());
if (newColumn==null)
{
newSchema.addTransient(JSON.parseObject(JSON.toJSONString(column),POSchema.Column.class));
}
else if(!ObjectUtils.isEmpty(column.getSearchModes()))
{
newColumn.putSearchModes(String.join(",",column.getSearchModes()));
}
});
}
if(!ObjectUtils.isEmpty(old.getForeignKeyConstraints()))
{
old.getForeignKeyConstraints().forEach(fk->{
if(!newSchema.getForeignKey().contains(fk.getConstraintName()))
newSchema.addForeignKeyConstraint(JSON.parseObject(JSON.toJSONString(fk),POSchema.ForeignKeyConstraint.class));
});
}
if(!ObjectUtils.isEmpty(old.getSegments()))
{
old.getSegments().forEach(script -> {
String key= DataObject.getStringValue(script.getName(),"").concat(".").concat(DataObject.getStringValue(script.getVendorProvider(),""));
if(newSchema.getSegment(key)==null)
{
newSchema.addSegment(JSON.parseObject(JSON.toJSONString(script),POSchema.Segment.class));
}
});
}
}
POSchema.writeTo(newSchema,json);
}
}
......@@ -344,7 +344,7 @@ public class DbPersistentServiceImpl implements IPersistentService {
}
@Override
public POSchema getSchema(DSLink link, String table) {
public POSchema getSchema(DSLink link, String system, String table) {
return null;
}
}
......@@ -250,7 +250,7 @@ public class MongoPersistentServiceImpl implements IPersistentService {
}
@Override
public POSchema getSchema(DSLink link, String table) {
public POSchema getSchema(DSLink link, String system, String table) {
return null;
}
}
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册