Buenas noches tengo un problema supongo que simple, pero problema en fin.
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 originalERROR: 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 originalpackage 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:
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>
como se ve comente varias opciones de configuracion, en las pruebas, sin lograr conectar a la base, que supongo que es el problema.
codigo de prueba.
Código prueba:
Ver originalpackage 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");
}
}
la excepcion salta en la linea 19: con 'emf = Persistence.createEntityManagerFactory("Persistenc ia");'
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.