用Java在数据库中存储对象



我正在尝试使用java语言将我的对象存储在MySQL数据库中。我正在尝试将对象转换为字节,以便将其存储到LONGBLOB中。但我面临错误,即"NotSerializable Exception"。

我想痛击的对象:

public class Books implements Serializable {
private int isbn;
private String bookName;
private String author;
private String edition;
private int rowNo;
private int colNo;
private String shelfNo;
private String img;
private InputStream imag;
validation v = new Validation();
Database database;
public Books() { database = new Database(); }
.
.
setters & getters...

调用数据库方法以在数据库中插入对象的方法:

String className = this.getClass().getName();
database.insertBookRecord(this.getIsbn(), this, className);  

this是我想要存储的当前类的对象。

以下是CCD_ 2方法。

    public void insertBookRecord(int isbn, Books book, String name) {
    String query = "INSERT INTO Test VALUES (?, ?, ?)";
    byte[] data = null;
    //book = new Books();
    try {
        ByteArrayOutputStream baos = new ByteArrayOutputStream();
        ObjectOutputStream oos = new ObjectOutputStream(baos);
        oos.writeObject(book);
        oos.flush();
        oos.close();
        baos.close();
        data = baos.toByteArray();
    }
    catch(IOException ex) {
        JOptionPane.showMessageDialog(null, ex.getMessage());
    }
    try {
        //conn.setAutoCommit(false);
        state = conn.prepareStatement(query);
        state.setInt(1, isbn);
        state.setString(2, name);
        state.setObject(3, data);
        state.executeUpdate();
        //conn.commit();
    }
    catch(SQLException ex) {
        JOptionPane.showMessageDialog(null, ex.getMessage());
    }
    finally {
        close(3);
    }
}

当我到达语句CCD_ 3时,它异常地停止并显示包&JOptionPane中的类名。

我的book对象具有我在文本字段中输入的所有数据字段。但我无法编写它。/将它转换为Serializable格式。

有什么建议吗?

堆栈跟踪:

java.io.NotSerializableException: com.my.classes.Database
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 com.my.classes.Database.insertBookRecord(Database.java:123)
at com.my.classes.Books.insertBookRecord(Books.java:107)
at com.my.jlms.ManageBooks$2.actionPerformed(ManageBooks.java:308)
at javax.swing.AbstractButton.fireActionPerformed(Unknown Source)
at javax.swing.AbstractButton$Handler.actionPerformed(Unknown Source)
at javax.swing.DefaultButtonModel.fireActionPerformed(Unknown Source)
at javax.swing.DefaultButtonModel.setPressed(Unknown Source)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(Unknown Source)
at java.awt.Component.processMouseEvent(Unknown Source)
at javax.swing.JComponent.processMouseEvent(Unknown Source)
at java.awt.Component.processEvent(Unknown Source)
at java.awt.Container.processEvent(Unknown Source)
at java.awt.Component.dispatchEventImpl(Unknown Source)
at java.awt.Container.dispatchEventImpl(Unknown Source)
at java.awt.Component.dispatchEvent(Unknown Source)
at java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source)
at java.awt.LightweightDispatcher.processMouseEvent(Unknown Source)
at java.awt.LightweightDispatcher.dispatchEvent(Unknown Source)
at java.awt.Container.dispatchEventImpl(Unknown Source)
at java.awt.Window.dispatchEventImpl(Unknown Source)
at java.awt.Component.dispatchEvent(Unknown Source)
at java.awt.EventQueue.dispatchEventImpl(Unknown Source)
at java.awt.EventQueue.access$500(Unknown Source)
at java.awt.EventQueue$3.run(Unknown Source)
at java.awt.EventQueue$3.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(Unknown Source)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(Unknown Source)
at java.awt.EventQueue$4.run(Unknown Source)
at java.awt.EventQueue$4.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(Unknown Source)
at java.awt.EventQueue.dispatchEvent(Unknown Source)
at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.run(Unknown Source)

您得到异常是因为您正在尝试序列化InputStream

private InputStream imag;

InputStream不是Serializable

序列化时可以通过声明transient:来省略此字段

private transient InputStream imag;

您的imag是InputStream,它不能实现Serializable。它应该是指向imag位置的byte[]或String链接。

Edited:您应该将业务与模型对象分离。将insertBook方法和数据库对象从Book类移动到另一个类。

所以问题是InputStream,因为我试图Seralize对象,即V&数据库我只是添加了transient,例如private transient Database database;,然后在构造函数中声明了database = new Database();。因此我能够序列化它。

感谢@Ralf、@Joseph、@Diyarbakir和@3kings帮助我。

相关内容

  • 没有找到相关文章

最新更新