View Full Version : [JAVA] Inserire intere classi in un DBMS
Salve ragazzi, ho la necessità di memorizzare un' intera classe in un database mysql con JDBC.
Riesco a scriverla nel database con il metodo updateObject, ma quando vado a leggere mi lancia delle eccezioni di casting:
Io leggo così
Classx x = new Classx();
x= (Classx)resultset.getObject("nome");
Ho provato a maneggiare sia Blob che Bytes all'interno del DB, ma la lettura lancia sempre eccezioni.
Qualcuno ha una soluzione ? Sono disposto anche a cambiare DBMS purchè funzioni.
prova a nn castare l'oggetto restituito dal resultset...
poi prova a loggare quello che hai ricevuto...
Ex:
Object x = resultset.getObject("nome");
if (x != null) {
System.out.println(x.getClass().getName());
}
Vedi che istanza ti restituisce il rs... e facci sapere... :D
Grazie, ho risolto in questo modo:
byte[] serialized= rs.getBytes("test");
ObjectInputStream in = new ObjectInputStream( new ByteArrayInputStream( serialized ) );
TestBean tbean= new TestBean();
tbean = (TestBean)in.readObject();
Ora però ho un problema un pò più grosso:
tale classe che si occupa di prendere questo oggetto funziona se la uso come applicazione a se stante, ma se la uso in tomcat mi lancia la seguente eccezione:
---------------------------------------------------------------
javax.servlet.ServletException: TestBean
org.apache.jasper.runtime.PageContextImpl.doHandlePageException(PageContextImpl.java:848)
org.apache.jasper.runtime.PageContextImpl.handlePageException(PageContextImpl.java:781)
org.apache.jsp.elencatest_jsp._jspService(elencatest_jsp.java:95)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:97)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:322)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:291)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:241)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:362)
root cause
java.lang.ClassNotFoundException: TestBean
org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1332)
org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1181)
java.lang.ClassLoader.loadClassInternal(ClassLoader.java:319)
java.lang.Class.forName0(Native Method)
java.lang.Class.forName(Class.java:242)
java.io.ObjectInputStream.resolveClass(ObjectInputStream.java:584)
java.io.ObjectInputStream.readNonProxyDesc(ObjectInputStream.java:1543)
java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:1465)
java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1698)
java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1304)
java.io.ObjectInputStream.readObject(ObjectInputStream.java:349)
TestManagement.TestStorage.TestDB.getTest(TestDB.java:45)
TestManagement.TestStorage.TestStorage.getTestById(TestStorage.java:25)
org.apache.jsp.elencatest_jsp._jspService(elencatest_jsp.java:68)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:97)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:322)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:291)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:241)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:362)
--------------------------------------------------------------------------
In pratica è come se non trovasse la classe TestBean (classe x dell'esempio precedente) anche se è presente e raggiungibile.
Ho trovato la riga dove mi lancia l'eccezione:
byte[] serialized= rs.getBytes("test");
ObjectInputStream in = new ObjectInputStream( new ByteArrayInputStream( serialized ) );
testbean = (TestBean) in.readObject();
in.close();
La riga sottolineta lancia l'eccezione ClassNotFoundException e si riferisce alla classe TestBean. Il problema è che questo accade in tomcat, se porto tutto su di un applicazione standard funziona tutto. Ci deve essere qualche meccanismo di tomcat per la deserializzazione che non conosco. Chi può darmi una mano ? Premetto che sto usando NetBeans IDE 5.0 per lo sviluppo e che quindi configura tutto in automatico.
vBulletin® v3.6.4, Copyright ©2000-2025, Jelsoft Enterprises Ltd.