| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472 |
- package jnpf.base.controller;
- import cn.dev33.satoken.annotation.SaCheckPermission;
- import cn.dev33.satoken.annotation.SaMode;
- import com.alibaba.fastjson.JSONObject;
- import io.swagger.v3.oas.annotations.Operation;
- import io.swagger.v3.oas.annotations.Parameter;
- import io.swagger.v3.oas.annotations.Parameters;
- import io.swagger.v3.oas.annotations.tags.Tag;
- import jakarta.validation.Valid;
- import jnpf.base.ActionResult;
- import jnpf.base.Page;
- import jnpf.base.Pagination;
- import jnpf.base.entity.PrintDevEntity;
- import jnpf.base.model.dbtable.dto.DbTableFieldDTO;
- import jnpf.base.model.dbtable.form.DbFieldForm;
- import jnpf.base.model.dbtable.vo.DbFieldVO;
- import jnpf.base.model.dbtable.vo.DbTableInfoVO;
- import jnpf.base.model.dbtable.vo.DbTableListVO;
- import jnpf.base.service.DbLinkService;
- import jnpf.base.service.DbTableService;
- import jnpf.base.vo.DownloadVO;
- import jnpf.base.vo.ListVO;
- import jnpf.base.vo.PageListVO;
- import jnpf.base.vo.PaginationVO;
- import jnpf.config.ConfigValueUtil;
- import jnpf.constant.FileTypeConstant;
- import jnpf.constant.GenerateConstant;
- import jnpf.constant.MsgCode;
- import jnpf.database.datatype.model.DtModelDTO;
- import jnpf.database.model.dbfield.DbFieldModel;
- import jnpf.database.model.dbtable.DbTableFieldModel;
- import jnpf.database.model.entity.DbLinkEntity;
- import jnpf.database.model.page.DbTableDataForm;
- import jnpf.database.sql.util.SqlFastUtil;
- import jnpf.emnus.ModuleTypeEnum;
- import jnpf.exception.DataException;
- import jnpf.util.*;
- import lombok.extern.slf4j.Slf4j;
- import org.apache.commons.collections4.CollectionUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.http.MediaType;
- import org.springframework.web.bind.annotation.*;
- import org.springframework.web.multipart.MultipartFile;
- import java.util.ArrayList;
- import java.util.List;
- import java.util.Map;
- import java.util.StringJoiner;
- import java.util.regex.Matcher;
- import java.util.regex.Pattern;
- import java.util.stream.Collectors;
- /**
- * 数据建模
- * N:方法说明 - 微服务同步使用
- *
- * @author JNPF开发平台组
- * @version V3.1.0
- * @copyright 引迈信息技术有限公司
- * @date 2019年9月27日 上午9:18
- */
- @Tag(name = "数据建模", description = "DataModel")
- @RestController
- @RequestMapping("/api/system/DataModel")
- @Slf4j
- public class DbTableController {
- @Autowired
- private DbTableService dbTableService;
- @Autowired
- private FileExport fileExport;
- @Autowired
- private ConfigValueUtil configValueUtil;
- @Autowired
- private DbLinkService dblinkService;
- /**
- * 1:列表
- *
- * @param id 连接id
- * @param pagination 关键词
- * @return 数据库表列表
- * @throws DataException ignore
- */
- @Operation(summary = "获取数据库表列表")
- @Parameters({
- @Parameter(name = "id", description = "连接id", required = true)
- })
- @GetMapping("/{id}/Tables")
- public ActionResult<DbTableListVO<DbTableFieldModel>> getList(@PathVariable("id") String id, Pagination pagination) throws Exception {
- try {
- List<DbTableFieldModel> tableList = dbTableService.getListPage(XSSEscape.escape(id), pagination);
- return ActionResult.success(new DbTableListVO<>(tableList, JsonUtil.getJsonToBean(pagination, PaginationVO.class)));
- } catch (Exception e) {
- log.error("获取表列表失败", e);
- throw new DataException(MsgCode.DB302.get());
- }
- }
- /**
- * 1:列表
- *
- * @param id 连接id
- * @param page 关键字
- * @return 数据库表列表
- * @throws DataException ignore
- */
- @Operation(summary = "获取数据库表列表")
- @Parameters({
- @Parameter(name = "id", description = "连接id", required = true)
- })
- @GetMapping("/{id}/TableAll")
- public ActionResult<ListVO<DbTableFieldModel>> getList(@PathVariable("id") String id, Page page) throws Exception {
- List<DbTableFieldModel> tableList = dbTableService.getListPage(XSSEscape.escape(id), page);
- ListVO<DbTableFieldModel> list = new ListVO<>();
- list.setList(tableList);
- return ActionResult.success(list);
- }
- /**
- * 2:预览数据库表
- *
- * @param dbTableDataForm 查询条件
- * @param linkId 接Id
- * @param tableName 表名
- * @return 数据库表
- * @throws Exception ignore
- */
- @Operation(summary = "预览数据库表")
- @Parameters({
- @Parameter(name = "linkId", description = "数据连接ID", required = true),
- @Parameter(name = "tableName", description = "表名", required = true)
- })
- @SaCheckPermission("dataCenter.dataModel")
- @GetMapping("/{linkId}/Table/{tableName}/Preview")
- public ActionResult<PageListVO<Map<String, Object>>> data(DbTableDataForm dbTableDataForm, @PathVariable("linkId") String linkId, @PathVariable("tableName") String tableName) throws Exception {
- String escape = XSSEscape.escape(linkId);
- String escapeTableName = XSSEscape.escape(tableName);
- List<Map<String, Object>> data = dbTableService.getData(dbTableDataForm, escape, escapeTableName);
- PaginationVO paginationVO = JsonUtilEx.getJsonToBeanEx(dbTableDataForm, PaginationVO.class);
- return ActionResult.page(JsonUtil.getJsonToListMap(JsonUtil.getObjectToStringAsDate(data)), paginationVO);
- }
- /**
- * 3:列表
- *
- * @param linkId 数据连接ID
- * @param tableName 表名
- * @return 列表
- * @throws DataException ignore
- */
- @GetMapping("/{linkId}/Tables/{tableName}/Fields/Selector")
- @Operation(summary = "获取数据库表字段下拉框列表")
- @Parameters({
- @Parameter(name = "linkId", description = "数据连接ID", required = true),
- @Parameter(name = "tableName", description = "表名", required = true)
- })
- public ActionResult<ListVO<DbFieldVO>> selectorList(@PathVariable("linkId") String linkId, @PathVariable("tableName") String tableName) throws Exception {
- List<DbFieldModel> data = dbTableService.getFieldList(linkId, tableName);
- List<DbFieldVO> vos = JsonUtil.getJsonToList(data, DbFieldVO.class);
- ListVO<DbFieldVO> vo = new ListVO<>();
- vo.setList(vos);
- return ActionResult.success(vo);
- }
- /**
- * 4:字段列表
- *
- * @param linkId 连接Id
- * @param tableName 表名
- * @param type 类型
- * @return 段列表
- * @throws DataException ignore
- */
- @Operation(summary = "获取数据库表字段列表")
- @Parameters({
- @Parameter(name = "linkId", description = "数据连接ID", required = true),
- @Parameter(name = "tableName", description = "表名", required = true),
- @Parameter(name = "type", description = "类型")
- })
- @GetMapping("/{linkId}/Tables/{tableName}/Fields")
- public ActionResult<ListVO<DbFieldVO>> fieldList(@PathVariable("linkId") String linkId, @PathVariable("tableName") String tableName, String type) throws Exception {
- List<DbFieldModel> data;
- try {
- data = dbTableService.getFieldList(linkId, tableName);
- } catch (Exception e) {
- log.error("获取表字段列表失败", e);
- return ActionResult.fail(MsgCode.DB302.get());
- }
- if (CollectionUtils.isEmpty(data)) {
- return ActionResult.fail(MsgCode.DB018.get());
- }
- List<DbFieldVO> voList = data.stream().map(DbFieldVO::new).collect(Collectors.toList());
- //返回数据库原字段
- // for (DbFieldVO vo : voList) {
- // String columnName = vo.getField();
- // if ("1".equals(type)) {
- // String name = vo.getField().toLowerCase();
- // name = name.startsWith("f_")? name.substring(2) : name;
- // vo.setField(CaseFormat.LOWER_UNDERSCORE.to(CaseFormat.LOWER_CAMEL, name));
- // }
- // vo.setColumnName(columnName);
- // }
- ListVO<DbFieldVO> vo = new ListVO<>();
- vo.setList(voList);
- return ActionResult.success(vo);
- }
- /**
- * 5:编辑显示 - 表、字段信息
- *
- * @param dbLinkId 连接Id
- * @param tableName 表名
- * @return 表、字段信息
- * @throws DataException ignore
- */
- @Operation(summary = "获取表及表字段信息")
- @Parameters({
- @Parameter(name = "dbLinkId", description = "数据连接ID", required = true),
- @Parameter(name = "tableName", description = "表名", required = true)
- })
- @SaCheckPermission(value = {"onlineDev.formDesign", "dataCenter.dataModel"}, mode = SaMode.OR)
- @GetMapping("/{dbLinkId}/Table/{tableName}")
- public ActionResult<DbTableInfoVO> get(@PathVariable("dbLinkId") String dbLinkId, @PathVariable("tableName") String tableName) throws Exception {
- return ActionResult.success(new DbTableInfoVO(dbTableService.getTable(dbLinkId, tableName), dbTableService.getFieldList(dbLinkId, tableName)));
- }
- /**
- * 验证表名字段名是否系统关键字
- *
- * @param dbTableFieldDTO
- * @return
- */
- private static String checkName(DbTableFieldDTO dbTableFieldDTO, Integer index) {
- List<String> javaSql = new ArrayList<>();
- javaSql.addAll(GenerateConstant.JAVA_KEYWORD);
- javaSql.addAll(GenerateConstant.SQL_KEYWORD);
- if (javaSql.contains(dbTableFieldDTO.getTableInfo().getNewTable().toLowerCase())) {
- return "表名称" + dbTableFieldDTO.getTableInfo().getNewTable();
- }
- if (dbTableFieldDTO.getTableFieldList() != null && dbTableFieldDTO.getTableFieldList().size() > 0) {
- StringJoiner sj = new StringJoiner(",");
- for (int n = 0; n < dbTableFieldDTO.getTableFieldList().size(); n++) {
- DbFieldForm item = dbTableFieldDTO.getTableFieldList().get(n);
- if (javaSql.contains(item.getField().toLowerCase())) {
- // sj.add("第" + (index + n + 1) + "行列名" + item.getField());
- sj.add("列名" + item.getField());
- }
- }
- if (StringUtil.isNotEmpty(sj.toString())) {
- return sj.toString();
- }
- }
- return "";
- }
- /**
- * 6:新建表
- *
- * @param linkId 连接Id
- * @return 执行结果
- * @throws DataException ignore
- */
- @Operation(summary = "新建")
- @Parameters({
- @Parameter(name = "linkId", description = "数据连接ID", required = true),
- @Parameter(name = "dbTableFieldDTO", description = "建表参数对象", required = true)
- })
- @SaCheckPermission("dataCenter.dataModel")
- @PostMapping("{linkId}/Table")
- public ActionResult<String> create(@PathVariable("linkId") String linkId, @RequestBody @Valid DbTableFieldDTO dbTableFieldDTO) throws Exception {
- try {
- String err = this.checkName(dbTableFieldDTO, 0);
- if (StringUtil.isNotEmpty(err)) {
- return ActionResult.fail(MsgCode.SYS128.get(err));
- }
- int status = dbTableService.createTable(dbTableFieldDTO.getCreDbTableModel(linkId));
- if (status == 1) {
- return ActionResult.success(MsgCode.SU001.get());
- } else if (status == 0) {
- return ActionResult.fail(MsgCode.EXIST001.get());
- } else {
- return ActionResult.fail(MsgCode.DB019.get());
- }
- } catch (Exception e) {
- return ActionResult.fail(e.getMessage());
- }
- }
- /**
- * 7:更新
- *
- * @param linkId 连接Id
- * @return 执行结果
- * @throws DataException ignore
- */
- @Operation(summary = "更新")
- @Parameters({
- @Parameter(name = "linkId", description = "数据连接ID", required = true),
- @Parameter(name = "dbTableFieldDTO", description = "建表参数对象", required = true)
- })
- @SaCheckPermission("dataCenter.dataModel")
- @PutMapping("/{linkId}/Table")
- public ActionResult<String> update(@PathVariable("linkId") String linkId, @RequestBody @Valid DbTableFieldDTO dbTableFieldDTO) throws Exception {
- String err = this.checkName(dbTableFieldDTO, 0);
- if (StringUtil.isNotEmpty(err)) {
- return ActionResult.fail(MsgCode.SYS128.get(err));
- }
- DbTableFieldModel dbTableModel = dbTableFieldDTO.getUpDbTableModel(linkId);
- // 当修改表名时,验证是否与其他表名重名
- if (!dbTableModel.getUpdateNewTable().equals(dbTableModel.getUpdateOldTable())) {
- if (dbTableService.isExistTable(linkId, dbTableModel.getUpdateNewTable())) {
- return ActionResult.fail(MsgCode.EXIST001.get());
- }
- }
- try {
- dbTableService.update(dbTableModel);
- return ActionResult.success(MsgCode.SU004.get());
- } catch (Exception e) {
- return ActionResult.fail(e.getMessage());
- }
- }
- /**
- * 8:更新
- *
- * @param linkId 连接Id
- * @return 执行结果
- * @throws DataException ignore
- */
- @Operation(summary = "添加字段")
- @Parameters({
- @Parameter(name = "linkId", description = "数据连接ID", required = true),
- @Parameter(name = "dbTableFieldDTO", description = "建表参数对象", required = true)
- })
- @SaCheckPermission(value = {"onlineDev.formDesign", "dataCenter.dataModel"}, mode = SaMode.OR)
- @PutMapping("/{linkId}/addFields")
- public ActionResult<String> addField(@PathVariable("linkId") String linkId, @RequestBody @Valid DbTableFieldDTO dbTableFieldDTO) throws Exception {
- int size = 0;
- // try {
- // DbLinkEntity dbLinkEntity = dblinkService.getResource(linkId);
- // List<DbFieldModel> fieldList = SqlFastUtil.getFieldList(dbLinkEntity, dbTableFieldDTO.getTableInfo().getTable());
- // size = fieldList.size();
- // } catch (Exception e) {
- // }
- String err = this.checkName(dbTableFieldDTO, size);
- if (StringUtil.isNotEmpty(err)) {
- return ActionResult.fail(MsgCode.SYS128.get(err));
- }
- DbTableFieldModel dbTableModel = dbTableFieldDTO.getUpDbTableModel(linkId);
- dbTableService.addField(dbTableModel);
- return ActionResult.success(MsgCode.SU004.get());
- }
- /**
- * 9:删除
- *
- * @param linkId 连接Id
- * @param tableName 表名
- * @return 执行结果
- * @throws DataException ignore
- */
- @Operation(summary = "删除")
- @Parameters({
- @Parameter(name = "linkId", description = "数据连接ID", required = true),
- @Parameter(name = "tableName", description = "表名", required = true)
- })
- @SaCheckPermission("dataCenter.dataModel")
- @DeleteMapping("/{linkId}/Table/{tableName}")
- public ActionResult<String> delete(@PathVariable("linkId") String linkId, @PathVariable("tableName") String tableName) throws Exception {
- dbTableService.delete(linkId, tableName);
- return ActionResult.success(MsgCode.SU003.get());
- }
- /**
- * 删除全部表(慎用)
- *
- * @param linkId 连接Id
- * @return 执行结果
- * @throws DataException ignore
- */
- @Operation(summary = "删除全部表")
- @Parameters({
- @Parameter(name = "linkId", description = "数据连接ID", required = true),
- })
- @SaCheckPermission("dataCenter.dataModel")
- @DeleteMapping("/{linkId}/deleteAllTable")
- public ActionResult<String> deleteAllTable(@PathVariable("linkId") String linkId, String dbType) throws Exception {
- dbTableService.deleteAllTable(linkId, dbType);
- return ActionResult.success(MsgCode.SU003.get());
- }
- /**
- * 10:导入
- *
- * @param linkId 连接id
- * @param multipartFile 文件
- * @return 执行结果
- * @throws DataException ignore
- */
- @Operation(summary = "导入")
- @Parameters({
- @Parameter(name = "linkId", description = "数据连接ID", required = true),
- })
- @SaCheckPermission("dataCenter.dataModel")
- @PostMapping(value = "/{linkId}/Actions/Import", consumes = MediaType.MULTIPART_FORM_DATA_VALUE)
- public ActionResult<PageListVO<PrintDevEntity>> importData(@PathVariable String linkId, @RequestPart("file") MultipartFile multipartFile) throws Exception {
- //判断是否为.json结尾
- if (FileUtil.existsSuffix(multipartFile, ModuleTypeEnum.SYSTEM_DBTABLE.getTableName())) {
- return ActionResult.fail(MsgCode.IMP002.get());
- }
- // 读取文件内容
- String fileContent = FileUtil.getFileContent(multipartFile);
- DbTableFieldModel dbTableFieldModel = JSONObject.parseObject(fileContent, DbTableFieldModel.class);
- // 数据类型长度解析(enum枚举无法Json化)
- for (DbFieldModel dbFieldModel : dbTableFieldModel.getDbFieldModelList()) {
- String formatDataType = dbFieldModel.getLength();
- String dataType = "";
- String dtLength = "";
- if (formatDataType.contains("(")) {
- Matcher matcher = Pattern.compile("(.+)\\((.*)\\)").matcher(formatDataType);
- if (matcher.find()) {
- dataType = matcher.group(1).trim();
- dtLength = matcher.group(2).trim();
- }
- } else {
- dataType = formatDataType.trim();
- }
- dbFieldModel.setDtModelDTO(new DtModelDTO(dataType, dtLength, dbTableFieldModel.getDbEncode(), false)
- .setConvertType(DtModelDTO.DB_VAL));
- }
- dbTableFieldModel.setDbLinkId(linkId);
- int i = dbTableService.createTable(dbTableFieldModel);
- if (i == 1) {
- return ActionResult.success(MsgCode.IMP001.get());
- } else {
- return ActionResult.fail(MsgCode.DB007.get());
- }
- }
- /**
- * 11:导出
- *
- * @param tableName 表明
- * @param linkId 连接id
- * @return 执行结果
- */
- @Operation(summary = "导出")
- @Parameters({
- @Parameter(name = "tableName", description = "表明", required = true),
- @Parameter(name = "linkId", description = "连接id", required = true)
- })
- @SaCheckPermission("dataCenter.dataModel")
- @GetMapping("/{linkId}/Table/{tableName}/Actions/Export")
- public ActionResult<DownloadVO> export(@PathVariable String tableName, @PathVariable String linkId) throws Exception {
- DbTableFieldModel dbTable = dbTableService.getDbTableModel(linkId, tableName);
- dbTable.getDbFieldModelList().forEach(dbField -> {
- dbField.setLength(dbField.getDtModelDTO().convert().formatDataType());
- dbField.setDtModelDTO(null);
- });
- //导出文件
- DownloadVO downloadVO = fileExport.exportFile(dbTable, FileTypeConstant.TEMPORARY,
- dbTable.getTable() + "_", ModuleTypeEnum.SYSTEM_DBTABLE.getTableName());
- return ActionResult.success(downloadVO);
- }
- }
|