SpringBatch启动批量报错

博客内容涉及SpringBatch在处理数据时遇到的Jackson序列化异常,具体表现为InvalidTypeIdException,由于旧版本Jackson反序列化旧数据缺少@class属性。解决方法是手动为旧数据添加@class字段,详细步骤包括五个步骤,涉及查询JOB_INSTANCE_ID、JOB_EXECUTION_ID和STEP_EXECUTION_ID并进行替换操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

异常信息如下:

com.fasterxml.jackson.databind.exc.InvalidTypeIdException:Missing type id when trying to resolve subtype of [map type;class java.util.HashMap,[simple type,class java.lang.String]->[simple type,class java.lang.Object]]:missing type id property ‘@class’

 原因是:jackjon 老版本序列化的时候,没有加上”@class”:”java.util.HashMap”,新版本的jackjon再对之前的老数据进行反序列化的时候,发现缺少@class,因此报上面的异常。

 解决思路:在原先的数据上面加上@class

修数步骤如下:

具体步骤如下:

第一步:获取MAX(t.JOB_INSTANCE_ID)

SELECT MAX(t.JOB_INSTANCE_ID) FROM BATCH_JOB_INSTANCE t WHERE t.JOB_NAME = '批量名称';

第二步:MAX(t.JOB_INSTANCE_ID)替换?,获取JOB_EXECUTION_ID

SELECT t.JOB_EXECUTION_ID FROM BATCH_JOB_EXECUTION t WHERE t.JOB_INSTANCE_ID = '?';

第三步:JOB_EXECUTION_ID替换?

UPDATE BATCH_JOB_EXECUTION_CONTEXT t SET t.SHORT_CONTEXT = '{"@class":"java.util.HashMap"}' WHERE t.JOB_EXECUTION_ID = '?';

第四步:JOB_EXECUTION_ID替换?   获取多个 STEP_EXECUTION_ID

SELECT t.STEP_EXECUTION_ID FROM BATCH_STEP_EXECUTION t WHERE t.JOB_EXECUTION_ID = '?';

第五步:将多个 STEP_EXECUTION_ID替换?

Oracle:

UPDATE BATCH_STEP_EXECUTION_CONTEXT SET t.SHORT_CONTEXT = json_mergepatch('{"@class":"java.util.HashMap"}',t.SHORT_CONTEXT)

WHERE t.STEP_EXECUTION_ID IN ('?', '?');

Mysql:

UPDATE BATCH_STEP_EXECUTION_CONTEXT SET t.SHORT_CONTEXT = json_merge_patch('{"@class":"java.util.HashMap"}',t.SHORT_CONTEXT)

WHERE t.STEP_EXECUTION_ID IN ('?', '?');

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值