javaではhibernateのプロファイルに基づいて自動的に表を作成します。

3397 ワード

1、javaプロジェクトと、データベースの移転をする時に、いずれも使うデータスクリプトです。
2、hibernateを導入すると、データベーステーブルのプロファイルを作成することができます。テーブルの設定ファイルに従って自動的にデータベースにテーブルを作ることができます。(データベースはあらかじめ作成しておきます。hibernateは表を作るだけですので、ライブラリを作ることはできません。)
ステップ:
1)設定ファイルのhibernature.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>
葃udateは自動的にmodelオブジェクトによってテーブル構造を更新し、hibernateを起動する時に自動的にデータベースをチェックすると表しています。テーブルがないと自動的にテーブルを建設します。テーブルに列がない場合は、列を自動的に追加します。
葃create:hibernateを起動すると、自動的に元のテーブルを削除して、すべてのテーブルを新築するので、起動後の以前のデータは毎回無くなります。
葃creat-drop:hibernateを起動すると、自動的にテーブルを作成し、プログラムが閉じられた時に、自動的に該当するテーブルを削除します。したがって、プログラムが終了すると、テーブルとデータは存在しません。 
2)pojoname.hbm.xmlプロファイルを配置し、追加する。 ヒベルナ-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);
     }
}
設定ファイルに基づいてデータベースにテーブルを作成できます。