SQLMERGE INTO rec_search_solution_field e1
USING (SELECT field_id, order_no
FROM rec_search_solution_field
WHERE solution_id =
'2023062616531652c6e468'
AND order_no IS NOT NULL) e2
ON (e1.field_id = e2.field_id)
WHEN MATCHED THEN
UPDATE
SET e1.order_no = e2.order_no
WHERE e1.solution_id in
('2023071916160381771c2e',
'20230724150725f378cd5f')
update子项的时候,使用in的方式会导致,只有一个子项会更新,其他子项还是原来的,因为 如果rec_search_solution_field表中有多个具有相同field_id的记录,那么这个MERGE语句将只更新第一个匹配的记录。如果需要更新所有匹配的记录,可以考虑使用其他方法,如循环或游标。
JSON Web Token (JWT)是一个开放标准(RFC 7519),它定义了一种紧凑的、自包含的方式,用于作为JSON对象在各方之间安全地传输信息。该信息可以被验证和信任,因为它是数字签名的。
JWT token的格式:header.payload.signature
header中用于存放签名的生成算法
{"alg": "HS512"}
payload中用于存放用户名、token的生成时间和过期时间
{"sub":"admin","created":1489079981393,"exp":1489684781}
signature为以header和payload生成的签名,一旦header和payload被篡改,验证将失败
java//secret为加密算法的密钥
String signature = HMACSHA512(base64UrlEncode(header) + "." +base64UrlEncode(payload),secret)
这是一个JWT的字符串
eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJhZG1pbiIsImNyZWF0ZWQiOjE1NTY3NzkxMjUzMDksImV4cCI6MTU1NzM4MzkyNX0.d-iki0193X0bBOETf2UN3r3PotNIEAV7mzIxxeI5IxFyzzkOZxS0PGfF_SK6wxCv2K8S0cZjMkv6b5bCqc0VBw
可以在该网站上获得解析结果:https://jwt.io/
Flyway是一款数据库迁移(migration)工具。简单点说,就是在部署应用的时候,帮你执行数据库脚本的工具。Flyway支持SQL和Java两种类型的脚本,你可以将脚本打包到应用程序中,在应用程序启动时,由Flyway来管理这些脚本的执行,这些脚本被Flyway称之为migration。
xml<!-- flyway数据库版本迁移-->
<dependency>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
<version>7.15.0</version>
</dependency>
由于业务要求使用easyexcel无对象导出的方式,通过sql获取list<string,object>数据,同时列名还需要用字段名转成中文,导致for循环比较多,因为单线程执行,数据量又是几千条,每一行的数据又是七八百列,导致效率非常慢
通过拆分list,将list拆成多段后,使用线程池,每个线程执行一个任务,最后把结果合并起来
问题比较多,也没对异常做很好的处理
java
public void exportSqlScriptExcuteResultExcel(HttpServletResponse response, RecSearchSolutionSqlScriptExcuteResultRequest request) {
request.setType(1);
IPage<Map<String, Object>> iPage = this.getSqlScriptExcuteResult(request);
List<Map<String,Object>> dataMaplist= iPage.getRecords();
//查询当前方案的已选字段
RecSearchSolutionFieldRequest fieldRequest=new RecSearchSolutionFieldRequest();
fieldRequest.setSolutionId(request.getSolutionId());
List<RecSearchSolutionFieldEntity> recSearchSolutionFieldList=iRecSearchSolutionFieldService.getRecSearchSolutionFieldMapByIsDisplay(fieldRequest);
Map<String, String> recSearchSolutionFieldMap = recSearchSolutionFieldList.stream().collect(Collectors.toMap(arr -> arr.getField(), arr -> arr.getText(), (v1, v2) -> null, LinkedHashMap::new));
recSearchSolutionFieldMap.values().removeIf(Objects::isNull);
//列名的集合
List<List<String>> headList = new ArrayList<>();
//每行数据的集合
List<List<Object>> dataList = new ArrayList<>();
//是否为首次 0为首次
int i = 0;
try {
for (Map<String, Object> map : dataMaplist) {
List<Object> data = new ArrayList<>();
List<String>[] head = new List[]{null};
for (Map.Entry<String, Object> m : map.entrySet()) {
if (recSearchSolutionFieldMap!=null){
if (!recSearchSolutionFieldMap.containsKey(m.getKey())){
continue;
}
}
if (m.getValue() instanceof Date){
data.add(DateUtil.format((Date) m.getValue(),"yyyy-MM-dd HH:ss:mm"));
}else {
data.add(m.getValue());
}
//首次遍历就进入
if (i == 0) {
int headNum = 0;
head[headNum] = new ArrayList<>();
String text=recSearchSolutionFieldMap.get(m.getKey());
if(StrUtil.isBlank(text)){
head[headNum].add(m.getKey());
}else{
head[headNum].add(text);
}
headList.add(head[headNum]);
headNum++;
}
}
i++;
dataList.add(data);
}
String nowDate = DateUtil.format(new Date(),"yyyy_MM_dd_HH_mm_ss");
String fileName = "综合查询导出_" + nowDate;
response.setCharacterEncoding("utf-8");
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
response.setHeader("Content-disposition", "attachment;filename=" + URLEncoder.encode(fileName + ".xlsx", "utf-8"));
WriteCellStyle headWriteCellStyle = new WriteCellStyle();
WriteFont headWriteFont = new WriteFont();
headWriteFont.setFontHeightInPoints((short)10);
headWriteCellStyle.setWriteFont(headWriteFont);
HorizontalCellStyleStrategy horizontalCellStyleStrategy=new HorizontalCellStyleStrategy();
horizontalCellStyleStrategy.setHeadWriteCellStyle(headWriteCellStyle);
EasyExcel.write(response.getOutputStream()).registerWriteHandler(horizontalCellStyleStrategy).head(headList).autoCloseStream(Boolean.FALSE).sheet("sheet").doWrite(dataList);
} catch (IOException e) {
throw new BusinessException(ResultCodeEnum.ERR_0x1000);
}
}