5
respostas

[Dúvida] Não consigo configurar o MySQL

Depois de muitas tentativas e muitas consultas nos foruns e pesquisa na internet, venho recorrer a quem possa me ajudar e me explicar o que está acontecendo. Com o código criado até a aula 3 do do curso de JPA com Hibernate, não consegui ter acesso ao banco de dados MySQL instalado na minha máquina.

Arquivo pom.xml:

<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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>br.com.alura</groupId>
    <artifactId>loja</artifactId>
    <version>1.0.0</version>
    <build>
        <finalName>loja</finalName>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.10.1</version>
                <configuration>
                    <source>17</source>
                    <target>17</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.jacoco</groupId>
                <artifactId>jacoco-maven-plugin</artifactId>
                <version>0.8.2</version>
                <executions>
                    <execution>
                        <goals>
                            <goal>prepare-agent</goal>
                        </goals>
                    </execution>
                    <execution>
                        <id>report</id>
                        <phase>test</phase>
                        <goals>
                            <goal>report</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
    <dependencies>
        <!-- https://mvnrepository.com/artifact/junit/junit -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.2</version>
            <scope>test</scope>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.thoughtworks.xstream/xstream -->
        <dependency>
            <groupId>com.thoughtworks.xstream</groupId>
            <artifactId>xstream</artifactId>
            <version>1.4.20</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-entitymanager -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-entitymanager</artifactId>
            <version>5.6.14.Final</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.32</version>
        </dependency>
        <dependency>
            <groupId>javax.persistence</groupId>
            <artifactId>javax.persistence-api</artifactId>
            <version>2.2</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.h2database/h2 -->
        <!--<dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <version>2.1.214</version>
            <scope>test</scope>
        </dependency>-->
    </dependencies>
</project>
5 respostas

O arquivo persistence.xml está assim:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.2"
             xmlns="http://xmlns.jcp.org/xml/ns/persistence"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_2.xsd">

    <persistence-unit name="loja" transaction-type="RESOURCE_LOCAL">

        <!--
        Caso não utiliza o "hibernate" deve ser acrescentada a tag abaixo para cada classe do projeto.
        Obs: Caso estja utilizando o hibernate e declarou uma classe, deve-se declarar todas as classes,
        do contrário o projeto dará erro, desta forma, ou declara todas as classes ou não declara nenhuma.-->

        <!-- <class>br.com.alura.loja.modelo.Produto</class> -->


        <properties>
            <!-- Para o banco de dados H2 é utilizado a linha abaixo.
            <property name="javax.persistence.jdbc.driver" value="org.h2.Driver"/> -->
            <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>

            <!-- Enderedo banco de dados
            <property name="javax.persistence.jdbc.url" value="jdbc:h2:mem:loja"/> -->
            <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/loja"/>

            <!-- Username do banco de dados
            <property name="javax.persistence.jdbc.user" value="sa"/> -->
            <property name="javax.persistence.jdbc.user" value="root"/>

            <!-- Senha do usuário do banco de dados
            <property name="javax.persistence.jdbc.password" value=""/> -->
            <property name="javax.persistence.jdbc.password" value="admin123"/>

            <!-- Dialeto utilizado pelo banco de dados, para o hibernate saber as particularidades de cada banco.
            <property name="hibernate.dialect" value="org.hibernate.dialect.H2Dialect" /> -->
            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL8Dialect" />


            <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>

Agradeço toda ajuda possível.

Mensagem de erro no console: Insira aqui a descrição dessa imagem para ajudar na acessibilidade

Extrutura do Projeto: Insira aqui a descrição dessa imagem para ajudar na acessibilidade

Oi Danilo!

Parece ser um problema com a estrutura do arquivo xml persistence.xml.

Confere se a primeira linha do seu arquivo é essa:

<?xml version="1.0" encoding="UTF-8"?>

Não pode ter uma linha em branco no início do arquivo. Sugiro também você apagar todos os comentários desse arquivo:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.2"
             xmlns="http://xmlns.jcp.org/xml/ns/persistence"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_2.xsd">

    <persistence-unit name="loja" transaction-type="RESOURCE_LOCAL">
        <properties>
            <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
            <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/loja"/>
            <property name="javax.persistence.jdbc.user" value="root"/>
            <property name="javax.persistence.jdbc.password" value="admin123"/>
            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL8Dialect" />
            <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>

Outra coisa, o driver correto do MySQL para a versão 8 é esse:

com.mysql.cj.jdbc.Driver