java.sql.SQLException: No data found

2024-09-08 03:18

本文主要是介绍java.sql.SQLException: No data found,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Java代码如下:

package com.accord.utils;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;import com.accord.entity.Corp;/*** @author 王久印* 2018年4月9日* 读取.ini配置文件工具类*/
public class ReadMdbUtil {private static List<Corp> CORPLISTS = new ArrayList<Corp>() ;static{//List<Corp> corpLists = new ArrayList<Corp>();Properties prop = new Properties();prop.put("charSet", "gb2312"); // 这里是解决中文乱码prop.put("user", "ufsoft");prop.put("password", "test0011");String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=src/main/resources/system.mdb"; // 文件地址PreparedStatement ps = null;Statement stmt = null;ResultSet rs = null;try {Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");Connection conn = DriverManager.getConnection(url, prop);stmt = (Statement) conn.createStatement();rs = stmt.executeQuery("select * from t_corp");ResultSetMetaData data = rs.getMetaData();//private static List<Corp> CORPLISTS ;while (rs.next()) {Corp corp = new Corp();System.out.println("---开始---");corp.setId(rs.getString("id"));//System.out.println(rs.getString("id"));corp.setFcorp(rs.getString("FCORP"));//System.out.println(rs.getString("FCORP"));corp.setFgsbm(rs.getString("FGSBM"));//System.out.println(rs.getString("FGSBM"));corp.setFgsmc(rs.getString("FGSMC"));//System.out.println(rs.getString("FGSMC"));corp.setFismerge(rs.getString("FISMERGE"));//System.out.println(rs.getString("FISMERGE"));corp.setFsid(rs.getString("FSID"));//System.out.println(rs.getString("FSID"));corp.setFuser(rs.getString("FUSER"));//System.out.println(rs.getString("FUSER"));corp.setFpwd(rs.getString("FPWD"));//System.out.println(rs.getString("FPWD"));corp.setFbilltype(rs.getString("FBILLTYPE"));//System.out.println(rs.getString("FBILLTYPE"));corp.setFprocedure(rs.getString("FPROCEDURE"));//System.out.println(rs.getString("FPROCEDURE"));corp.setFip(rs.getString("FIP"));//System.out.println(rs.getString("FIP"));corp.setFimpcust(rs.getString("FIMPCUST"));//System.out.println(rs.getString("FIMPCUST"));corp.setFimpemp(rs.getString("FIMPEMP"));//System.out.println(rs.getString("FIMPEMP"));corp.setFimppz(rs.getString("FIMPPZ"));System.out.println("凭证:" + rs.getString("FIMPPZ"));//System.out.println(rs.getString("FIMPPZ"));System.out.println("--结束---");CORPLISTS.add(corp);//CORPLISTS.add(corp);/*Map map = new HashMap();for (int i = 1; i <= data.getColumnCount(); i++) {String columnName = data.getColumnName(i); // 列名String columnValue = rs.getString(i);map.put(columnName, columnValue);System.out.println(columnName + "---" + columnValue);}*///maplist.add(map);}} catch (Exception e) {e.printStackTrace();}//System.out.println("maplist的大小:" + maplist.size());/*for (Map map : maplist) {System.out.println("公司名称:" + map.get("FGSMC"));}*/}/*public List<Corp> getCorpLists() {List<Corp> corps = new ArrayList<Corp>();Properties prop = new Properties();prop.put("charSet", "gb2312"); // 这里是解决中文乱码prop.put("user", "ufsoft");prop.put("password", "test0011");String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=src/main/resources/system.mdb"; // 文件地址PreparedStatement ps = null;Statement stmt = null;ResultSet rs = null;try {Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");Connection conn = DriverManager.getConnection(url, prop);stmt = (Statement) conn.createStatement();rs = stmt.executeQuery("select * from t_corp");ResultSetMetaData data = rs.getMetaData();//private static List<Corp> CORPLISTS ;while (rs.next()) {Corp corp = new Corp();System.out.println("---开始---");//String id = rs.getString("id");corp.setId(rs.getString("id"));//System.out.println(id);System.out.println("--结束---");//CORPLISTS.add(corp);}}catch(Exception e){e.printStackTrace();}return null;}*/public static void main(String[] args) {for (Corp corp : CORPLISTS) {System.out.println(corp.getId() + corp.getFcorp() + corp.getFgsbm() + corp.getFgsmc() + corp.getFismerge() + corp.getFsid() + corp.getFuser() + corp.getFpwd() + corp.getFbilltype() + corp.getFprocedure() + corp.getFip() + corp.getFimpcust()+ corp.getFimpemp() + corp.getFimppz());//System.out.println(corp.getId());}}
}
报错如下:

---开始---
java.sql.SQLException: No data foundat sun.jdbc.odbc.JdbcOdbc.standardError(JdbcOdbc.java:7137)at sun.jdbc.odbc.JdbcOdbc.SQLGetDataString(JdbcOdbc.java:3906)at sun.jdbc.odbc.JdbcOdbcResultSet.getDataString(JdbcOdbcResultSet.java:5697)at sun.jdbc.odbc.JdbcOdbcResultSet.getString(JdbcOdbcResultSet.java:353)at sun.jdbc.odbc.JdbcOdbcResultSet.getString(JdbcOdbcResultSet.java:410)at com.accord.utils.ReadMdbUtil.<clinit>(ReadMdbUtil.java:72)
解决问题如下:

access不能在一个字段上连续多次调用 rs.getString("字段名"),你需要先定义一个变量保存 

corp.setFimppz(rs.getString("FIMPPZ"));
System.out.println("凭证:" + rs.getString("FIMPPZ"));

如上面的代码,rs.getString("FIMPPZ")被使用两次,这是不可以的,如果想要重复使用数据库的结果,需要将结果赋值给中间变量。

另外:

This is a typical error when using the MS Access database through the poor JDBC-ODBC bridge driver and retrieving the same data more than once from the result set. You need to retrieve the data once and assign it to a variable and use the variable multiple times instead.

while (rs.next()) {
    String flatNo = rs.getString("Flat_No");
    buffer += "<option value='" + flatNo + "'>" + flatNo + "</option>";   
}



这篇关于java.sql.SQLException: No data found的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1146963

相关文章

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名