rs.next()为false导致resultset遍历不出数据
2017-03-10 20:34
363 查看
网上查找到的时数据库字符集错误,
我的原因是通过ResultsetMetaData 可以取到表字段跟字段种类
,证明连接成功,但是 数据却是空的,
像我的错误出在使用pl/sql编辑数据进行测试时没有提交事务处理,没有插入成功,
获取方法reseultset各字段: http://blog.csdn.net/sun2445067/article/details/6492166
public ResultSet Search() ...{
ResultSet rset = null;
sqlStr = "SELECT * FROM STUDENTINF ";
Statement smt = null;
try ...{
smt = conn.createStatement();
rset = smt.executeQuery(sqlStr);
}
catch (SQLException ex) ...{
System.out.println("Exception:" + ex.toString());
}
return rset;
}
public void getResultSetMetaData()...{
ResultSet rs = null;
try ...{
String[] tp = ...{"TABLE"};
rs = this.Search();
ResultSetMetaData rsmd = rs.getMetaData();
/**//*
获得ResultSetMeataData对象。所有方法的参数都是列的索引号,即第几列,从1开始
*/
System.out.println("下面这些方法是ResultSetMetaData中方法");
System.out.println("获得1列所在的Catalog名字 : " + rsmd.getCatalogName(1));
System.out.println("获得1列对应数据类型的类 " + rsmd.getColumnClassName(1));
System.out.println("获得该ResultSet所有列的数目 " + rsmd.getColumnCount());
System.out.println("1列在数据库中类型的最大字符个数" + rsmd.getColumnDisplaySize(1));
System.out.println(" 1列的默认的列的标题" + rsmd.getColumnLabel(1));
System.out.println("1列的模式 " + rsmd.GetSchemaName(1));
System.out.println("1列的类型,返回SqlType中的编号 " + rsmd.getColumnType(1));
System.out.println("1列在数据库中的类型,返回类型全名" + rsmd.getColumnTypeName(1));
System.out.println("1列类型的精确度(类型的长度): " + rsmd.getPrecision(1));
System.out.println("1列小数点后的位数 " + rsmd.getScale(1));
System.out.println("1列对应的模式的名称(应该用于Oracle) " + rsmd.getSchemaName(1));
System.out.println("1列对应的表名 " + rsmd.getTableName(1));
System.out.println("1列是否自动递增" + rsmd.isAutoIncrement(1));
System.out.println("1列在数据库中是否为货币型" + rsmd.isCurrency(1));
System.out.println("1列是否为空" + rsmd.isNullable(1));
System.out.println("1列是否为只读 " + rsmd.isReadOnly(1));
System.out.println("1列能否出现在where中 " + rsmd.isSearchable(1));
}
catch (SQLException ex) ...{
ex.printStackTrace();
}
}
我的原因是通过ResultsetMetaData 可以取到表字段跟字段种类
,证明连接成功,但是 数据却是空的,
像我的错误出在使用pl/sql编辑数据进行测试时没有提交事务处理,没有插入成功,
获取方法reseultset各字段: http://blog.csdn.net/sun2445067/article/details/6492166
public ResultSet Search() ...{
ResultSet rset = null;
sqlStr = "SELECT * FROM STUDENTINF ";
Statement smt = null;
try ...{
smt = conn.createStatement();
rset = smt.executeQuery(sqlStr);
}
catch (SQLException ex) ...{
System.out.println("Exception:" + ex.toString());
}
return rset;
}
public void getResultSetMetaData()...{
ResultSet rs = null;
try ...{
String[] tp = ...{"TABLE"};
rs = this.Search();
ResultSetMetaData rsmd = rs.getMetaData();
/**//*
获得ResultSetMeataData对象。所有方法的参数都是列的索引号,即第几列,从1开始
*/
System.out.println("下面这些方法是ResultSetMetaData中方法");
System.out.println("获得1列所在的Catalog名字 : " + rsmd.getCatalogName(1));
System.out.println("获得1列对应数据类型的类 " + rsmd.getColumnClassName(1));
System.out.println("获得该ResultSet所有列的数目 " + rsmd.getColumnCount());
System.out.println("1列在数据库中类型的最大字符个数" + rsmd.getColumnDisplaySize(1));
System.out.println(" 1列的默认的列的标题" + rsmd.getColumnLabel(1));
System.out.println("1列的模式 " + rsmd.GetSchemaName(1));
System.out.println("1列的类型,返回SqlType中的编号 " + rsmd.getColumnType(1));
System.out.println("1列在数据库中的类型,返回类型全名" + rsmd.getColumnTypeName(1));
System.out.println("1列类型的精确度(类型的长度): " + rsmd.getPrecision(1));
System.out.println("1列小数点后的位数 " + rsmd.getScale(1));
System.out.println("1列对应的模式的名称(应该用于Oracle) " + rsmd.getSchemaName(1));
System.out.println("1列对应的表名 " + rsmd.getTableName(1));
System.out.println("1列是否自动递增" + rsmd.isAutoIncrement(1));
System.out.println("1列在数据库中是否为货币型" + rsmd.isCurrency(1));
System.out.println("1列是否为空" + rsmd.isNullable(1));
System.out.println("1列是否为只读 " + rsmd.isReadOnly(1));
System.out.println("1列能否出现在where中 " + rsmd.isSearchable(1));
}
catch (SQLException ex) ...{
ex.printStackTrace();
}
}
相关文章推荐
- java中登录查询条件为中文时,rs.next为false,导致无法登录
- JSP 遍历ResultSet中的数据并转化为表格
- java中ResultSet遍历数据
- setAutoCommit(false)导致读不到数据
- JSP 遍历ResultSet中的数据并转化为表格
- oracle JDBC 查询 rs.next()总报false
- rs.next false问题
- mysql的sql查询语句含有中文,rs.next()就false的解决办法
- java中sql查询条件为中文时,rs.next为false,查询不到结果的解决办法
- ResultSet遍历过程中修改自身数据,不会改变循环的过程
- rs.next()为false
- 遍历数组修改数据导致的错误
- ResultSet中做if判断时next()两次取不到第一条数据的问题
- ResultSet中做if判断时next()两次取不到第一条数据的问题
- ResultSet.next()一直是false
- 遍历dataGrid行更新数据
- 遍历替换整个数据库中所有用户表的字段中的数据
- VBScript 遍历表单元素, 简化数据操作代码
- 数据库中取出数据用什么算法遍历它的子节点
- 关于JDBC中的ResultSet的更新数据操作