我正在使用PostgreSQL和Spring4,希望我的应用程序在运行时自动创建数据库。
我的实体类是:
@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;
}
}
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;
}
}
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
但当我运行SQL来访问表USER时,将出现错误:表‘USER’不存在。
如何让Hibernate自动创建数据库?
7条答案
按热度按时间5gfr0r5j1#
只要找零就行了
出发地:
致:
因为PostgreSQL有默认的“USER”
bqujaahr2#
您可以使用
"CREATE SCHEMA IF NOT EXISTS x;"
和"CREATE SCHEMA IF NOT EXISTS x;"
它应该能行得通
xlpyo6sf3#
与MySQL不同,Postgres不支持
Create Database If not exist
。因此,更改
hibernate.hbm2ddl.auto=create
和更改URLjdbc.url=jdbc:postgresql://localhost/database?createDatabaseIfNotExist=true
对您不起作用。但是,您可以尝试模拟以下问题中的行为:
Create Postgres database on the fly, if it doesn't exists using Hibernate
Simulate CREATE DATABASE IF NOT EXISTS for PostgreSQL?
50few1ms4#
试试这条路
这是我的工作。
从《Hibernate用户指南》的自动模式生成部分:
javax.persistence.schema-generation.database.action
设置为在SessionFactory生命周期中自动执行SchemaManagementTool操作。有效选项由操作枚举的外部JpaName值定义:
none
-不执行任何操作。create
-将生成数据库创建。drop
-将生成数据库删除。drop-and-create
-在创建数据库之后将生成数据库删除。在那里
spring.jpa.hibernate.ddl-auto=update
==>update
,您可以根据您的场景进行更改。iszxjhcz5#
属性
hibernate.hbm2ddl.auto
将为您完成此任务。在创建SessionFactory时,它会自动验证模式DDL或将其导出到数据库。使用CREATE-DROP,当显式关闭SessionFactory时,数据库模式将被删除。Hibernate可以接受上述属性的这些选项。
validate
:验证模式,不更改数据库。update
:更新架构。create
:创建模式,销毁以前的数据。create-drop
:在会话结束时删除该架构。myzjeezk6#
Spring Boot
Postgres不支持
createDatabaseIfNotExist=true
,所以您可以尝试类似的方法,它对我也有效,请参阅Screenshotsxissh067#
问题出在 hibernate 方言上。您正在使用旧的。你应该用像这样的新的。