mirror of
https://github.com/tencentmusic/supersonic.git
synced 2025-12-10 19:51:00 +00:00
(improvement)(Headless) Support setting fields as foreign keys when creating data-model (#1857)
Co-authored-by: lxwcodemonkey
This commit is contained in:
@@ -84,14 +84,14 @@ public class SchemaElement implements Serializable {
|
||||
return false;
|
||||
}
|
||||
Object o = extInfo.get(DimensionConstants.DIMENSION_TYPE);
|
||||
DimensionType dimensionTYpe = null;
|
||||
DimensionType dimensionType = null;
|
||||
if (o instanceof DimensionType) {
|
||||
dimensionTYpe = (DimensionType) o;
|
||||
dimensionType = (DimensionType) o;
|
||||
}
|
||||
if (o instanceof String) {
|
||||
dimensionTYpe = DimensionType.valueOf((String) o);
|
||||
dimensionType = DimensionType.valueOf((String) o);
|
||||
}
|
||||
return DimensionType.isIdentity(dimensionTYpe);
|
||||
return DimensionType.isPrimaryKey(dimensionType);
|
||||
}
|
||||
|
||||
public String getTimeFormat() {
|
||||
|
||||
@@ -1,7 +1,16 @@
|
||||
package com.tencent.supersonic.headless.api.pojo.enums;
|
||||
|
||||
public enum DimensionType {
|
||||
categorical, time, partition_time, identify;
|
||||
categorical, time, partition_time, primary_key, foreign_key;
|
||||
|
||||
public static DimensionType fromIdentify(String identify) {
|
||||
if (IdentifyType.foreign.name().equalsIgnoreCase(identify)) {
|
||||
return DimensionType.foreign_key;
|
||||
} else if (IdentifyType.primary.name().equalsIgnoreCase(identify)) {
|
||||
return DimensionType.primary_key;
|
||||
}
|
||||
return DimensionType.categorical;
|
||||
}
|
||||
|
||||
public static boolean isTimeDimension(String type) {
|
||||
try {
|
||||
@@ -19,7 +28,7 @@ public enum DimensionType {
|
||||
return type == partition_time;
|
||||
}
|
||||
|
||||
public static boolean isIdentity(DimensionType type) {
|
||||
return type == identify;
|
||||
public static boolean isPrimaryKey(DimensionType type) {
|
||||
return type == primary_key;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -7,6 +7,7 @@ import com.tencent.supersonic.headless.api.pojo.Field;
|
||||
import com.tencent.supersonic.headless.api.pojo.Identify;
|
||||
import com.tencent.supersonic.headless.api.pojo.ModelDetail;
|
||||
import com.tencent.supersonic.headless.api.pojo.SchemaItem;
|
||||
import com.tencent.supersonic.headless.api.pojo.enums.IdentifyType;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Data;
|
||||
import lombok.NoArgsConstructor;
|
||||
@@ -95,6 +96,16 @@ public class ModelResp extends SchemaItem {
|
||||
return fieldSet;
|
||||
}
|
||||
|
||||
public IdentifyType getIdentifyType(String fieldName) {
|
||||
List<Identify> identifiers = modelDetail.getIdentifiers();
|
||||
for (Identify identify : identifiers) {
|
||||
if (Objects.equals(identify.getFieldName(), fieldName)) {
|
||||
return IdentifyType.valueOf(identify.getType());
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(Object o) {
|
||||
if (this == o) {
|
||||
|
||||
@@ -8,9 +8,14 @@ import com.tencent.supersonic.common.pojo.JoinCondition;
|
||||
import com.tencent.supersonic.common.pojo.ModelRela;
|
||||
import com.tencent.supersonic.common.pojo.User;
|
||||
import com.tencent.supersonic.common.util.BeanMapper;
|
||||
import com.tencent.supersonic.headless.api.pojo.enums.IdentifyType;
|
||||
import com.tencent.supersonic.headless.api.pojo.response.ModelResp;
|
||||
import com.tencent.supersonic.headless.server.persistence.dataobject.ModelRelaDO;
|
||||
import com.tencent.supersonic.headless.server.persistence.mapper.ModelRelaDOMapper;
|
||||
import com.tencent.supersonic.headless.server.service.ModelRelaService;
|
||||
import com.tencent.supersonic.headless.server.service.ModelService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.context.annotation.Lazy;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.util.CollectionUtils;
|
||||
|
||||
@@ -21,8 +26,13 @@ import java.util.stream.Collectors;
|
||||
public class ModelRelaServiceImpl extends ServiceImpl<ModelRelaDOMapper, ModelRelaDO>
|
||||
implements ModelRelaService {
|
||||
|
||||
@Lazy
|
||||
@Autowired
|
||||
private ModelService modelService;
|
||||
|
||||
@Override
|
||||
public void save(ModelRela modelRela, User user) {
|
||||
check(modelRela);
|
||||
modelRela.createdBy(user.getName());
|
||||
ModelRelaDO modelRelaDO = convert(modelRela);
|
||||
save(modelRelaDO);
|
||||
@@ -30,11 +40,31 @@ public class ModelRelaServiceImpl extends ServiceImpl<ModelRelaDOMapper, ModelRe
|
||||
|
||||
@Override
|
||||
public void update(ModelRela modelRela, User user) {
|
||||
check(modelRela);
|
||||
modelRela.updatedBy(user.getName());
|
||||
ModelRelaDO modelRelaDO = convert(modelRela);
|
||||
updateById(modelRelaDO);
|
||||
}
|
||||
|
||||
private void check(ModelRela modelRela) {
|
||||
ModelResp fromModel = modelService.getModel(modelRela.getFromModelId());
|
||||
ModelResp toModel = modelService.getModel(modelRela.getToModelId());
|
||||
if (CollectionUtils.isEmpty(modelRela.getJoinConditions())) {
|
||||
throw new RuntimeException("关联关系不可为空");
|
||||
}
|
||||
for (JoinCondition joinCondition : modelRela.getJoinConditions()) {
|
||||
IdentifyType identifyTypeLeft = fromModel.getIdentifyType(joinCondition.getLeftField());
|
||||
IdentifyType identifyTypeRight = toModel.getIdentifyType(joinCondition.getRightField());
|
||||
if (IdentifyType.foreign.equals(identifyTypeLeft)
|
||||
|| IdentifyType.foreign.equals(identifyTypeRight)) {
|
||||
if (!IdentifyType.primary.equals(identifyTypeLeft)
|
||||
&& !IdentifyType.primary.equals(identifyTypeRight)) {
|
||||
throw new RuntimeException("外键必须跟主键关联");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<ModelRela> getModelRelaList(Long domainId) {
|
||||
QueryWrapper<ModelRelaDO> wrapper = new QueryWrapper<>();
|
||||
|
||||
@@ -116,7 +116,7 @@ public class DimensionConverter {
|
||||
try {
|
||||
// Support compatibility with legacy data.
|
||||
IdentifyType.valueOf(type.toLowerCase());
|
||||
return DimensionType.identify;
|
||||
return DimensionType.primary_key;
|
||||
} catch (IllegalArgumentException e) {
|
||||
return DimensionType.valueOf(type);
|
||||
}
|
||||
|
||||
@@ -152,7 +152,7 @@ public class ModelConverter {
|
||||
dimensionReq.setSemanticType(SemanticType.CATEGORY.name());
|
||||
dimensionReq.setModelId(modelDO.getId());
|
||||
dimensionReq.setExpr(identify.getBizName());
|
||||
dimensionReq.setType(DimensionType.identify.name());
|
||||
dimensionReq.setType(DimensionType.fromIdentify(identify.getType()).name());
|
||||
return dimensionReq;
|
||||
}
|
||||
|
||||
|
||||
@@ -224,7 +224,7 @@ public class S2VisitsDemo extends S2BaseDemo {
|
||||
modelReq.setAdminOrgs(Collections.emptyList());
|
||||
List<Identify> identifiers = new ArrayList<>();
|
||||
ModelDetail modelDetail = new ModelDetail();
|
||||
identifiers.add(new Identify("用户名", IdentifyType.primary.name(), "user_name", 0));
|
||||
identifiers.add(new Identify("用户名", IdentifyType.foreign.name(), "user_name", 0));
|
||||
modelDetail.setIdentifiers(identifiers);
|
||||
|
||||
List<Dim> dimensions = new ArrayList<>();
|
||||
@@ -268,7 +268,7 @@ public class S2VisitsDemo extends S2BaseDemo {
|
||||
modelReq.setAdminOrgs(Collections.emptyList());
|
||||
List<Identify> identifiers = new ArrayList<>();
|
||||
ModelDetail modelDetail = new ModelDetail();
|
||||
identifiers.add(new Identify("用户", IdentifyType.primary.name(), "user_name", 0));
|
||||
identifiers.add(new Identify("用户", IdentifyType.foreign.name(), "user_name", 0));
|
||||
modelDetail.setIdentifiers(identifiers);
|
||||
|
||||
List<Dim> dimensions = new ArrayList<>();
|
||||
|
||||
Reference in New Issue
Block a user