用pd建好模生成数据库之后,如果你的表有一对多的关系,当你生成hibernate时就是自动生成一个双向一对多关系。即一的一方用<set>...</set.>,多的一方就<many-to-one .../>,现代码的顺序及写法都没有问题,hbm.xml文件同时也没错。但是在保存时就是报违反唯一约束的值。这个问题,搞了好久才知道是数据库外键约束而且 引发的总是。
解决的办法就是手动将数据库里的外键全部删除即可.(这个情况是发生在一个表的pid是另外几个表的id字段,即表(uploadfile)是跟表1表2表3表4表5中ID字段是有关系的。则生成的hbm.xml文件就如下:
<many-to-one name="TZhengshu" class="com.webaorta.comm.pojo.TZhengshu" fetch="select">
<column name="OBJID" length="50" />
</many-to-one>
<many-to-one name="TTopicpost" class="com.webaorta.comm.pojo.TTopicpost" update="false" insert="false" fetch="select">
<column name="OBJID" length="50" />
</many-to-one>
<many-to-one name="TQz" class="com.webaorta.comm.pojo.TQz" update="false" insert="false" fetch="select">
<column name="OBJID" length="50" />
</many-to-one>
当有多个many-to-one时,如果你将update改成true也会报错的。