mysql - Hibernate ObjectNotFoundException,即使表中存在记录

标签 mysql hibernate spring-mvc

我正在开发一个 Spring MVC 应用程序,其中有两个模型类:LocationModel 和 ContactModel。下面是代码:

@Entity
@Table(name="Contact")
public class ContactModel {

    @Id
    @Column(name="contactid")
    @GeneratedValue
    private int contactId;

    @Column(name="contactname")
    private String contactName;

    @Column(name="contactemail")
    private String email;

    @Column(name="contactphone")
    private String phone;

    @ManyToOne
    @JoinColumn(name="locationid")
    private LocationModel locationModel;
}

@Entity
@Table(name="Location")
public class LocationModel {

    @Id
    @Column(name="locationid")
    @GeneratedValue 
    private int locationId;

    @Column(name="locationname")
    private String locationName;

    @Column(name="locationdesc")
    private String locationDescription;

    @Column(name="type")
    private String locationType;

    @Column(name="address")
    private String address;

    @Column(name="state")
    private String state;

    @Column(name="circle")
    private int circle;

    @Column(name="district")
    private int district;

    @Column(name="town")
    private int town;

    @Column(name="lattitude")
    private String lattitude;

    @Column(name="longitude")
    private String longitude;

    @Column(name="locationuid")
    private String locationUID;

    @Column(name="category")
    private String category;

    @Column(name="bedcount")
    private int bedCount;

    @OneToMany(mappedBy = "locationModel", fetch = FetchType.EAGER)
    private List<ContactModel> contactList;
}

位置表中的主键是联系人表中的外键。我在联系人表中有 2 条记录,位置 ID 为 0。

我使用以下代码来获取联系人列表:

Session session = sessionFactory.getCurrentSession();
            Query query = session
                    .createQuery("from ContactModel where contactName like :contactName");
            return query.setParameter("contactName", contactName + "%").list();

但它显示异常:

Error performing load command : org.hibernate.ObjectNotFoundException: No row with the given identifier exists: [com.bizmerlin.scm.model.LocationModel#0]
17:03:31,135 ERROR [stderr] (http--127.0.0.1-9090-2) org.hibernate.ObjectNotFoundException: No row with the given identifier exists: [com.bizmerlin.scm.model.LocationModel#0]

17:03:31,139 ERROR [stderr] (http--127.0.0.1-9090-2)    at org.hibernate.internal.SessionFactoryImpl$1$1.handleEntityNotFound(SessionFactoryImpl.java:247)

17:03:31,141 ERROR [stderr] (http--127.0.0.1-9090-2)    at org.hibernate.event.internal.DefaultLoadEventListener.load(DefaultLoadEventListener.java:214)

17:03:31,143 ERROR [stderr] (http--127.0.0.1-9090-2)    at org.hibernate.event.internal.DefaultLoadEventListener.proxyOrLoad(DefaultLoadEventListener.java:264)

也许是因为位置表没有位置 id 为 0 的记录。如果是这样,我如何获取联系人列表,即使他们的位置为空?

最佳答案

使用可选属性

@ManyToOne(optional=true)
@JoinColumn(name="locationid")
private LocationModel locationModel;

http://learningviacode.blogspot.in/2011/12/one-to-many-assocition-that-is-optional.html

关于mysql - Hibernate ObjectNotFoundException,即使表中存在记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28251757/

相关文章:

php - 使用 PHP 将多列数据发布到 Mysql 数据库

Hibernate hql - 帮助查询外键

java - Hibernate 搜索过滤器不适用于标记化字段

java - spring中如何将事务设置在最底层,类似jdbc?

mysql - 我应该在此查询中使用哪些 mysql 索引?

MySQL 删除不起作用

mysql - 用自定义字符串替换 Mysql 空字段

hibernate HQL : Get count of results without actually returning them

java - Spring MVC Controller 响应作为静态内容缓存在浏览器中

java - Spring MVC/Hibernate/mySQL "read"始终为空