use of com.baomidou.mybatisplus.core.incrementer.IdentifierGenerator in project citrus by Yiuman.
the class MdaServiceImpl method save.
@Override
public String save(Map<String, Object> entity) throws Exception {
if (!this.beforeSave(entity)) {
return null;
}
Table tableEntity = getTableEntity(getModelId(WebUtils.getRequest()));
TableMeta tableMeta = entity2Meta(tableEntity);
PrimaryKeyConstraint primaryKeyConstraint = tableMeta.getPrimaryKey();
final Map<ColumnMeta, Object> keyMap = new HashMap<>(tableMeta.getColumns().size());
if (Objects.nonNull(primaryKeyConstraint)) {
// 如果是组合主键必须主动赋值,否则抛异常
if (isCombinePrimaryKeys(primaryKeyConstraint)) {
primaryKeyConstraint.getColumns().forEach(primaryKeyColumn -> {
Object key = entity.get(primaryKeyColumn.getColumnName());
if (Objects.isNull(key)) {
// 当前模型的主键为组合模式,不能为空
throw new MdaException(String.format("The primary key of the current model is in combination mode and cannot be empty." + " The corresponding columns are [%s]", primaryKeyConstraint.getColumns().stream().map(ColumnMeta::getColumnName).collect(Collectors.joining(","))));
}
keyMap.put(primaryKeyColumn, key);
});
} else {
primaryKeyConstraint.getColumns().stream().findFirst().ifPresent(primaryKeyColumn -> {
if (Objects.isNull(entity.get(primaryKeyColumn.getColumnName()))) {
final IdentifierGenerator identifierGenerator = GlobalConfigUtils.getGlobalConfig(getDmlProcessor().getSqlSessionFactory(tableEntity.getNamespace()).getConfiguration()).getIdentifierGenerator();
IdType idType = tableEntity.getIdType();
Object key;
if (idType == IdType.ASSIGN_ID) {
Number number = identifierGenerator.nextId(entity);
key = primaryKeyColumn.getJdbcType().equals(JDBCType.VARCHAR) ? number.toString() : number;
} else {
key = identifierGenerator.nextUUID(entity);
}
keyMap.put(primaryKeyColumn, key);
entity.put(primaryKeyColumn.getColumnName(), key);
} else {
keyMap.put(primaryKeyColumn, entity.get(primaryKeyColumn.getColumnName()));
}
});
}
}
SaveMeta saveMeta = SaveMeta.builder().namespace(tableMeta.getNamespace()).tableName(tableMeta.getTableName()).entity(entity).build();
SimpleQueryBuilder simpleQueryBuilder = QueryBuilders.create();
keyMap.forEach((key, value) -> simpleQueryBuilder.eq(key.getColumnName(), value));
if (Objects.isNull(get(simpleQueryBuilder.toQuery()))) {
getDmlProcessor().insert(saveMeta);
} else {
UpdateWrapper<?> updateWrapper = Wrappers.update();
keyMap.forEach((key, value) -> {
updateWrapper.eq(key.getColumnName(), value);
entity.remove(key.getColumnName());
});
getDmlProcessor().update(saveMeta, updateWrapper);
}
afterSave(entity);
return keyMap.values().stream().map(Object::toString).collect(Collectors.joining("-"));
}
Aggregations