estoy arrancando con java, hibernate y jpa...
tengo el siguiente error a ver si alguien me puede dar con alguna sugerencia, ya que no encuentro temas similares a este caso.
Código error por consola:
Ver original
ERROR: CLIENT_PLUGIN_AUTH is required Exception in thread "main" org.hibernate.service.spi.ServiceException: Unable to create requested service [org.hibernate.engine.jdbc.env.spi.JdbcEnvironment] at org.hibernate.service.internal.AbstractServiceRegistryImpl.createService(AbstractServiceRegistryImpl.java:275) at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:237) at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:214) at org.hibernate.id.factory.internal.DefaultIdentifierGeneratorFactory.injectServices(DefaultIdentifierGeneratorFactory.java:152) at org.hibernate.service.internal.AbstractServiceRegistryImpl.injectDependencies(AbstractServiceRegistryImpl.java:286) at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:243) at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:214) at org.hibernate.boot.internal.InFlightMetadataCollectorImpl.<init>(InFlightMetadataCollectorImpl.java:175) at org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:118) at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.metadata(EntityManagerFactoryBuilderImpl.java:900) at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:931) at org.hibernate.jpa.HibernatePersistenceProvider.createEntityManagerFactory(HibernatePersistenceProvider.java:56) at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:79) at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:54) at com.contable.test.TestPersona.main(TestPersona.java:19) Caused by: org.hibernate.exception.JDBCConnectionException: Error calling Driver#connect
y estas son las clases y archivo de configuración involucradas.
Código clase persona:
Ver original
package com.contable.modelo.Persona; import java.io.Serializable; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.Table; @Entity @Table(name = "Persona") public class Persona implements Serializable{ private static final long serialVersionUID = 1L; @Id @GeneratedValue(strategy = GenerationType.IDENTITY) //autoincremental private int id; @Column(name="empresa") private int Empresa; //STRING @Column(name="nombre", length=45) private String nombre; @Column(name="apellido", length=45) private String apellido; @Column(name="direccion", length=45) private String direccion; @Column(name="prov", length=30) private String prov; @Column(name="localidad", length=70) private String localidad; @Column(name="mail", length=70) private String mail; @Column(name="tel1", length=45) private String tel1; @Column(name="tel2", length=45) private String tel2; @Column(name="condicion_iva", length=45) private String condicion_iva; //BOOLEANO @Column(name="proveedor") private boolean proveedor; @Column(name="cliente") private boolean cliente; @Column(name="eliminado") private boolean eliminado; //ENTERO @Column (name="cp") private int cp; //constructores getters y setters. }
Código PERSISTENCIA.XML:
como se ve comente varias opciones de configuracion, en las pruebas, sin lograr conectar a la base, que supongo que es el problema.Ver original
<?xml version="1.0" encoding="UTF-8"?> <persistence xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd" version="2.0" xmlns="http://java.sun.com/xml/ns/persistence"> <persistence-unit name="Persistencia"> <!-- PERSISTENCIA DE CLASES --> <!-- PAQUETE PERSONA--> <class> com.contable.modelo.Persona.Persona </class> <properties> <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver" /> <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/dbcontable" /> <property name="hibernate.connection.username" value="root" /> <property name="hibernate.connection.password" value="ternario" /> <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" /> <property name="hibernate.show_sql" value="true"/> <property name="hibernate.hbm2ddl.auto" value="update" /> <!-- <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" /> <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/dbcontable" /> <property name="javax.persistence.jdbc.user" value="root" /> <property name="javax.persistence.jdbc.password" value="ternario" /> <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" /> <property name="hibernate.show_sql" value="true" /> <property name="hibernate.hbm2ddl.auto" value="update" /> --> </properties> </persistence-unit> </persistence>
codigo de prueba.
Código prueba:
la excepcion salta en la linea 19: con 'emf = Persistence.createEntityManagerFactory("Persistenc ia");'Ver original
package com.contable.test; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.Persistence; import com.contable.modelo.Persona.Persona; public class TestPersona { private static EntityManager manager; private static EntityManagerFactory emf; public static void main (String[] args) { emf = Persistence.createEntityManagerFactory("Persistencia"); manager = emf.createEntityManager(); List<Persona> list= (List<Persona>)manager.createQuery("FROM Persona").getResultList(); System.out.println("en la base de datos hay: "+list.size()+" empleados"); } }
y este es mi archivo pom.xml
Código POM.XML:
Ver original
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.ternario</groupId> <artifactId>hib-jpa-contable</artifactId> <version>1.0.0.1-SNAPSHOT</version> <dependencies> <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-core --> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-core</artifactId> <version>5.4.4.Final</version> </dependency> <!-- https://mvnrepository.com/artifact/javax.persistence/persistence-api --> <dependency> <groupId>javax.persistence</groupId> <artifactId>persistence-api</artifactId> <version>1.0.2</version> </dependency> <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-entitymanager --> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-entitymanager</artifactId> <version>5.4.4.Final</version> </dependency> <!-- https://mvnrepository.com/artifact/com.h2database/h2 g database como archivo.--> <dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <version>1.4.199</version> <scope>test</scope> </dependency> <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.17</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.1</version> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build> </project>
Según la documentación, el error devuelto es error de conexión a la base, controlo con mucha atención, la configuración al la base esta bien cargada, supongo que puede ser alguna property mal expresada o alguna dependencia que este de maso o que falte, porque realmente no tengo idea que puede ser.
Si alguien cree tener alguna sugerencia, la escucho y pruebo para ver si avanzo con este tema.
Desde ya muchas gracias. un abrazo a todos.