Tra*_*ang 3 java postgresql spring hibernate
我正在使用PostgreSQL和Spring 4,希望我的应用在运行时自动创建数据库。
我的实体类是:
@Entity
@Table(name = "user", schema = "public")
public class User extends BaseEntity {
private Integer id;
private String name;
private Integer contractId;
public User() {
}
public User(Integer id) {
super(id);
}
@Id
@Column(name = "usr_id", nullable = false)
@GeneratedValue(strategy= GenerationType.IDENTITY)
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
@Basic
@Column(name = "usr_name", nullable = true, length = -1)
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Basic
@Column(name = "usr_contract_id", nullable = true)
public Integer getContractId() {
return contractId;
}
public void setContractId(Integer contractId) {
this.contractId = contractId;
}
}
Run Code Online (Sandbox Code Playgroud)
HibernateConfig.java
@Configuration
@EnableTransactionManagement(proxyTargetClass = true)
@PropertySources({
@PropertySource(value = "classpath:application.properties")})
@ConfigurationProperties(prefix = "spring.datasource")
public class HibernateConfig {
@Autowired
private Environment environment;
@Autowired
private DataSource dataSource;
@Autowired
private MultiTenantConnectionProvider multiTenantConnectionProvider;
@Autowired
private CurrentTenantIdentifierResolver currentTenantIdentifierResolver;
public HibernateConfig() {}
@Bean
public LocalSessionFactoryBean sessionFactory() throws Exception {
LocalSessionFactoryBean sessionFactory = new LocalSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
sessionFactory.setHibernateProperties(hibernateProperties());
sessionFactory.setPackagesToScan(new String[] {
"com.xxx.xxx.model",
});
return sessionFactory;
}
private Properties hibernateProperties() {
Properties properties = new Properties();
properties.put(DIALECT, environment.getRequiredProperty(DIALECT));
properties.put(SHOW_SQL, environment.getRequiredProperty(SHOW_SQL));
properties.put(FORMAT_SQL, environment.getRequiredProperty(FORMAT_SQL));
properties.put(HBM2DDL_AUTO, environment.getRequiredProperty(HBM2DDL_AUTO));
return properties;
}
@Bean
@Primary
@Autowired
public HibernateTransactionManager transactionManager(SessionFactory s) {
HibernateTransactionManager txManager = new HibernateTransactionManager();
txManager.setSessionFactory(s);
return txManager;
}
@Bean
@Autowired
public HibernateTemplate hibernateTemplate(SessionFactory s) {
HibernateTemplate hibernateTemplate = new HibernateTemplate(s);
return hibernateTemplate;
}
}
Run Code Online (Sandbox Code Playgroud)
application.properties
# Database connection settings:
jdbc.driverClassName=org.postgresql.Driver
jdbc.url=jdbc:postgresql://localhost:5432/database
jdbc.username=postgres
jdbc.password=111111
hibernate.dialect=org.hibernate.dialect.PostgreSQLDialect
hibernate.show_sql=false
hibernate.format_sql=false
hibernate.hbm2ddl.auto=update
spring.datasource.initialSize=50
spring.datasource.maxActive=200
spring.datasource.maxIdle=200
spring.datasource.minIdle=50
Run Code Online (Sandbox Code Playgroud)
但是,当我运行SQL访问表User时,将出现错误:表'User'不存在。
如何使Hibernate自动创建数据库?
Postgres不像mysql不支持Create Database If not exist。
因此,更改hibernate.hbm2ddl.auto=create和更改URL jdbc.url=jdbc:postgresql://localhost/database?createDatabaseIfNotExist=true
对您不起作用。
但是,您可以尝试模拟以下问题中的行为:
使用Hibernate动态创建Postgres数据库(如果不存在)
如果不存在PostgreSQL,则模拟CREATE DATABASE吗?
试试这个方法
spring.jpa.hibernate.ddl-auto=update
spring.jpa.generate-ddl=true
spring.jpa.database-platform=org.hibernate.dialect.PostgreSQL94Dialect
spring.datasource.driverClassName=org.postgresql.Driver
spring.datasource.url= jdbc:postgresql://localhost:5432/postgres
spring.datasource.username=postgres
spring.datasource.password=123
spring.jpa.show-sql=true
spring.session.store-type=none
Run Code Online (Sandbox Code Playgroud)
这对我来说是工作。
javax.persistence.schema-generation.database.action设置为作为 SessionFactory 生命周期的一部分自动执行 SchemaManagementTool 操作。有效选项由Action 枚举的externalJpaName值定义:
none- 不会执行任何操作。
create- 将生成数据库创建。
drop- 将产生数据库删除。
drop-and-create- 将生成数据库删除,然后创建数据库。
那里spring.jpa.hibernate.ddl-auto=update==> update,您可以根据您的情况进行更改。
该物业hibernate.hbm2ddl.auto将为您解决问题。创建 SessionFactory 时,它会自动验证或将模式 DDL 导出到数据库。使用 create-drop,当 SessionFactory 显式关闭时,数据库模式将被删除。
Hibernate 可以接受上述属性的这些选项。
validate: 验证架构,不对数据库做任何更改。
update: 更新架构。
create: 创建模式,破坏以前的数据。
create-drop:在会话结束时删除架构。
| 归档时间: |
|
| 查看次数: |
15314 次 |
| 最近记录: |