hibernate保存时违反唯一约束值

      用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也会报错的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值