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

相关文章

MySQL 衍生表(Derived Tables)的使用

《MySQL衍生表(DerivedTables)的使用》本文主要介绍了MySQL衍生表(DerivedTables)的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录一、衍生表简介1.1 衍生表基本用法1.2 自定义列名1.3 衍生表的局限在SQL的查询语句select

MySQL 横向衍生表(Lateral Derived Tables)的实现

《MySQL横向衍生表(LateralDerivedTables)的实现》横向衍生表适用于在需要通过子查询获取中间结果集的场景,相对于普通衍生表,横向衍生表可以引用在其之前出现过的表名,本文就来... 目录一、横向衍生表用法示例1.1 用法示例1.2 使用建议前面我们介绍过mysql中的衍生表(From子句

六个案例搞懂mysql间隙锁

《六个案例搞懂mysql间隙锁》MySQL中的间隙是指索引中两个索引键之间的空间,间隙锁用于防止范围查询期间的幻读,本文主要介绍了六个案例搞懂mysql间隙锁,具有一定的参考价值,感兴趣的可以了解一下... 目录概念解释间隙锁详解间隙锁触发条件间隙锁加锁规则案例演示案例一:唯一索引等值锁定存在的数据案例二:

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。

MYSQL查询结果实现发送给客户端

《MYSQL查询结果实现发送给客户端》:本文主要介绍MYSQL查询结果实现发送给客户端方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql取数据和发数据的流程(边读边发)Sending to clientSending DataLRU(Least Rec

MySQL分区表的具体使用

《MySQL分区表的具体使用》MySQL分区表通过规则将数据分至不同物理存储,提升管理与查询效率,本文主要介绍了MySQL分区表的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、分区的类型1. Range partition(范围分区)2. List partition(列表分区)3. H

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig

Java SWT库详解与安装指南(最新推荐)

《JavaSWT库详解与安装指南(最新推荐)》:本文主要介绍JavaSWT库详解与安装指南,在本章中,我们介绍了如何下载、安装SWTJAR包,并详述了在Eclipse以及命令行环境中配置Java... 目录1. Java SWT类库概述2. SWT与AWT和Swing的区别2.1 历史背景与设计理念2.1.