如何取消hibernate hbm2ddl.auto 自动创建外键
利用hbm2ddl自动创建数据库表时,会同时创建表的外键关联。配置如下。
<prop key="hibernate.hbm2ddl.auto">create</prop>
要取消外键的自动创建,需要配置foreign-key="none"。
hibernate的更新log有如下说明:
Changes in version 2.1.9 (xx.x.xxxx) ------------------------------------ * foreign-key="none" can be used to disable generation of a foreign key.
因此,项目中关于hibernate ORM的配置可以用注解方式,也可以用配置文件方式。
用配置文件方式可以在xml相应实体类进行如下配置(注意其中的foreign-key="none"):
<class name="org.jbpm.identity.User" table="JBPM_ID_USER" discriminator-value="U"> <id name="id" column="ID_"> <generator class="native" /> </id> <discriminator type="char" column="CLASS_" /> <property name="name" column="NAME_" /> <property name="email" column="EMAIL_" /> <property name="password" column="PASSWORD_" /> <set name="memberships" cascade="all"> <key column="USER_" /> <one-to-many class="org.jbpm.identity.Membership" /> </set> <set name="permissions" cascade="all" table="JBPM_ID_PERMISSIONS"> <key column="ENTITY_" foreign-key="none" /> <element type="org.jbpm.identity.hibernate.PermissionUserType"> <column name="CLASS_" /> <column name="NAME_" /> <column name="ACTION_" /> </element> </set> </class>
用注解方式可以在相应类字段的get方法前配置注解如下:
@JoinColumn(name="parent_id") @ForeignKey( name = "none" )
以上。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。