hibernate java 数据库_关于Java:如何通过Hibernate创建数据库

在我的春季项目中,我正在使用Hibernate将我的实体类导出到以前创建的数据库中。 但这将要求最终用户知道如何在数据库管理器系统中创建数据库(当前我正在使用Postgresql)。

有没有办法,仅考虑安装postgresql的机器(以及第一次运行该应用程序时提供的用户名和密码),如果不存在,Hibernate会在服务器中创建一个新数据库?

Hibernate的可能重复项:根据实体类自动创建/更新数据库表

没有重复,我不想创建/更新表,但是创建数据库。

stackoverflow.com/questions/306806/

如果不存在PostgreSQL,可能会模拟Simulate CREATE DATABASE的副本?

复制了stackoverflow.com/questions/18389124/

如果您的配置如下所示

org.hibernate.dialect.PostgreSQLDialect

org.postgresql.Driver

jdbc:postgresql://host:port/database

username

password

thread

false

update

然后,数据库将由Hibernate自动创建。

更新:

好吧,现在我明白了你想要什么。您要使用Hibernate启动Postgresql服务器。这是不可能的。 Hibernate不会这样做。

你可以用

另一个以您的应用程序开头的脚本

一个行家/蚂蚁目标。

建造工作

但是最好的解决方案是使用不需要外部服务器(例如H2或Java derby)的内存数据库

也可以看看

如果不存在PostgreSQL,则模拟CREATE DATABASE吗?

Postgres数据库创建(如果不存在)

不,这不会发生:如果我在不创建数据库的情况下运行应用程序,则会收到错误消息。 我的配置文件是:github.com/klebermo/maven_example/blob/master/src/main/java/。

有什么错误? 将此发布到您的问题以及github项目lin上。

如果我在运行应用程序之前未手动创建数据库,则在应用程序尝试访问数据库时会收到以下错误消息:klebermota.eti.br/wp-content/

查看我的最新答案

作为本地SQL查询运行"创建数据库..."(请参阅??http://www.postgresql.org/docs/9.0/static/sql-createdatabase.html)。

.createSQLQuery(" ...").executeUpdate(); ...

至少据我所知,Hibernate不会创建数据库,而只会创建其中的表。

我想您需要通过第二个持久性单元/连接来连接到postgresql,因为这种方法具有"鸡到鸡"的特性。

看一下hibernate.cfg.xml文件的参数hibernate.hbm2ddl.auto。我建议您使用此链接:Hibernate hbm2ddl.auto,可能的值及其用途-有任何官方解释吗?

我已经在数据库中创建/更新了表,现在我希望能够通过Hibernate在服务器中创建DATABASE,以避免将此任务交给用户。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hibernate 的核心功能之一是 Java 对象和数据库表之间的映射,这是实现 ORM 的核心。Hibernate 提供了多种方式来进行对象和表之间的映射,包括 XML 映射文件、注解和 Java 代码映射等。无论使用哪种方式,Hibernate 的映射原理都是一致的。 Hibernate 的映射原理可以分为两个方面:对象属性和表列之间的映射、对象之间的关系映射。 1. 对象属性和表列之间的映射 在 Hibernate 中,每个实体类都对应着一个数据库表,实体类的属性对应着数据库表的列。在使用 Hibernate 进行数据库操作时,Hibernate 会将实体对象的属性值映射到数据库表的列上,或将数据库表的列值映射到实体对象的属性上。Hibernate 的属性和表列之间的映射关系主要通过映射文件或注解来进行配置。 在映射文件中,使用 <class> 标签定义实体类,使用 <property> 标签或 <id> 标签来定义属性,使用 <column> 标签来定义属性对应的数据库表列。例如: ```xml <class name="com.example.User" table="user"> <id name="id" type="long" column="id"> <generator class="identity"/> </id> <property name="name" column="name" type="string"/> <property name="age" column="age" type="integer"/> </class> ``` 在注解中,使用 @Entity 标注实体类,使用 @Column 标注属性对应的数据库表列。例如: ```java @Entity @Table(name = "user") public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(name = "name") private String name; @Column(name = "age") private Integer age; // 省略 getter 和 setter 方法 } ``` 2. 对象之间的关系映射 在 Hibernate 中,实体类之间可以存在多种关系,包括一对一、一对多、多对一和多对多等。Hibernate 通过映射文件或注解来定义实体类之间的关系映射关系。 例如,一对多关系可以通过在多的一方的实体类中定义一个集合属性来表示。在映射文件中,使用 <set> 标签定义集合属性,使用 <one-to-many> 标签定义集合元素对应的实体类。例如: ```xml <class name="com.example.Order" table="orders"> <id name="id" type="long" column="id"> <generator class="identity"/> </id> <property name="name" column="name" type="string"/> <set name="items" inverse="true" lazy="true" cascade="all"> <key column="order_id"/> <one-to-many class="com.example.OrderItem"/> </set> </class> <class name="com.example.OrderItem" table="order_items"> <id name="id" type="long" column="id"> <generator class="identity"/> </id> <property name="name" column="name" type="string"/> <property name="price" column="price" type="double"/> <many-to-one name="order" class="com.example.Order" column="order_id"/> </class> ``` 在注解中,可以使用 @OneToMany 和 @ManyToOne 注解来定义一对多关系,使用 @JoinColumn 注解来定义外键。例如: ```java @Entity @Table(name = "orders") public class Order { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(name = "name") private String name; @OneToMany(mappedBy = "order", cascade = CascadeType.ALL) private List<OrderItem> items; // 省略 getter 和 setter 方法 } @Entity @Table(name = "order_items") public class OrderItem { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(name = "name") private String name; @Column(name = "price") private Double price; @ManyToOne @JoinColumn(name = "order_id") private Order order; // 省略 getter 和 setter 方法 } ``` 总之,Hibernate 的映射原理是将 Java 对象和数据库表之间的属性和关系进行映射,通过映射文件或注解来进行配置。Hibernate 支持多种关系映射,包括一对一、一对多、多对一和多对多等,开发人员可以根据需要选择合适的映射方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值