sql >> データベース >  >> RDS >> PostgreSQL

XMLなしでJPA/Hibernate/PostgreSQLを構成する

    次のフラグメントを@Configurationアノテーションが付けられたクラスに配置します および@EnableTransactionManagement

    Hibernate / JPA(packagesToScan文字列を編集):

    @Bean
    public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
        LocalContainerEntityManagerFactoryBean em = new LocalContainerEntityManagerFactoryBean();
        em.setDataSource(dataSource());
        em.setPackagesToScan(new String[] { "com.XY.model" });
        JpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
        em.setJpaVendorAdapter(vendorAdapter);
        em.setJpaProperties(additionalProperties());
        return em;
    }
    
    Properties additionalProperties() {
        Properties properties = new Properties();
        properties.setProperty("hibernate.hbm2ddl.auto", "update");
        properties.setProperty("hibernate.dialect", "org.hibernate.dialect.PostgreSQL9Dialect");
        properties.setProperty("hibernate.show_sql", "true");
        return properties;
    }
    

    データソース(ユーザー名、パスワード、ホストアドレスを編集):

    @Bean
    public DataSource dataSource() {
        DriverManagerDataSource dataSource = new DriverManagerDataSource();
        dataSource.setDriverClassName("org.postgresql.Driver");
        dataSource.setUrl("jdbc:postgresql://localhost:port/DB_NAME");
        dataSource.setUsername("root");
        dataSource.setPassword("");
        return dataSource;
    }
    

    トランザクションマネージャー:

    @Bean
    public PlatformTransactionManager transactionManager(EntityManagerFactory emf) {
        JpaTransactionManager transactionManager = new JpaTransactionManager();
        transactionManager.setEntityManagerFactory(emf);
        return transactionManager;
    }
    


    1. Laravelのデータに影響を与えずにテーブルスキームを更新する

    2. WHERE句内でパラメータがNULLかどうかを確認します

    3. ミリ秒を表示するLaravelタイムスタンプ

    4. post_idをmysqlデータベースに挿入するにはどうすればよいですか