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

Hibernate não altera tabela utilizando update

Após adicionar o atributo 'dataLancamento' o Hibernate não adiciona a coluna na tabela 'Produto'.

Só funciona se alterar o comando:

props.setProperty("hibernate.hbm2ddl.auto", "update")

para:

props.setProperty("hibernate.hbm2ddl.auto", "create")

Dessa forma ele não está atualizando a estrutura do banco apenas criando.

Classe JPAConfiguration

 package br.com.casadocodigo.loja.conf;

import java.util.Properties;

import javax.persistence.EntityManagerFactory;

import org.springframework.context.annotation.Bean;
import org.springframework.jdbc.datasource.DriverManagerDataSource;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.orm.jpa.JpaVendorAdapter;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
import org.springframework.transaction.annotation.EnableTransactionManagement;

@EnableTransactionManagement
public class JPAConfiguration {

    @Bean
    public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
        LocalContainerEntityManagerFactoryBean factoryBean = new LocalContainerEntityManagerFactoryBean();

        JpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
        factoryBean.setJpaVendorAdapter(vendorAdapter);

        DriverManagerDataSource dataSource = new DriverManagerDataSource();
        dataSource.setUsername("root");
        dataSource.setPassword("12345");
        dataSource.setUrl("jdbc:mysql://localhost:3306/casadocodigo?useTimezone=true&serverTimezone=UTC");
        dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");

        factoryBean.setDataSource(dataSource);

        Properties props = new Properties();
        props.setProperty("hibernate.dialect", "org.hibernate.dialect.MySQL5Dialect");
        props.setProperty("hibernate.show_sql", "true");
        props.setProperty("hibernate.format_sql", "true");
        props.setProperty("hibernate.hbm2ddl.auto", "update");
        factoryBean.setJpaProperties(props);

        factoryBean.setPackagesToScan("br.com.casadocodigo.loja.models");

        return factoryBean;
    }

    @Bean
    public JpaTransactionManager transactionManager(EntityManagerFactory emf) {
        return new JpaTransactionManager(emf);
    }

}
4 respostas

Problema interessante Welton, sabe dizer se atualizando as versões do seu Hibernate no pom.xml para a 5.4.2.Final se isso continua ocorrendo?

Exemplo:

    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-entitymanager</artifactId>
        <version>5.4.2.Final</version>
    </dependency>
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-core</artifactId>
        <version>5.4.2.Final</version>
    </dependency>

Otávio, utilizando essa versão do Hibernate, a tabela é alterada com sucesso e a coluna acrescentada. Porém, no momento de salvar as informações pelo formulário é exibido o seguinte erro:

https://gist.github.com/wefgoncalves/e26e3c9f56c22c88f5f8227a7e1a3603#file-gistfile1-txt

solução!

Welton, esse erro parece um conflito das dependências com a versão do Spring Framework 4.3.5.RELEASE. Por favor, faça o downgrade para o hibernate-core-5.1.0.Final e veja se resolve ambos os problemas, por favor.

Otávio, muito obrigado pela ajuda e pelo retorno, problema resolvido.

Eu estava utilizando a versão 4.3.0.Final do Hibernate.

Abraço!