|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Member
Iscritto dal: Apr 2005
Messaggi: 87
|
[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. |
![]() |
![]() |
![]() |
#2 |
Junior Member
Iscritto dal: Apr 2002
Messaggi: 10
|
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... ![]() |
![]() |
![]() |
![]() |
#3 |
Member
Iscritto dal: Apr 2005
Messaggi: 87
|
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. Ultima modifica di ademar : 28-06-2006 alle 17:26. |
![]() |
![]() |
![]() |
#4 |
Member
Iscritto dal: Apr 2005
Messaggi: 87
|
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. |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 11:57.