hibernate建表

Hibernate配置文件:
<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">root</property>
  
  <!-- 数据路方言 -->
  <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
  <property name="myeclipse.connection.profile">mysql</property>
  <property name="hibernate.show_sql">true</property>
<property name="hbm2ddl.auto">update</property>
  <mapping resource="org/mdl/school/Person.hbm.xml" />
 </session-factory>
</hibernate-configuration>

映射文件:
<hibernate-mapping package="org.mdl.domain">
 <class name="Person">
  <id name="id" column="personid">
   <generator class="identity"></generator>
  </id>
  <property name="name" />
  <property name="age" />
  <list name="schools" table="school">
   <key column="personid" not-null="true" />
   <list-index column="list_order" />
   <element type="string" column="school_name" />
  </list>
 </class>
</hibernate-mapping>
创建两个数据表Person和school,两个数据表存在的话不创建,不存在的话用hibernate创建 
update:表示自动根据model对象来更新表结构,启动hibernate时会自动检查数据库,如果缺少表,则自动建表;如果表里缺少列,则自动添加列。 

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

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

数据库要预先建立好,因为hibernate只会建表,不会建库 

你可能感兴趣的:(数据结构,Hibernate,mysql,jdbc,MyEclipse)