MyException - 我的异常网
当前位置:我的异常网» J2SE » 获取ResultSet类型有关问题

获取ResultSet类型有关问题

www.MyException.Cn  网友分享于:2013-03-22  浏览:71次
获取ResultSet类型问题
我从数据库中获取一行信息放入ResultSet(RS),并不清楚每一列的数据类型(有String,有Int,有Date),然后将其放入到JTable中,纵向展示(第一列放RS的列名称,第二列放列的数据),代码如下:
Java code

public void initInfo(String id) {
        MyCon mycon = null;
        Statement stmt = null;
        ResultSet rs = null;
        try {
            mycon = new MyCon();//此处自己写的打开数据库程序,运行OK
            stmt = mycon.con.createStatement();
            String querycommand = "SELECT * FROM Table WHERE ID='" + id + "'";
            rs = stmt.executeQuery(querycommand);
            ResultSetMetaData rsmd = rs.getMetaData();

            DefaultTableModel dataModel = new DefaultTableModel();
            Object[][] values = new Object[0][0];
            values = new Object[rsmd.getColumnCount()][2];

            for (int i = 1; i <= rsmd.getColumnCount(); i++) {
                //values[i] = new Object[2];
                values[i][0] = rsmd.getColumnName(i);
                System.out.println(rsmd.getColumnName(i));//此处OK
                values[i][1] = rs.getObject(rsmd.getColumnName(i));//运行到此处报错,错误代码如下
            }
            String header[] = {"基本信息", "内容"};
            dataModel.setDataVector(values, header);
            JTable table = new JTable(dataModel);
            JScrollPane pane = new JScrollPane(table);
            this.add(pane, BorderLayout.CENTER);

        } catch (Exception ex) {
            ex.printStackTrace();
        } finally {
            mycon.MyClose(mycon.con, stmt, rs);//自己写的一个关闭数据库程序,运行OK
        }
    }



错误如下:
java.sql.SQLException: [Microsoft][ODBC 驱动程序管理器] 无效的游标状态
at sun.jdbc.odbc.JdbcOdbc.createSQLException(JdbcOdbc.java:6957)
at sun.jdbc.odbc.JdbcOdbc.standardError(JdbcOdbc.java:7114)
at sun.jdbc.odbc.JdbcOdbc.SQLGetDataInteger(JdbcOdbc.java:3811)
at sun.jdbc.odbc.JdbcOdbcResultSet.getDataInteger(JdbcOdbcResultSet.java:5638)
at sun.jdbc.odbc.JdbcOdbcResultSet.getInt(JdbcOdbcResultSet.java:583)
at sun.jdbc.odbc.JdbcOdbcResultSet.getObject(JdbcOdbcResultSet.java:1693)


有哪位能帮我调试一下,赶紧不尽。。。

------解决方案--------------------
你用的数据源是用ODBC桥搭建的?
你用这个ODBC桥搭建,那么查询元数据的信息就无法获得或者不完整,所以ResultSetMetaData rsmd的很多API可能无法调用,解决这个问题的办法就是换掉ODBC的连接方法,而用纯JDBC的连接,比如连接MySQL添加MySQL的JDBC驱动,这样ResultSetMetaData 的API绝大部分都支持了
------解决方案--------------------
对,你的数据源是Access,是桥接的方法——这个没办法了,没有纯JDBC的Access的驱动
要么你把数据全部迁移到MySQL这样的数据库
要么你就放弃使用ResultSetMetaData,必须要知道每一列的数据类型,
再牛一些的就是你自己写个ResultSetMetaData,但是这个不是很现实,程序可能不够健壮,楼主权衡下选择一种折中方案吧,反正现在这种方案是不行的
------解决方案--------------------
试试:
Java code

public JTable createTableFromSQL(Connection connection,String sql , Object[] name)throws Exception{
        Statement stmt = connection.createStatement(
            ResultSet.TYPE_SCROLL_INSENSITIVE,// 对滚动不敏感,结果集可滚来滚去
            ResultSet.CONCUR_READ_ONLY);// 只能够读取里边的内容,
        ResultSet rs = stmt.executeQuery(sql);//开始执行查询语句,结果存储在rs中
        rs.last();// 指到定位到最后一行
        int row = rs.getRow();// 获得总行数
        rs.beforeFirst();// 定位到开始
        ResultSetMetaData rsmd1 = rs.getMetaData();// 计算字段个数
        int col = rsmd1.getColumnCount(); // 计算字段个数
        Object a[][] = new Object[row][col];//确定表格存储数据的大小
        JTable jTable = new JTable(a, name);//建立表格
        for (int index = 0; rs.next(); index++)//使用查询返回的结果初始化表格
        for (int j = 0; j < col; j++)
            a[index][j] = rs.getString(j + 1);
    return jTable;
    }

------解决方案--------------------
不成功就改变数据库,或采取另外的展示方案

文章评论

 程序员的样子
程序员的样子
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
一个程序员的时间管理
一个程序员的时间管理
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
中美印日四国程序员比较
中美印日四国程序员比较
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
总结2014中国互联网十大段子
总结2014中国互联网十大段子
10个调试和排错的小建议
10个调试和排错的小建议
如何成为一名黑客
如何成为一名黑客
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
Java程序员必看电影
Java程序员必看电影
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
代码女神横空出世
代码女神横空出世
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
老程序员的下场
老程序员的下场
程序员必看的十大电影
程序员必看的十大电影
我的丈夫是个程序员
我的丈夫是个程序员
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
为什么程序员都是夜猫子
为什么程序员都是夜猫子
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
编程语言是女人
编程语言是女人
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
我是如何打败拖延症的
我是如何打败拖延症的
每天工作4小时的程序员
每天工作4小时的程序员
旅行,写作,编程
旅行,写作,编程
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
程序员应该关注的一些事儿
程序员应该关注的一些事儿
程序员的鄙视链
程序员的鄙视链
那些争议最大的编程观点
那些争议最大的编程观点
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
漫画:程序员的工作
漫画:程序员的工作
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有