Solucionado (ver solução)
Solucionado
(ver solução)
2
respostas

Caused by: java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: NO)

Procurei nos outros tópicos com o mesmo erro e não encontrei o erro. No MariaDB eu acesso normalmente sem senha de root, crio databases sem problemas, com o usuario ROOT e com outros usuarios que criei. Já verifiquei os privilégios de usuario e estão funcionando normalmente. O problema ocorre ao compilar a classe TesteCriaTabelas.java.

Erro:

Caused by: java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: NO)
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:129)
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97)
    at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:122)
    at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:836)
    at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:456)
    at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:246)
    at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:199)
    at org.hibernate.engine.jdbc.connections.internal.DriverConnectionCreator.makeConnection(DriverConnectionCreator.java:38)
    ... 29 more

Segui exatamente a aula de criação de tabelas, porém não chega nem a acessar o MariaDB, deixei sem senha para ver se era alguma coisa assim porém o problema persiste.

Meu persistence.xml

<persistence xmlns="http://java.sun.com/xml/ns/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">

    <persistence-unit name="contas">
        <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
        <class>br.com.alura.jpa.modelo.Conta</class>

        <properties>
            <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
            <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost/alura_jpa?serverTimezone=UTC" />
            <property name="javax.persistence.jdbc.user" value="root" />
            <property name="javax.persistence.jdbc.password" value="" />

            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect" />
            <property name="hibernate.show_sql" value="true" />
            <property name="hibernate.format_sql" value="true" />

            <property name="hibernate.hbm2ddl.auto" value="update" />

        </properties>
    </persistence-unit>
</persistence>

Desde já agradeço.

2 respostas

Oi Marcos

Pode ser o dialect MySQL5InnoDBDialect

Qual versão do MariaDB você está tentando se conectar? Tenta atualizar o driver de conexão

solução!

Opá, boa tarde! Descobri o que era, eu ja tinha instalado o Mysql e como no curso foi solicitado para instalar o MariaDB acabou que o MySql ficou com a porta padrão e quando instalei o MariaDB configurei outra porta (3307).

Assim meu persistence.xml estava tentando conectar com o Mysql. Então eu adicionei a porta do MariaDB para o meu persistence.xml e ficou funcionando normalmente.

Linha 'property name' :

<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3307/alura_jpa?serverTimezone=UTC" />

Arquivo persistence.xml completo

<persistence xmlns="http://java.sun.com/xml/ns/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">

    <persistence-unit name="contas">
        <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
        <class>br.com.alura.jpa.modelo.Conta</class>

        <properties>
            <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
            <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3307/alura_jpa?serverTimezone=UTC" />
            <property name="javax.persistence.jdbc.user" value="root" />
            <property name="javax.persistence.jdbc.password" value="" />

            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect" />
            <property name="hibernate.show_sql" value="true" />
            <property name="hibernate.format_sql" value="true" />

            <property name="hibernate.hbm2ddl.auto" value="update" />

        </properties>
    </persistence-unit>
</persistence>