java中根据hibernate配置文件自动建表

1、对与java项目,做数据库迁移时,都会用的数据脚本。

2、当引入hibernate时,可以创建数据库表的配置文件。可以根据表的配置文件自动在数据库建表。(数据库要预先建立好,因为hibernate只会建表,不会建库)

步骤:

1)、在配置文件 hibernate.cfg.cml 中加入参数 ,配置相关数据源参数和pojo文件

<property name="hbm2dll.auto">update</property>

<hibernate-configuration><session-factory>
	<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
	<property name="connection.url">jdbc:mysql://localhost:3306/test</property>
	<property name="connection.username">root</property>
	<property name="connection.password">mysecretpassword</property>
	<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
	
	<property name="hbm2dll.auto">update</property>
	<property name="javax.persistence.validation.mode">none</property>
	<property name="show_sql">true</property>
	
	<mapping resource="com/bean/User.hbm.xml"/>
	<mapping resource="com/bean/Journal.hbm.xml"/>	
	<mapping resource="com/bean/Article.hbm.xml"/>
	<mapping resource="com/bean/Chapter.hbm.xml"/>
	<mapping resource="com/bean/Paragraph.hbm.xml"/>
</session-factory></hibernate-configuration>

#update 表示自动根据model对象来更新表结构,启动hibernate时会自动检查数据库,如果缺少表,则自动建表;如果表里缺少列,则自动添加列。

#create:启动hibernate时,自动删除原来的表,新建所有的表,所以每次启动后的以前数据都会丢失。

#create-drop:启动hibernate时,自动创建表,程序关闭时,自动把相应的表都删除。所以程序结束时,表和数据也不会再存在。 


2)、配置 pojoname.hbm.xml 配置文件, 添加 hibernate-mapping

<hibernate-mapping>
	<class name="com.bean.Article" table="article" catalog="test">
		<id name="article_id" type="java.lang.Integer">
			<column name="article_id"></column>
			<generator class="identity"></generator>
		</id>
		<property name="outline" type="java.lang.String">
			<column name="outline" length="20" not-null="false"></column>
		</property>
		<property name="title" type="java.lang.String">
			<column name="title" length="20" not-null="false"></column>
		</property>
		<many-to-one name="journal" class="com.bean.Journal" 
		column="journal_id" not-null="true" cascade="all"></many-to-one>
		<set name="chapters" inverse="true" cascade="all">
			<key column="article_id"></key>
			<one-to-many class="com.bean.Chapter"></one-to-many>
		</set>
	</class>
</hibernate-mapping>

3、建立一个启动类

public class InportDatabase {

    public static void main(String[] args) {
        Configuration cfg = new Configuration().configure();
        SchemaExport export = new SchemaExport(cfg);
        export.create(true, true);
     }
}


即可根据配置文件在数据库中建立相应的表。


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值