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只会建表,不会建库