Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 1277|回复: 0

配置Hibernate n:1时出现的问题

[复制链接]

该用户从未签到

发表于 2011-11-29 22:31:25 | 显示全部楼层 |阅读模式
Hibernate: insert into users (name, room_id) values (?, ?) select scope_identity()
org.hibernate.TransientObjectException: object references an unsaved transient instance - save the transient instance before flushing: po.Room
    at org.hibernate.engine.ForeignKeys.getEntityIdentifierIfNotUnsaved(ForeignKeys.java:219)
    at org.hibernate.type.EntityType.getIdentifier(EntityType.java:397)
    at org.hibernate.type.ManyToOneType.isDirty(ManyToOneType.java:242)
    at org.hibernate.type.TypeFactory.findDirty(TypeFactory.java:563)
    at org.hibernate.persister.entity.AbstractEntityPersister.findDirty(AbstractEntityPersister.java:3071)
    at org.hibernate.event.def.DefaultFlushEntityEventListener.dirtyCheck(DefaultFlushEntityEventListener.java:472)
    at org.hibernate.event.def.DefaultFlushEntityEventListener.isUpdateNecessary(DefaultFlushEntityEventListener.java:197)
    at org.hibernate.event.def.DefaultFlushEntityEventListener.onFlushEntity(DefaultFlushEntityEventListener.java:120)
    at org.hibernate.event.def.AbstractFlushingEventListener.flushEntities(AbstractFlushingEventListener.java:196)
    at org.hibernate.event.def.AbstractFlushingEventListener.flushEverythingToExecutions(AbstractFlushingEventListener.java:76)
    at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:26)
    at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:1000)
    at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:338)
    at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:106)
    at dao.imp.UsersDAL.SaveUser(UsersDAL.java:22)

    at dao.imp.test.main(test.java:21)
这句异常的意思是:我们在使用一个临时的对象room,按常理我们应先保存room,然后保存users信息。解决此问题我们可以采取以下2种方式将room列入session保持其持久化状态:
  save roomsave users,即保证usersroom共用一个session,因为dal中代码已封装好,因此采用第二种方式即cascade关键字
  使用cascade关键字(取值:nonesave-updateall、delete


按照以上方法配置过后出现
log4j:WARN No appenders could be found for logger (org.hibernate.cfg.Environment).
log4j:WARN Please initialize the log4j system properly.
Hibernate: insert into room (name) values (?) select scope_identity()
Exception in thread "main" java.lang.NullPointerException
    at dao.imp.RoomDAL.SaveRoom(RoomDAL.java:20)

    at dao.imp.test.main(test.java:23)
配置方法如下:
<
hibernate-mapping
>
    <class name="po.Users" table="users">
        <id name="id" type="integer">
            <column name="id"></column>
            <generator class="native"></generator>
        </id>
        <property name="name" type="string">
            <column name="name" not-null="true" length="30"></column>
        </property>
        <many-to-one name="room" class="po.Room" cascade="all">
            <column name="room_id"></column>
        </many-to-one>
    </class>


</
hibernate-mapping
>
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2025-1-16 07:46 , Processed in 0.401642 second(s), 46 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表