|
|
|
@ -1,7 +1,5 @@
|
|
|
|
|
package com.dsideal.base.DataEase.Util;
|
|
|
|
|
|
|
|
|
|
import cn.hutool.core.lang.Snowflake;
|
|
|
|
|
import cn.hutool.core.util.IdUtil;
|
|
|
|
|
import cn.hutool.http.HttpUtil;
|
|
|
|
|
import com.alibaba.fastjson.JSONObject;
|
|
|
|
|
import com.dsideal.base.DataEase.Model.DataEaseModel;
|
|
|
|
@ -13,7 +11,6 @@ import com.jfinal.plugin.activerecord.Db;
|
|
|
|
|
import com.jfinal.plugin.activerecord.Record;
|
|
|
|
|
|
|
|
|
|
import java.util.List;
|
|
|
|
|
import java.util.Random;
|
|
|
|
|
import java.util.UUID;
|
|
|
|
|
|
|
|
|
|
import static com.dsideal.base.DataEase.Model.DataEaseModel.DB_NAME;
|
|
|
|
@ -39,13 +36,13 @@ public class CopyBigScreen {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 清理通过本程序生成的所有副本,为了再次生成不重复
|
|
|
|
|
* 清理指定名称大屏的所有副本,为了再次生成不重复
|
|
|
|
|
*
|
|
|
|
|
* @param dataVisualizationName
|
|
|
|
|
* @param bigScreenName 大屏名称
|
|
|
|
|
*/
|
|
|
|
|
public static void clear(String dataVisualizationName) {
|
|
|
|
|
public static void clearScreen(String bigScreenName) {
|
|
|
|
|
//一、先删除后插入保持健康:保留:【云南省教育决策支持系统【市州】】,删除掉云南省教育决策支持系统【市州】+昆明市,云南省教育决策支持系统【市州】+楚雄州等数据
|
|
|
|
|
String sql = "select * from data_visualization_info where name like '%" + dataVisualizationName + "%' and name <>'" + dataVisualizationName + "'";
|
|
|
|
|
String sql = "select * from data_visualization_info where name like '%" + bigScreenName + "%' and name <>'" + bigScreenName + "'";
|
|
|
|
|
List<Record> toDelList = Db.use(DB_NAME).find(sql);
|
|
|
|
|
for (Record record : toDelList) {
|
|
|
|
|
long id = record.getLong("id");
|
|
|
|
@ -53,7 +50,7 @@ public class CopyBigScreen {
|
|
|
|
|
sql = "delete from core_chart_view where scene_id=?";
|
|
|
|
|
Db.use(DB_NAME).update(sql, id);
|
|
|
|
|
//(2) 删除共享链接表
|
|
|
|
|
sql = "delete from xpack_share WHERE resource_id=?";
|
|
|
|
|
sql = "delete from xpack_share where resource_id=?";
|
|
|
|
|
Db.use(DB_NAME).update(sql, id);
|
|
|
|
|
//(3) 删除可视化资源表
|
|
|
|
|
sql = "delete from core_opt_recent where resource_id=?";
|
|
|
|
@ -85,16 +82,16 @@ public class CopyBigScreen {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 拷贝大屏
|
|
|
|
|
* 拷贝城市大屏
|
|
|
|
|
*
|
|
|
|
|
* @param dataVisualizationName
|
|
|
|
|
* @param dataVisualizationNameCity
|
|
|
|
|
*/
|
|
|
|
|
public static void Copy(String dataVisualizationName) {
|
|
|
|
|
public static void copyCityScreen(String dataVisualizationNameCity) {
|
|
|
|
|
//清理掉旧的数据
|
|
|
|
|
clear(dataVisualizationName);
|
|
|
|
|
clearScreen(dataVisualizationNameCity);
|
|
|
|
|
//母屏信息
|
|
|
|
|
String sql = "select * from data_visualization_info where name =?";
|
|
|
|
|
Record motherRecord = Db.use(DataEaseModel.DB_NAME).findFirst(sql, dataVisualizationName);
|
|
|
|
|
Record motherRecord = Db.use(DataEaseModel.DB_NAME).findFirst(sql, dataVisualizationNameCity);
|
|
|
|
|
long motherId = motherRecord.getLong("id");//母屏ID
|
|
|
|
|
long pid = motherRecord.getLong("pid"); //隶属文件夹
|
|
|
|
|
//母屏共享链接
|
|
|
|
@ -103,7 +100,7 @@ public class CopyBigScreen {
|
|
|
|
|
|
|
|
|
|
//按16个市州进行生成
|
|
|
|
|
for (String cityName : dm.getCityNameList()) {
|
|
|
|
|
String screenName = dataVisualizationName + cityName;//要拷贝出来的屏幕名称
|
|
|
|
|
String screenName = dataVisualizationNameCity + cityName;//要拷贝出来的屏幕名称
|
|
|
|
|
//拷贝API
|
|
|
|
|
String url = urlPrefix + "/de2api/dataVisualization/copy";
|
|
|
|
|
JSONObject jo = new JSONObject();
|
|
|
|
@ -162,10 +159,63 @@ public class CopyBigScreen {
|
|
|
|
|
System.out.println("恭喜,所有操作成功完成!");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 拷贝省级大屏
|
|
|
|
|
*
|
|
|
|
|
* @param dataVisualizationProvince 省级大屏的名称
|
|
|
|
|
*/
|
|
|
|
|
public static long copyProvinceScreen(String dataVisualizationProvince) {
|
|
|
|
|
//清理掉旧的数据
|
|
|
|
|
clearScreen(dataVisualizationProvince);
|
|
|
|
|
//母屏信息
|
|
|
|
|
String sql = "select * from data_visualization_info where name =?";
|
|
|
|
|
Record motherRecord = Db.use(DataEaseModel.DB_NAME).findFirst(sql, dataVisualizationProvince);
|
|
|
|
|
long motherId = motherRecord.getLong("id");//母屏ID
|
|
|
|
|
long pid = motherRecord.getLong("pid"); //隶属文件夹
|
|
|
|
|
//母屏共享链接
|
|
|
|
|
sql = "select * from xpack_share where resource_id=?";
|
|
|
|
|
Record motherShareRecord = Db.use(DataEaseModel.DB_NAME).findFirst(sql, motherId);
|
|
|
|
|
|
|
|
|
|
String screenName = dataVisualizationProvince + "【黄海】";//要拷贝出来的屏幕名称
|
|
|
|
|
//拷贝API
|
|
|
|
|
String url = urlPrefix + "/de2api/dataVisualization/copy";
|
|
|
|
|
JSONObject jo = new JSONObject();
|
|
|
|
|
jo.put("nodeType", "leaf");
|
|
|
|
|
jo.put("name", screenName);
|
|
|
|
|
jo.put("type", "dataV");
|
|
|
|
|
jo.put("id", motherId);
|
|
|
|
|
jo.put("pid", pid);
|
|
|
|
|
String res = HttpUtil.createPost(url).contentType("application/json")
|
|
|
|
|
.header("x-de-token", getToken()).body(jo.toString()).execute().body();
|
|
|
|
|
long childId = Long.parseLong(JSONObject.parseObject(res).getString("data"));
|
|
|
|
|
|
|
|
|
|
//更新pid,没有这步的话,在界面上看不到拷贝出来的大屏!
|
|
|
|
|
sql = "update data_visualization_info set pid=? where id=?";
|
|
|
|
|
Db.use(DB_NAME).update(sql, pid, childId);
|
|
|
|
|
|
|
|
|
|
//发布共享链接
|
|
|
|
|
Record shareRecord = new Record().setColumns(motherShareRecord);
|
|
|
|
|
shareRecord.set("resource_id", childId);
|
|
|
|
|
shareRecord.set("id", CommonUtil.getSnowId());
|
|
|
|
|
shareRecord.set("uuid", CommonUtil.randomString(8));//大小写字母和数字组合,长度为8
|
|
|
|
|
Db.use(DataEaseModel.DB_NAME).save("xpack_share", "id", shareRecord);
|
|
|
|
|
System.out.println("恭喜,省级大屏拷贝完成!");
|
|
|
|
|
return motherId;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void main(String[] args) throws InterruptedException {
|
|
|
|
|
//连接本地数据库系统
|
|
|
|
|
LocalMysqlConnectUtil.Init();
|
|
|
|
|
//获取数据可视化名称
|
|
|
|
|
String dataVisualizationName = LocalMysqlConnectUtil.PropKit.get("dataEase.dataVisualizationName");
|
|
|
|
|
Copy(dataVisualizationName);
|
|
|
|
|
String dataVisualizationNameCity = LocalMysqlConnectUtil.PropKit.get("dataEase.dataVisualizationNameCity");
|
|
|
|
|
|
|
|
|
|
//获取数据可视化名称
|
|
|
|
|
String dataVisualizationProvince = LocalMysqlConnectUtil.PropKit.get("dataEase.dataVisualizationProvince");
|
|
|
|
|
|
|
|
|
|
//拷贝省级大屏
|
|
|
|
|
long provinceScreenId = copyProvinceScreen(dataVisualizationProvince);
|
|
|
|
|
|
|
|
|
|
//拷贝市州级大屏
|
|
|
|
|
copyCityScreen(dataVisualizationNameCity);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|