Error attempting to get column ‘xxx‘ from result set. Cause: java.sql.SQLDataException错误的解决方法

文章目录

  • [1. 复现错误](#1. 复现错误)
  • [2. 分析错误](#2. 分析错误)
  • [3. 解决错误](#3. 解决错误)
  • [4. 文末总结](#4. 文末总结)

1. 复现错误

今天写好导入hive表的详情列表的接口,如下代码所示:

java 复制代码
  /**
   * hive表导入的回调接口
   *
   * @author super先生
   * @datetime 2023/3/20:16:32
   * @return
   */
  @ResponseBody
  @GetMapping(value = "/xxx/importTables/detail")
  public ServiceStatusData localHiveImportTablesDetail(
          @RequestParam("datasetId") Long datasetId) {
    logger.info("mock数据的入参记录:datasetId={}", datasetId);
    if (null == datasetId) {
      return new ServiceStatusData(ServiceStatusData.Status.Fail, "入参错误:缺少任务id", null);
    }
    return hiveImportTaskService.localHiveImportTablesDetail(datasetId);
  }

启动postman访问该接口,确报出如下错误:

Error attempting to get column 'missionId' from result set. Cause: java.sql.SQLDataException: Cannot determine value type from string 'missionMockId'\n; SQL []; Cannot determine value type from string 'missionMockId'; nested exception is java.sql.SQLDataException: Cannot determine value type from string 'missionMockId'

2. 分析错误

根据java.sql.SQLDataException可知,这是sql数据的错误异常。

其次,再将错误信息Error attempting to get column 'missionId' from result set,翻译成中文是尝试从结果集中获取列"missionId"时出错

为什么尝试从结果集中获取列"missionId"时出错呢?继续分析错误信息。

接着将错误信息Cannot determine value type from string 'missionMockId',翻译成中文是无法从字符串"missionMockId"确定值类型

为什么无法确定missionMockId值类型呢?在Navicat中执行hiveImportTaskMapper.xml中的sql语句,如下代码所示:

sql 复制代码
<select id="listByDatasetId" parameterType="java.lang.Long" resultType="com.xxx.HiveTableDetailVo">
 SELECT
	hit.id AS id,
	du.user_name AS username,
	hit.user_id AS userId,
	hit.dataset_id AS datasetId,
	hit.mission_id AS missionId,
	hit.mission_state AS missionState,
	date_format( hit.create_time, '%Y-%m-%d %H:%I:%s' ) AS createTime,
	date_format( hit.call_back_time, '%Y-%m-%d %H:%I:%s' ) AS callbackTime,
	hit.import_result AS remark
 FROM
	hive_import_task hit
	LEFT JOIN `user` du ON du.user_id = hit.user_id
 WHERE
	dataset_id = #{datasetId}
 order by hit.create_time desc
    </select>

将上述代码中的#{datasetId}替换成实际值2后,执行结果如下图所示:

从上图中,可以很清楚地看到missionId的值为missionMockId,这是字符串类型的。

接着分析hiveImportTaskMapper.xml中的select标签中的返回类型(resultType),即是HiveTableDetailVo类:

HiveTableDetailVo代码如下所示:

java 复制代码
/**
* @author super先生
* @datetime 2023/3/23 14:21
* @desc 导入hive表的详情列表
*/
@AllArgsConstructor
@NoArgsConstructor
@Data
public class HiveTableDetailVo {
	 private Long id;
	 private String username;
	 private Long userId;
	 private Long datasetId;
	 private Long missionId;
	 private String missionState;
	 private String createTime;
	 private String callbackTime;
	 private String remark;
}

HiveTableDetailVo类中,可以清晰地看到missionId的类型是Long,而mysql查询出的missionId值为missionMockId,即字符串类型。

总结错误原因为:HiveTableDetailVo类中定义missionId的类型和mysql查询出的missionId值类型不一致,故而sql报出无法确定missionId值类型。

3. 解决错误

既然HiveTableDetailVo类中定义missionId的类型和mysql查询出的missionId值类型不一致,那就修改?HiveTableDetailVo类中定义missionId的类型为String,如下代码所示:

java 复制代码
/**
* @author super先生
* @datetime 2023/3/23 14:21
* @desc 导入hive表的详情列表
*/
@AllArgsConstructor
@NoArgsConstructor
@Data
public class HiveTableDetailVo {
	 private Long id;
	 private String username;
	 private Long userId;
	 private Long datasetId;
	 private String missionId;
	 private String missionState;
	 private String createTime;
	 private String callbackTime;
	 private String remark;
}

重新启动项目,再次使用postman测试,方可成功运行,如下图所示:

4. 文末总结

通过Error attempting to get column 'missionId' from result set. Cause: java.sql.SQLDataException: Cannot determine value type from string 'missionMockId'错误的分析与解决可知,一般报出类似错误的原因如下:

实体类的属性类型同mysql查询出来的值类型不一致导致的。

解决方法就是修改实体类的属性类型,来适配mysql查询出来的值类型。

相关推荐
q90854470311 分钟前
MySQL 二进制日志binlog解析
mysql·binlog·binlog2sql·my2sql
重庆小透明25 分钟前
力扣刷题记录【1】146.LRU缓存
java·后端·学习·算法·leetcode·缓存
lang2015092831 分钟前
Reactor操作符的共享与复用
java
TTc_41 分钟前
@Transactional事务注解的批量回滚机制
java·事务
博观而约取1 小时前
Django 数据迁移全解析:makemigrations & migrate 常见错误与解决方案
后端·python·django
码不停蹄的玄黓1 小时前
MySQL分布式ID冲突详解:场景、原因与解决方案
数据库·分布式·mysql·id冲突
wei_shuo2 小时前
飞算 JavaAI 开发助手:深度学习驱动下的 Java 全链路智能开发新范式
java·开发语言·飞算javaai
寻月隐君2 小时前
Rust 异步编程实践:从 Tokio 基础到阻塞任务处理模式
后端·rust·github
GO兔2 小时前
开篇:GORM入门——Go语言的ORM王者
开发语言·后端·golang·go
Sincerelyplz2 小时前
【Temproal】快速了解Temproal的核心概念以及使用
笔记·后端·开源