Vista combinada Visión Plana Vista de árbol
Discusiones [ Anterior | Siguiente ]
toggle
Sanjeev Kumar
java.lang.ClassCastException: org.hibernate.dialect.MySQLDialect cannot be
26 de febrero de 2013 22:19
Respuesta

Sanjeev Kumar

Ranking: New Member

Mensajes: 6

Fecha de incorporación: 26 de febrero de 2013

Mensajes recientes

Hi everyone,
I am using Liferay CE 6.1, tomcat 7.
I am developing custom portlets in my liferay project.
I am connecting to external database MySQL.
I need to add hibernate3.jar to implement my custom API's in my portlet.
I tried adding the hibernate3.jar explicitly in my WEB-INF/lib folder and also tried adding through liferay-plugin-package.properties to include the dependency jar which liferay uses.
But I get the same error, saying org.hibernate.HibernateException: Could not instantiate dialect class

BeanLocator not set for servlet context,

java.lang.ClassCastException: org.hibernate.dialect.MySQLDialect cannot be cast to org.hibernate.dialect.Dialect.

org.hibernate.HibernateException: Could not instantiate dialect class.

Context initialization failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'liferayHibernateSessionFactory' defined in ServletContext resource [/WEB-INF/classes/META-INF/hibernate-spring.xml]: Invocation of init method failed; nested exception is org.hibernate.HibernateException: Could not instantiate dialect class.

I am not able to go forward until I get rid of this problem, please I need help, thanks in advance...
MICHAIL MOUDATSOS
RE: java.lang.ClassCastException: org.hibernate.dialect.MySQLDialect cannot
1 de marzo de 2013 5:58
Respuesta

MICHAIL MOUDATSOS

Ranking: Regular Member

Mensajes: 110

Fecha de incorporación: 4 de octubre de 2011

Mensajes recientes

I think ou should first mention what kind of frameworks you use, i.e. "Do you use plain Hibernate?", "Are you using Spring?". This will help people understand your situation better. E.g., for the plain hibernate case, I have tried that in the past and there was no problem. I just had to add hibernate and all of its dependencies to my lib folder (and of course initialize it properly emoticon).
David H Nebinger
RE: java.lang.ClassCastException: org.hibernate.dialect.MySQLDialect cannot
1 de marzo de 2013 6:24
Respuesta

David H Nebinger

Ranking: Liferay Legend

Mensajes: 7252

Fecha de incorporación: 1 de septiembre de 2006

Mensajes recientes

You're encountering class loader issues...

Basically you've got your own hibernate jar loaded in your class loader, but the liferayHibernateSessionFactory instance is defined in Liferay's class loader. In Liferay's class loader, it has already created the connection and established the dialect to use, in this case a MySQLDialect.

So you're trying to reuse the connection from their class loader in your own class loader and, of course, although both have a Dialect interface defined, they are completely different class and cannot be cast around.
Sanjeev Kumar
RE: java.lang.ClassCastException: org.hibernate.dialect.MySQLDialect cannot
6 de marzo de 2013 20:51
Respuesta

Sanjeev Kumar

Ranking: New Member

Mensajes: 6

Fecha de incorporación: 26 de febrero de 2013

Mensajes recientes

But the error occurs when the hibernate jar is added in lib folder, not while implementing the API's which are built on hibernate.
MICHAIL MOUDATSOS
RE: java.lang.ClassCastException: org.hibernate.dialect.MySQLDialect cannot
6 de marzo de 2013 21:03
Respuesta

MICHAIL MOUDATSOS

Ranking: Regular Member

Mensajes: 110

Fecha de incorporación: 4 de octubre de 2011

Mensajes recientes

Sanjeev Kumar:
But the error occurs when the hibernate jar is added in lib folder, not while implementing the API's which are built on hibernate.
So, you mean you haven't written a single line of code, not even a configuration file, anything?
Sanjeev Kumar
RE: java.lang.ClassCastException: org.hibernate.dialect.MySQLDialect cannot
7 de marzo de 2013 2:28
Respuesta

Sanjeev Kumar

Ranking: New Member

Mensajes: 6

Fecha de incorporación: 26 de febrero de 2013

Mensajes recientes

we are connecting to different (application) Database using hibernate.
We created API to connect to the other application database. The API is using hibernate to connect the other application.
Sahil Shaikh
RE: java.lang.ClassCastException: org.hibernate.dialect.MySQLDialect cannot
28 de mayo de 2014 2:52
Respuesta

Sahil Shaikh

Ranking: New Member

Mensajes: 1

Fecha de incorporación: 21 de mayo de 2014

Mensajes recientes

Does anyone one have any success with hibernate?
Di He
RE: java.lang.ClassCastException: org.hibernate.dialect.MySQLDialect cannot
19 de septiembre de 2014 16:40
Respuesta

Di He

Ranking: New Member

Mensajes: 13

Fecha de incorporación: 28 de enero de 2008

Mensajes recientes

I started a liferay6.2.2 service builder portlet by using the eclipselink 2.5.1 and JPA 2.1 to get data from external database, my service builder portlet also have tables created by service.xml. I tested the service builder portlet in my LR6.2.2 tomcat server and it works well.

I then deployed my service builder portlet on LR6.2.2 Glassfish 3 server, I got an error says it can't created the EntityManagerFactory from the persistence unit defined in persistence.xml. So I tried using hibernate JPA to replace the eclipselink, then I ran into the same issue you guys are talking about.

I think glassfish 3 server has older version of eclipselink installed. I am going to try to upgrade it to 2.5.1 and see my portlet will work or not.

If you are running liferay on tomcat, you could try what I did. Good luck.