大数据加工平台---数据清洗

package snow.controller;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.datasource.DataSourceUtils;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
import snow.entity.DataSource;
import snow.entity.Dictionary;
import snow.service.DataSourceService;
import snow.utils.ApiResponse;
import snow.utils.CSV2Excel;
import snow.utils.ExcelToSQLUtils;

import javax.servlet.http.HttpServletRequest;
import java.io.BufferedReader;
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;
import java.text.SimpleDateFormat;
import java.util.*;

@RestController
public class DataSourceController {
@Autowired
private DataSourceService dataSourceService;

//创建表 Spring
@PostMapping("/createtable/{nameIndex}/{unitIndex}/{meansIndex}")
public Map<String, Object> createTable(MultipartFile file, @PathVariable("nameIndex") Integer nameIndex, @PathVariable("unitIndex") Integer unitIndex, @PathVariable("meansIndex") Integer meansIndex, HttpServletRequest req) {

// String path = "/home/g2431/Documents/2018年软件基地年报.xlsx";
// dataSourceService.createTable(path);
String originName = file.getOriginalFilename();
if (!(originName.endsWith(".xlsx") || originName.endsWith(".csv"))) {
return ApiResponse.toJsonDefault(60204, "文件格式错误");
}

    DataSource dataSource;
    try {
        dataSource = fileUpload(file, req);
    } catch (IOException e) {
        e.printStackTrace();
        return ApiResponse.toJsonDefault(60204, "上传失败");
    }

    if (originName.endsWith("xlsx") || originName.endsWith("csv")) {
        try {
            int table = dataSourceService.createTable(dataSource.getFilePath(), nameIndex, unitIndex, meansIndex, dataSource.getTableName());
            System.out.println("table: " + table + dataSource.getTableName());
            dataSourceService.addDataSource(dataSource);
            System.out.println("dataSource: " + dataSource);
        } catch (Exception e) {
            System.out.println(e.toString());
            return ApiResponse.toJsonDefault(60205, "上传失败");
        }
    }


    Map<String, Object> map = new HashMap();
    map.put("dataSource", dataSource);
    return ApiResponse.toJson(20000, map);
}

//从excel添加
@PostMapping("/addfromexcel/{id}/{beginIndex}")
public Map<String, Object> addFromExcel(MultipartFile file, @PathVariable("id") Integer id, @PathVariable("beginIndex") Integer beginIndex, HttpServletRequest req) {
    String originName = file.getOriginalFilename();
    if (!(originName.endsWith(".xlsx") || originName.endsWith(".csv"))) {
        return ApiResponse.toJsonDefault(60204, "文件格式错误");
    }

    DataSource dataSource;
    try {
        dataSource = fileUpload(file, req);
    } catch (IOException e) {
        e.printStackTrace();
        return ApiResponse.toJsonDefault(60204, "上传失败");
    }

    if (originName.endsWith("xlsx") || originName.endsWith("csv")) {
        try {
            DataSource dataSource1 = dataSourceService.getOneById(id);
            int table = dataSourceService.addOneByOne(dataSource.getFilePath(), dataSource1.getTableName(), beginIndex);
            System.out.println("table: " + table + dataSource1.getTableName());
            System.out.println("dataSource: " + dataSource1);
        } catch (Exception e) {
            System.out.println(e.toString());
            return ApiResponse.toJsonDefault(60205, "上传失败");
        }
    }

    Map<String, Object> map = new HashMap();
    map.put("dataSource", dataSource);
    return ApiResponse.toJson(20000, map);
}

//文件上传
private DataSource fileUpload(MultipartFile file, HttpServletRequest req) throws IOException {
    DataSource dataSource = new DataSource();

    SimpleDateFormat sdf = new SimpleDateFormat("/yyyy/MM/dd/");
    String format = sdf.format(new Date());
    String realPath = "/home/g2431/upload" + format;
    File folder = new File(realPath);
    if (!folder.exists()) {
        folder.mkdirs();
    }

    String originalFilename = file.getOriginalFilename();

    String uuid = UUID.randomUUID().toString();

    String newName = uuid + "." + originalFilename.substring(originalFilename.lastIndexOf('.') + 1);

    System.out.println(folder + newName);
    String excelPath = folder + "/" + newName;
    file.transferTo(new File(folder, newName));

    if (originalFilename.endsWith("csv"))
        excelPath = CSV2Excel.csvToXLSX(excelPath);

    String url = req.getScheme() + "://" + req.getServerName() + ":" + req.getServerPort() + "/upload" + format + newName;

    dataSource.setFileUrl(url);
    dataSource.setFilePath(excelPath);
    dataSource.setShowName(originalFilename);
    dataSource.setTableName(uuid.replace("-", "").replaceAll("[0-9]", ""));
    dataSource.setType(originalFilename.substring(originalFilename.lastIndexOf('.') + 1).equals("xlsx") ? "excel" : "csv");
    System.out.println(dataSource);

    return dataSource;
}

//获取列表
@RequestMapping("/list")
@ResponseBody
public Map<String, Object> list() {
    Map<String, Object> map = new HashMap<String, Object>();
    List<DataSource> list = dataSourceService.getAll(1, 20);
    map.put("list", list);
    return ApiResponse.toJson(20000, map);
}

//删除数据源
@RequestMapping("/delete/{id}")
@ResponseBody
public Map<String, Object> delete(@PathVariable("id") Integer id) {
    int i = dataSourceService.deleteById(id);
    if (i > 0) {
        return ApiResponse.toJsonSuccess(20000, "删除成功");
    } else {
        return ApiResponse.toJsonDefault(62560, "删除失败");
    }
}

//修改
@RequestMapping("/update")
@ResponseBody
public Map<String, Object> update(@RequestBody DataSource dataSource) {
    int i = dataSourceService.updateById(dataSource);
    if (i > 0) {
        return ApiResponse.toJsonSuccess(20000, "修改成功");
    } else {
        return ApiResponse.toJsonDefault(62560, "修改失败");
    }
}

//查询接口
@RequestMapping("/query/{num}/{size}")
@ResponseBody
public Map<String, Object> query(@RequestBody DataSource dataSource, @PathVariable("num") Integer num, @PathVariable("size") Integer size) {
    Map<String, Object> map = new HashMap<String, Object>();
    List<DataSource> list = dataSourceService.query(dataSource, num, size);
    map.put("items", list);
    map.put("totals", list.size());
    return ApiResponse.toJson(20000, map);
}

//查找一个
@RequestMapping("/getOneById/{id}")
@ResponseBody
public Map<String, Object> getOneById(@PathVariable("id") Integer id) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);

    dataSource.getTableName();

    return ApiResponse.toJson(20000, map);
}

//获取字典
@RequestMapping("/getDictionary/{id}")
@ResponseBody
public Map<String, Object> getDictionary(@PathVariable("id") Integer id) {
    Map<String, Object> map = new HashMap<String, Object>();
    List<Dictionary> list = dataSourceService.getDictionary(id);
    map.put("items", list);
    return ApiResponse.toJson(20000, map);
}

//添加一个
@PostMapping("/addonedata/{id}")
public Map<String, Object> addOneData(@PathVariable("id") Integer id, @RequestBody Map<String, Object> map) {
    Map<String, Object> responseMap = new HashMap<>();

    int i = dataSourceService.addOneData(map, id);

    responseMap.put("nums", i);
    for (Map.Entry<String, Object> entry : map.entrySet()) {
        System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue());
    }
    return ApiResponse.toJson(20000, responseMap);
}

@PostMapping("/addonedatabydic/{id}")
public Map<String, Object> addOneDataByDic(@PathVariable("id") Integer id, @RequestBody List<Dictionary> list) {
    Map<String, Object> responseMap = new HashMap<>();
    Map<String, Object> map = new LinkedHashMap<>();

    for (Dictionary dictionary : list) {
        map.put(dictionary.getField(), dictionary.getDefault());
    }

    System.out.println(map);

    int i = dataSourceService.addOneData(map, id);

    responseMap.put("nums", i);
    for (Map.Entry<String, Object> entry : map.entrySet()) {
        System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue());
    }
    return ApiResponse.toJson(20000, responseMap);
}

@GetMapping("/getTableDetails/{id}/{num}/{size}")
public Map<String, Object> list(@PathVariable("id") Integer id, @PathVariable("num") Integer num, @PathVariable("size") Integer size) {
    Map<String, Object> responseMap = new HashMap<>();
    List<HashMap<String, Object>> hashMaps = dataSourceService.queryTableDetails(id, num, size);
    responseMap.put("items", hashMaps);
    responseMap.put("total", dataSourceService.getTableTotal(id));

    return ApiResponse.toJson(20000, responseMap);
}

//获取文件路径
@GetMapping("/getfileurl/{id}")
public Map<String, Object> getFileUrl(@PathVariable("id") Integer id) {
    Map<String, Object> responseMap = new HashMap<>();

    String fileUrl = dataSourceService.getFileUrl(id);
    responseMap.put("fileurl", fileUrl);

    return ApiResponse.toJson(20000, responseMap);
}

//修改字典
@RequestMapping("/updateDic/{id}/{field}/{type}/{comment}")
@ResponseBody
public Map<String, Object> updateDic(@PathVariable("id") Integer id, @PathVariable("field") String field, @PathVariable("type") String type, @PathVariable("comment") String comment) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);

    String tablename = dataSource.getTableName();

    int result = dataSourceService.updateDic(tablename, field, type, comment);
    map.put("num", result);

    return ApiResponse.toJson(20000, map);
}

//修改字典
@PostMapping(value = "/changeDic")
@ResponseBody
public Map<String, Object> changeDic(@RequestBody JSONObject dic) {
    Integer id = dic.getInteger("id");
    String oldfield = dic.getString("oldfield");
    String field = dic.getString("field");
    String oldtype = dic.getString("oldtype");
    String type = dic.getString("type");
    String comment = dic.getString("comment");

    System.out.println(id + "  " + oldfield);

    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);
    String tablename = dataSource.getTableName();
    int result = dataSourceService.changeDic(tablename, oldfield, field, oldtype, type, comment);
    map.put("num", result);
    return ApiResponse.toJson(20000, map);
}

//修改字典
@RequestMapping("/addField/{id}/{field}/{type}/{comment}")
@ResponseBody
public Map<String, Object> addField(@PathVariable("id") Integer id, @PathVariable("field") String field, @PathVariable("type") String type, @PathVariable("comment") String comment) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);

    String tablename = dataSource.getTableName();

    int result = dataSourceService.addField(tablename, field, type, comment);
    map.put("num", result);

    return ApiResponse.toJson(20000, map);
}

//修改字典
@RequestMapping("/deleteField/{id}/{field}")
@ResponseBody
public Map<String, Object> deleteField(@PathVariable("id") Integer id, @PathVariable("field") String field) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);

    String tablename = dataSource.getTableName();

    int result = dataSourceService.deleteField(tablename, field);
    map.put("num", result);

    return ApiResponse.toJson(20000, map);
}

//获取树json数据
@RequestMapping("/tableTree")
@ResponseBody
public Map<String, Object> tableTree() {
    Map<String, Object> map = new HashMap<String, Object>();

    List<DataSource> list = dataSourceService.getAll(1, 200);

    List<Map<String, Object>> tableList = new ArrayList();

    for (int i = 0; i < list.size(); i++) {
        List<Dictionary> dicList = dataSourceService.getDictionary(list.get(i).getId());
        Map<String, Object> cmap = new HashMap<>();
        cmap.put("name", list.get(i).getTableName());
        cmap.put("label", list.get(i).getTableName());

        List<Map<String, Object>> childrenList = new ArrayList<>();

        for (Dictionary dic : dicList) {
            Map<String, Object> fieldMap = new HashMap<>();
            fieldMap.put("name", list.get(i).getTableName() + "." + dic.getField());
            fieldMap.put("label", dic.getComment());
            childrenList.add(fieldMap);
        }

        cmap.put("children", childrenList);
        tableList.add(cmap);

    }

    map.put("data", tableList);
    return ApiResponse.toJson(20000, map);
}

//空值检测
@RequestMapping("/getNull/{id}/{field}")
@ResponseBody
public Map<String, Object> nullSearch(@PathVariable("id") Integer id, @PathVariable("field") String field) {
    Map<String, Object> responseMap = new HashMap<>();

    DataSource dataSource = dataSourceService.getOneById(id);

    String tablename = dataSource.getTableName();

    List<HashMap<String, Object>> hashMaps = dataSourceService.nullSearch(tablename, field);
    responseMap.put("items", hashMaps);

    return ApiResponse.toJson(20000, responseMap);
}

//空值补全
@RequestMapping("/nullUpdate/{id}/{field}/{value}/{rowid}")
@ResponseBody
public Map<String, Object> nullUpdate(@PathVariable("id") Integer id, @PathVariable("field") String field, @PathVariable("value") String value, @PathVariable("rowid") String rowid) {
    Map<String, Object> responseMap = new HashMap<>();

    DataSource dataSource = dataSourceService.getOneById(id);

    String tablename = dataSource.getTableName();

    int result = dataSourceService.nullUpdate(tablename, field,value,rowid);
    responseMap.put("num", result);

    return ApiResponse.toJson(20000, responseMap);
}

//jsonUpdate
@RequestMapping("/jsonUpdate/{id}/{field}")
@ResponseBody
public Map<String, Object> jsonUpdate(@PathVariable("id") Integer id, @PathVariable("field") String field) {
    Map<String, Object> responseMap = new HashMap<>();

    DataSource dataSource = dataSourceService.getOneById(id);
    String tablename = dataSource.getTableName();

    List<HashMap<String, Object>> list = dataSourceService.queryTableDetails(id,1,500000);

    Integer sum = 0;
    for (HashMap<String, Object> map : list) {
        Object object = map.get(field);
        String jsonStr = object.toString();
        String newStr = dataSourceService.jsonToStr(jsonStr);
        int result = dataSourceService.nullUpdate(tablename,field,newStr,map.get("id").toString());
        sum += result;
    }


    responseMap.put("num", sum);

    return ApiResponse.toJson(20000, responseMap);
}

//按条件删除
@RequestMapping("/deleteByNum/{id}/{field}/{value}/{type}")
@ResponseBody
public Map<String, Object> deleteByNum(@PathVariable("id") Integer id,@PathVariable("field") String field,@PathVariable("value") String value,@PathVariable("type") String type) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);
    String tablename = dataSource.getTableName();

    Integer result = dataSourceService.deleteByNum(tablename, field, value, type);

    map.put("num",result);

    return ApiResponse.toJson(20000, map);
}


//删除重复数据
@RequestMapping("/deleteRepe/{id}")
public Map<String, Object> deleteRepe(@PathVariable("id") Integer id) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);
    String tablename = dataSource.getTableName();

    Integer result = dataSourceService.deleteRepe(tablename);

    map.put("num",result);

    return ApiResponse.toJson(20000, map);
}

}
package snow.controller;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.datasource.DataSourceUtils;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
import snow.entity.DataSource;
import snow.entity.Dictionary;
import snow.service.DataSourceService;
import snow.utils.ApiResponse;
import snow.utils.CSV2Excel;
import snow.utils.ExcelToSQLUtils;

import javax.servlet.http.HttpServletRequest;
import java.io.BufferedReader;
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;
import java.text.SimpleDateFormat;
import java.util.*;

@RestController
public class DataSourceController {
@Autowired
private DataSourceService dataSourceService;

//创建表 Spring
@PostMapping("/createtable/{nameIndex}/{unitIndex}/{meansIndex}")
public Map<String, Object> createTable(MultipartFile file, @PathVariable("nameIndex") Integer nameIndex, @PathVariable("unitIndex") Integer unitIndex, @PathVariable("meansIndex") Integer meansIndex, HttpServletRequest req) {

// String path = "/home/g2431/Documents/2018年软件基地年报.xlsx";
// dataSourceService.createTable(path);
String originName = file.getOriginalFilename();
if (!(originName.endsWith(".xlsx") || originName.endsWith(".csv"))) {
return ApiResponse.toJsonDefault(60204, "文件格式错误");
}

    DataSource dataSource;
    try {
        dataSource = fileUpload(file, req);
    } catch (IOException e) {
        e.printStackTrace();
        return ApiResponse.toJsonDefault(60204, "上传失败");
    }

    if (originName.endsWith("xlsx") || originName.endsWith("csv")) {
        try {
            int table = dataSourceService.createTable(dataSource.getFilePath(), nameIndex, unitIndex, meansIndex, dataSource.getTableName());
            System.out.println("table: " + table + dataSource.getTableName());
            dataSourceService.addDataSource(dataSource);
            System.out.println("dataSource: " + dataSource);
        } catch (Exception e) {
            System.out.println(e.toString());
            return ApiResponse.toJsonDefault(60205, "上传失败");
        }
    }


    Map<String, Object> map = new HashMap();
    map.put("dataSource", dataSource);
    return ApiResponse.toJson(20000, map);
}

//从excel添加
@PostMapping("/addfromexcel/{id}/{beginIndex}")
public Map<String, Object> addFromExcel(MultipartFile file, @PathVariable("id") Integer id, @PathVariable("beginIndex") Integer beginIndex, HttpServletRequest req) {
    String originName = file.getOriginalFilename();
    if (!(originName.endsWith(".xlsx") || originName.endsWith(".csv"))) {
        return ApiResponse.toJsonDefault(60204, "文件格式错误");
    }

    DataSource dataSource;
    try {
        dataSource = fileUpload(file, req);
    } catch (IOException e) {
        e.printStackTrace();
        return ApiResponse.toJsonDefault(60204, "上传失败");
    }

    if (originName.endsWith("xlsx") || originName.endsWith("csv")) {
        try {
            DataSource dataSource1 = dataSourceService.getOneById(id);
            int table = dataSourceService.addOneByOne(dataSource.getFilePath(), dataSource1.getTableName(), beginIndex);
            System.out.println("table: " + table + dataSource1.getTableName());
            System.out.println("dataSource: " + dataSource1);
        } catch (Exception e) {
            System.out.println(e.toString());
            return ApiResponse.toJsonDefault(60205, "上传失败");
        }
    }

    Map<String, Object> map = new HashMap();
    map.put("dataSource", dataSource);
    return ApiResponse.toJson(20000, map);
}

//文件上传
private DataSource fileUpload(MultipartFile file, HttpServletRequest req) throws IOException {
    DataSource dataSource = new DataSource();

    SimpleDateFormat sdf = new SimpleDateFormat("/yyyy/MM/dd/");
    String format = sdf.format(new Date());
    String realPath = "/home/g2431/upload" + format;
    File folder = new File(realPath);
    if (!folder.exists()) {
        folder.mkdirs();
    }

    String originalFilename = file.getOriginalFilename();

    String uuid = UUID.randomUUID().toString();

    String newName = uuid + "." + originalFilename.substring(originalFilename.lastIndexOf('.') + 1);

    System.out.println(folder + newName);
    String excelPath = folder + "/" + newName;
    file.transferTo(new File(folder, newName));

    if (originalFilename.endsWith("csv"))
        excelPath = CSV2Excel.csvToXLSX(excelPath);

    String url = req.getScheme() + "://" + req.getServerName() + ":" + req.getServerPort() + "/upload" + format + newName;

    dataSource.setFileUrl(url);
    dataSource.setFilePath(excelPath);
    dataSource.setShowName(originalFilename);
    dataSource.setTableName(uuid.replace("-", "").replaceAll("[0-9]", ""));
    dataSource.setType(originalFilename.substring(originalFilename.lastIndexOf('.') + 1).equals("xlsx") ? "excel" : "csv");
    System.out.println(dataSource);

    return dataSource;
}

//获取列表
@RequestMapping("/list")
@ResponseBody
public Map<String, Object> list() {
    Map<String, Object> map = new HashMap<String, Object>();
    List<DataSource> list = dataSourceService.getAll(1, 20);
    map.put("list", list);
    return ApiResponse.toJson(20000, map);
}

//删除数据源
@RequestMapping("/delete/{id}")
@ResponseBody
public Map<String, Object> delete(@PathVariable("id") Integer id) {
    int i = dataSourceService.deleteById(id);
    if (i > 0) {
        return ApiResponse.toJsonSuccess(20000, "删除成功");
    } else {
        return ApiResponse.toJsonDefault(62560, "删除失败");
    }
}

//修改
@RequestMapping("/update")
@ResponseBody
public Map<String, Object> update(@RequestBody DataSource dataSource) {
    int i = dataSourceService.updateById(dataSource);
    if (i > 0) {
        return ApiResponse.toJsonSuccess(20000, "修改成功");
    } else {
        return ApiResponse.toJsonDefault(62560, "修改失败");
    }
}

//查询接口
@RequestMapping("/query/{num}/{size}")
@ResponseBody
public Map<String, Object> query(@RequestBody DataSource dataSource, @PathVariable("num") Integer num, @PathVariable("size") Integer size) {
    Map<String, Object> map = new HashMap<String, Object>();
    List<DataSource> list = dataSourceService.query(dataSource, num, size);
    map.put("items", list);
    map.put("totals", list.size());
    return ApiResponse.toJson(20000, map);
}

//查找一个
@RequestMapping("/getOneById/{id}")
@ResponseBody
public Map<String, Object> getOneById(@PathVariable("id") Integer id) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);

    dataSource.getTableName();

    return ApiResponse.toJson(20000, map);
}

//获取字典
@RequestMapping("/getDictionary/{id}")
@ResponseBody
public Map<String, Object> getDictionary(@PathVariable("id") Integer id) {
    Map<String, Object> map = new HashMap<String, Object>();
    List<Dictionary> list = dataSourceService.getDictionary(id);
    map.put("items", list);
    return ApiResponse.toJson(20000, map);
}

//添加一个
@PostMapping("/addonedata/{id}")
public Map<String, Object> addOneData(@PathVariable("id") Integer id, @RequestBody Map<String, Object> map) {
    Map<String, Object> responseMap = new HashMap<>();

    int i = dataSourceService.addOneData(map, id);

    responseMap.put("nums", i);
    for (Map.Entry<String, Object> entry : map.entrySet()) {
        System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue());
    }
    return ApiResponse.toJson(20000, responseMap);
}

@PostMapping("/addonedatabydic/{id}")
public Map<String, Object> addOneDataByDic(@PathVariable("id") Integer id, @RequestBody List<Dictionary> list) {
    Map<String, Object> responseMap = new HashMap<>();
    Map<String, Object> map = new LinkedHashMap<>();

    for (Dictionary dictionary : list) {
        map.put(dictionary.getField(), dictionary.getDefault());
    }

    System.out.println(map);

    int i = dataSourceService.addOneData(map, id);

    responseMap.put("nums", i);
    for (Map.Entry<String, Object> entry : map.entrySet()) {
        System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue());
    }
    return ApiResponse.toJson(20000, responseMap);
}

@GetMapping("/getTableDetails/{id}/{num}/{size}")
public Map<String, Object> list(@PathVariable("id") Integer id, @PathVariable("num") Integer num, @PathVariable("size") Integer size) {
    Map<String, Object> responseMap = new HashMap<>();
    List<HashMap<String, Object>> hashMaps = dataSourceService.queryTableDetails(id, num, size);
    responseMap.put("items", hashMaps);
    responseMap.put("total", dataSourceService.getTableTotal(id));

    return ApiResponse.toJson(20000, responseMap);
}

//获取文件路径
@GetMapping("/getfileurl/{id}")
public Map<String, Object> getFileUrl(@PathVariable("id") Integer id) {
    Map<String, Object> responseMap = new HashMap<>();

    String fileUrl = dataSourceService.getFileUrl(id);
    responseMap.put("fileurl", fileUrl);

    return ApiResponse.toJson(20000, responseMap);
}

//修改字典
@RequestMapping("/updateDic/{id}/{field}/{type}/{comment}")
@ResponseBody
public Map<String, Object> updateDic(@PathVariable("id") Integer id, @PathVariable("field") String field, @PathVariable("type") String type, @PathVariable("comment") String comment) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);

    String tablename = dataSource.getTableName();

    int result = dataSourceService.updateDic(tablename, field, type, comment);
    map.put("num", result);

    return ApiResponse.toJson(20000, map);
}

//修改字典
@PostMapping(value = "/changeDic")
@ResponseBody
public Map<String, Object> changeDic(@RequestBody JSONObject dic) {
    Integer id = dic.getInteger("id");
    String oldfield = dic.getString("oldfield");
    String field = dic.getString("field");
    String oldtype = dic.getString("oldtype");
    String type = dic.getString("type");
    String comment = dic.getString("comment");

    System.out.println(id + "  " + oldfield);

    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);
    String tablename = dataSource.getTableName();
    int result = dataSourceService.changeDic(tablename, oldfield, field, oldtype, type, comment);
    map.put("num", result);
    return ApiResponse.toJson(20000, map);
}

//修改字典
@RequestMapping("/addField/{id}/{field}/{type}/{comment}")
@ResponseBody
public Map<String, Object> addField(@PathVariable("id") Integer id, @PathVariable("field") String field, @PathVariable("type") String type, @PathVariable("comment") String comment) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);

    String tablename = dataSource.getTableName();

    int result = dataSourceService.addField(tablename, field, type, comment);
    map.put("num", result);

    return ApiResponse.toJson(20000, map);
}

//修改字典
@RequestMapping("/deleteField/{id}/{field}")
@ResponseBody
public Map<String, Object> deleteField(@PathVariable("id") Integer id, @PathVariable("field") String field) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);

    String tablename = dataSource.getTableName();

    int result = dataSourceService.deleteField(tablename, field);
    map.put("num", result);

    return ApiResponse.toJson(20000, map);
}

//获取树json数据
@RequestMapping("/tableTree")
@ResponseBody
public Map<String, Object> tableTree() {
    Map<String, Object> map = new HashMap<String, Object>();

    List<DataSource> list = dataSourceService.getAll(1, 200);

    List<Map<String, Object>> tableList = new ArrayList();

    for (int i = 0; i < list.size(); i++) {
        List<Dictionary> dicList = dataSourceService.getDictionary(list.get(i).getId());
        Map<String, Object> cmap = new HashMap<>();
        cmap.put("name", list.get(i).getTableName());
        cmap.put("label", list.get(i).getTableName());

        List<Map<String, Object>> childrenList = new ArrayList<>();

        for (Dictionary dic : dicList) {
            Map<String, Object> fieldMap = new HashMap<>();
            fieldMap.put("name", list.get(i).getTableName() + "." + dic.getField());
            fieldMap.put("label", dic.getComment());
            childrenList.add(fieldMap);
        }

        cmap.put("children", childrenList);
        tableList.add(cmap);

    }

    map.put("data", tableList);
    return ApiResponse.toJson(20000, map);
}

//空值检测
@RequestMapping("/getNull/{id}/{field}")
@ResponseBody
public Map<String, Object> nullSearch(@PathVariable("id") Integer id, @PathVariable("field") String field) {
    Map<String, Object> responseMap = new HashMap<>();

    DataSource dataSource = dataSourceService.getOneById(id);

    String tablename = dataSource.getTableName();

    List<HashMap<String, Object>> hashMaps = dataSourceService.nullSearch(tablename, field);
    responseMap.put("items", hashMaps);

    return ApiResponse.toJson(20000, responseMap);
}

//空值补全
@RequestMapping("/nullUpdate/{id}/{field}/{value}/{rowid}")
@ResponseBody
public Map<String, Object> nullUpdate(@PathVariable("id") Integer id, @PathVariable("field") String field, @PathVariable("value") String value, @PathVariable("rowid") String rowid) {
    Map<String, Object> responseMap = new HashMap<>();

    DataSource dataSource = dataSourceService.getOneById(id);

    String tablename = dataSource.getTableName();

    int result = dataSourceService.nullUpdate(tablename, field,value,rowid);
    responseMap.put("num", result);

    return ApiResponse.toJson(20000, responseMap);
}

//jsonUpdate
@RequestMapping("/jsonUpdate/{id}/{field}")
@ResponseBody
public Map<String, Object> jsonUpdate(@PathVariable("id") Integer id, @PathVariable("field") String field) {
    Map<String, Object> responseMap = new HashMap<>();

    DataSource dataSource = dataSourceService.getOneById(id);
    String tablename = dataSource.getTableName();

    List<HashMap<String, Object>> list = dataSourceService.queryTableDetails(id,1,500000);

    Integer sum = 0;
    for (HashMap<String, Object> map : list) {
        Object object = map.get(field);
        String jsonStr = object.toString();
        String newStr = dataSourceService.jsonToStr(jsonStr);
        int result = dataSourceService.nullUpdate(tablename,field,newStr,map.get("id").toString());
        sum += result;
    }


    responseMap.put("num", sum);

    return ApiResponse.toJson(20000, responseMap);
}

//按条件删除
@RequestMapping("/deleteByNum/{id}/{field}/{value}/{type}")
@ResponseBody
public Map<String, Object> deleteByNum(@PathVariable("id") Integer id,@PathVariable("field") String field,@PathVariable("value") String value,@PathVariable("type") String type) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);
    String tablename = dataSource.getTableName();

    Integer result = dataSourceService.deleteByNum(tablename, field, value, type);

    map.put("num",result);

    return ApiResponse.toJson(20000, map);
}


//删除重复数据
@RequestMapping("/deleteRepe/{id}")
public Map<String, Object> deleteRepe(@PathVariable("id") Integer id) {
    Map<String, Object> map = new HashMap<String, Object>();
    DataSource dataSource = dataSourceService.getOneById(id);
    String tablename = dataSource.getTableName();

    Integer result = dataSourceService.deleteRepe(tablename);

    map.put("num",result);

    return ApiResponse.toJson(20000, map);
}

}

posted @ 2021-12-16 23:03  巩云龙  阅读(127)  评论(0)    收藏  举报