0

我正在尝试打印出设置为文件的行的内容,但我得到了 java.io.NotSerializableException:

这是我的程序..

package k564;

import java.io.*;
import javax.sql.RowSet;
import com.sun.rowset.JdbcRowSetImpl;

public class Lab15a {
public static void main(String[] args) {

    try{
    Class.forName("com.mysql.jdbc.Driver");
    RowSet rs= new JdbcRowSetImpl();
    rs.setUrl("jdbc:mysql://localhost:3306/jdbc");
    rs.setUsername("root");
    rs.setPassword("123");
    rs.setCommand("select cid,cname,cemail,cphone,camount from customer");
    rs.execute();

    while(rs.next()){
                System.out.println(rs.getInt("cid")+"\t"+rs.getString("cname")+"\t"+rs.getString("cemail")+"\t"+rs.getInt("cphone")+rs.getInt("camount"));          
    }

    rs.beforeFirst();
    System.out.println("Serialixzing Rowset");
    FileOutputStream fos = new FileOutputStream("d:\\rowset.txt");
    ObjectOutputStream oos = new ObjectOutputStream(fos);
    oos.writeObject(rs);
    System.out.println("serialized");
    }catch(Exception e){
        e.printStackTrace();
    }       
}

}

我得到的错误。

错误:

java.io.NotSerializableException: java.lang.Object
at java.io.ObjectOutputStream.writeObject0(Unknown Source)
at java.io.ObjectOutputStream.writeObject(Unknown Source)
at java.util.HashMap.writeObject(Unknown Source)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at java.io.ObjectStreamClass.invokeWriteObject(Unknown Source)
at java.io.ObjectOutputStream.writeSerialData(Unknown Source)
at java.io.ObjectOutputStream.writeOrdinaryObject(Unknown Source)
at java.io.ObjectOutputStream.writeObject0(Unknown Source)
at java.io.ObjectOutputStream.defaultWriteFields(Unknown Source)
at java.io.ObjectOutputStream.writeSerialData(Unknown Source)
at java.io.ObjectOutputStream.writeOrdinaryObject(Unknown Source)
at java.io.ObjectOutputStream.writeObject0(Unknown Source)
at java.io.ObjectOutputStream.defaultWriteFields(Unknown Source)
at java.io.ObjectOutputStream.writeSerialData(Unknown Source)
at java.io.ObjectOutputStream.writeOrdinaryObject(Unknown Source)
at java.io.ObjectOutputStream.writeObject0(Unknown Source)
at java.io.ObjectOutputStream.writeObject(Unknown Source)
at k564.Lab15a.main(Lab15a.java:33)

我无法弄清楚这里有什么问题?

4

2 回答 2

1

JavaObjectOuputStream只能序列化实现java.io.Serializable接口的对象。JdbcRowSet类没有实现这个接口。

要打印出内容,请尝试使用getRow()toString()或类似的东西来实现您的目标。

于 2014-04-24T11:40:21.123 回答
0

根据文档

断开连接的 RowSet 对象具有连接的 RowSet 对象的所有功能,此外它们还具有仅断开连接的 RowSet 对象可用的附加功能。例如,不必维护与数据源的连接使得断开连接的 RowSet 对象比 JdbcRowSet 对象或 ResultSet 对象轻得多。断开连接的 RowSet 对象也是可序列化的,可序列化和轻量级的结合使它们成为通过网络发送数据的理想选择。

我建议根据文档使用CachedRowSetwhich 可能更适合序列化

您还可以考虑创建一个 Customer 类,该类使用诸如表示从数据库读取的值的Serializable字段来实现。cid,cname,cemail,cphone,camount然后使用每个字段的设置器将结果集的值映射到列的值,然后您可以将Customer类序列化到输出文件。

注意:如果你想序列化一个Object,该类必须实现Serializable,强烈建议你也添加一个serialVersionUID来表示版本号

于 2014-04-24T11:43:48.247 回答