- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 Hibernate Criteria API 时,我正在努力解决 Hibernate 的一个非常奇怪的行为。我正在使用 hibernate 4.3.6 Final。我有一个像这样的AnnouncementAttribute类:
@Entity
@Table(name = "announcement_attribute")
public class AnnouncementAttribute implements Serializable {
@EmbeddedId
protected AnnouncementAttributePK id;
@Column(name = "attribute_value")
private String attributeValue;
}
以及AnnouncementAttributePK类下面:
@Embeddable
public class AnnouncementAttributePK implements Serializable {
@ManyToOne
@JoinColumn(name = "attribute_id")
private Attribute attr;
@ManyToOne
@JoinColumn(name = "announcement_id")
private Announcement announcement;
}
和属性类:
@Entity
@Table(name = "attribute")
public class Attribute implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
@Column(name = "attribute_type")
private Integer attributeType;
@Column(name = "attribute_name")
private String attributeName;
}
我在这里省略了 getter/setter。
问题是当我尝试通过 Criteria API 访问 @EmbeddedId 属性 attr 时:
Criteria ac = session().createCriteria(AnnouncementAttribute.class);
ac.add(Restrictions.and(
Restrictions.eq("id.attr.attributeName", "someKey"),
Restrictions.eqOrIsNull("attributeValue", "someValue")));
我得到:
org.hibernate.QueryException: could not resolve property: id.attr.attributeName of: com.example.app.domain.AnnouncementAttribute
我已经尝试为EmbeddedId 创建别名 - 仍然没有成功。
最佳答案
好吧,虽然我不相信我找到的解决方案,但无论如何我都会发布它,也许有人会发现它有用,或者也许它将成为进一步讨论的好主题。
我从AnnouncementAttributePK中删除了@Embedded
public class AnnouncementAttributePK implements Serializable {
@ManyToOne
@JoinColumn(name = "attribute_id")
private Attribute attr;
@ManyToOne
@JoinColumn(name = "announcement_id")
private Announcement announcement;
}
,然后在AnnouncementAttribute中我将@EmbeddedId更改为@IdClass和@Id的组合:
@Entity
@Table(name = "announcement_attribute")
@IdClass(AnnouncementAttributePK.class)
public class AnnouncementAttribute implements Serializable {
@Id
private Attribute attr;
@Id
private Announcement announcement;
@Column(name = "attribute_value")
private String attributeValue;
}
最后是标准:
Criteria ac = session().createCriteria(AnnouncementAttribute.class)
.createAlias("attr", "atrib");
ac.add(Restrictions.and(
Restrictions.eq("atrib.attributeName", "someKey"),
Restrictions.eqOrIsNull("attributeValue", "someValue")));
经过这些更改后,一切正常。我不知道为什么......无论如何我都会进一步调查它,因为它至少很奇怪。也许这与我的应用程序在 Spring Context 中运行、使用 LocalContainerEntityManagerFactoryBean 和 spring-data-jpa 以及通过解包 EntityManager 获得 org.hibernate.Session 对象有关? :
@PersistenceContext
private EntityManager entityManager;
和 session :
private Session session(){
return entityManager.unwrap(Session.class);
}
关于java - EmbeddedId 属性上的 Hibernate Criteria 抛出 org.hibernate.QueryException : could not resolve property,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34941909/
我在执行此代码时遇到问题org.hibernate.QueryException:无法解析属性 def show = { def results = PM.createCriteria().l
我在尝试将条目插入包含地理位置数据的表时遇到问题。事实上,该表仅包含一个地理位置列,一种 Point 数据类型。我正在使用 Java JPA 和 MariaDB。最奇怪的部分是,代码曾经可以工作,但应
我正在使用 FluentNHibernate 和 Linq To Nhibernate,以及这些实体(仅相关部分): public class Player : BaseEntity { pr
我使用 NHiberNate 编写了联合查询,但收到 NHibernate.QueryException:not an Association: Id 这就是 NHibernate 库的样子 Tick
我有一个正在尝试执行的 HQL 查询,但我不断收到 QueryException。 我的查询是 SELECT a FROM (SELECT MAX(m.version) maxVersionOp, m
使用oracle DB,我们创建了一个没有PK的表(我们知道这不是一个好的做法,但我们仍然希望有人可以帮助我们),我们需要使用约束作为替代方案。我们能够将数据插入数据库,不幸的是我们无法检索,因为它会
我关闭了 EclipseLink 缓存,因为我正在外部修改数据,并且不希望遇到手动刷新所有内容的麻烦。显然,这是在 persistence.xml 中关闭缓存以避免对象身份问题的正确方法:
使用 JPA 2.0、Java EE 5、Weblogic 10.3 (11g)、JDK 6、EclipseLink。 当我尝试运行它时: CriteriaQuery _criteriaquery
我已经在本地主机中创建了数据库 Illuminate\Database\QueryException : SQLSTATE[HY000] [1045] Access denied for user
我想通过限制在 Hibernate 中的条件添加订单。 我有两个表 Event 和 MainEvent 与一对多的关系(一个 MainEvent 有很多事件)。 final Criteria
我正在尝试使用 Hibernate 连接到数据库。当前表格具有以下布局: (field1, field2, field3, optional1, optional2...) 其中 field1、fie
这是此错误的另一种情况: 21:22:15,881 ERROR [SessionFactoryImpl] Error in named query: ch.software.gvs.TroubleNo
这是我的查询 SQL_QUERY="SELECT review.comment FROM ReviewDO review WHERE title='"+titleName+"'"; 我试图通过使用标题
我有一个 org.hibernate.QueryException,我很难理解为什么。 hibernate 未解析的属性 langue_id 在我的实体 Conditionnement 中定义。 堆栈
我想在laravel中注册时遇到问题。完成注册表后,我看到此错误消息: QueryException in Connection.php line 770:SQLSTATE[HY000] [1045]
这是我尝试处理重复条目的模型代码: $userData = ['name' => $name, 'email' => $email, 'password' => $password]; publ
我在 Laravel 应用程序中工作,并通过 user_id 列将 users 表与 posts 表相关联。 posts 表中已有 user_id 列。但是当我运行 php artisan db:se
我正面临一种奇怪的问题,不知道该往哪个方向解决;-) 我目前正在开发一个 Web 应用程序,用于使用 Hibernate 存储员工。 插入、删除、搜索;一切正常。 但! 每个员工都有一个由字符串列表表
这是我第一次使用JPA。我用 Java 和 JPA 编写代码。我的代码如下。 String queryStr = "SELECT m.title, b.isbn, b.authors"; q
我正在尝试从当前用户获取特定租金的列表。 Controller 中的代码: def index() { if (isLoggedIn()) { String username = getPri
我是一名优秀的程序员,十分优秀!