使用easyexcel导出的时候,发现一直提示这个异常
javaorg.apache.poi.ss.usermodel.Cell.setCellValue(Ljava/time/LocalDateTime;)V
但是我在实体类里并没有对时间属性使用easyexcel的导出注解
1.使用@ExcelIgnore注解注释时间类型,这样导致的问题就是不能直接导出时间类型,如果还想导出时间就要加个字段转成字符串类型导出,比较麻烦
2.自定义转换类,实现对时间类型的转换
javaimport com.alibaba.excel.converters.Converter;
import com.alibaba.excel.enums.CellDataTypeEnum;
import com.alibaba.excel.metadata.GlobalConfiguration;
import com.alibaba.excel.metadata.data.WriteCellData;
import com.alibaba.excel.metadata.property.ExcelContentProperty;
import com.alibaba.excel.util.DateUtils;
import java.util.Date;
/**
* 解决 EasyExcel 日期类型 Date 转换的问题
*/
public class DateConverter implements Converter<Date> {
private static final String formatDate = "yyyy-MM-dd HH:mm:ss";
@Override
public Class<?> supportJavaTypeKey() {
return Converter.super.supportJavaTypeKey();
}
@Override
public CellDataTypeEnum supportExcelTypeKey() {
return Converter.super.supportExcelTypeKey();
}
@Override
public WriteCellData<?> convertToExcelData(Date value, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) throws Exception {
return new WriteCellData<>(DateUtils.format(value,formatDate));
}
}
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>