- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用带有 Hibernate 的 Java 1.7。
我有下表:
CREATE TABLE public.approvalautoselectionconfig
(
id bigint NOT NULL,
active boolean NOT NULL,
approvalstrategy character varying(255) COLLATE pg_catalog."default",
costcentreid bigint,
createuser bigint,
merchantid bigint,
uri character varying(255) COLLATE pg_catalog."default",
company bytea,
costcentre bytea,
CONSTRAINT approvalautoselectionconfig_pkey PRIMARY KEY (id),
CONSTRAINT approvalautoselectionconfig_costcentreid_fk FOREIGN KEY (costcentreid)
REFERENCES public.lob (lobid) MATCH SIMPLE
ON UPDATE NO ACTION
ON DELETE NO ACTION
NOT VALID,
CONSTRAINT approvalautoselectionconfig_merchantid_fk FOREIGN KEY (merchantid)
REFERENCES public.merchants (merchant_id) MATCH SIMPLE
ON UPDATE NO ACTION
ON DELETE NO ACTION
NOT VALID
)
和
CREATE TABLE public.merchants
(
merchant_id bigint NOT NULL,
company_name character varying(255) COLLATE pg_catalog."default",
trading_as character varying(255) COLLATE pg_catalog."default",
store_name character varying(255) COLLATE pg_catalog."default",
registration_number character varying(50) COLLATE pg_catalog."default",
url character varying(80) COLLATE pg_catalog."default",
receive_email integer,
receive_news integer,
created timestamp without time zone,
bank_mer_id character varying(20) COLLATE pg_catalog."default",
location_id integer,
member_id bigint,
mer_type_id integer,
logourl character varying(200) COLLATE pg_catalog."default",
vatnumber character varying(255) COLLATE pg_catalog."default",
logourllarge character varying(255) COLLATE pg_catalog."default",
autogenerateorder integer,
carsuperwaiver boolean,
carwaivertype character varying(255) COLLATE pg_catalog."default",
logourlsecondary character varying(255) COLLATE pg_catalog."default",
autogenerateordernumberscenario character varying(255) COLLATE pg_catalog."default",
allowtravellercalendar boolean,
auto_email_itinerary_documents integer DEFAULT 0,
email_calendar_appointments integer DEFAULT 0,
personalassistantname integer,
purchaseorder integer,
projectnumber integer,
autovoucher boolean,
autovoucher_email character varying(255) COLLATE pg_catalog."default",
customer_no character varying(255) COLLATE pg_catalog."default",
office_number integer,
viptravellerreason boolean,
CONSTRAINT merchants_pkey PRIMARY KEY (merchant_id),
CONSTRAINT fkd1c98f8b56d4a048 FOREIGN KEY (mer_type_id)
REFERENCES public.merchant_type (merchanttypeid) MATCH SIMPLE
ON UPDATE NO ACTION
ON DELETE NO ACTION
NOT VALID,
CONSTRAINT fkd1c98f8b82f76ace FOREIGN KEY (member_id)
REFERENCES public.members (member_id) MATCH SIMPLE
ON UPDATE NO ACTION
ON DELETE NO ACTION
NOT VALID
)
我有以下实体:
@Entity(name = "ApprovalAutoSelectionConfiguration")
@Table(name = "approvalautoselectionconfig")
@NamedQueries({
@NamedQuery(name = "ApprovalAutoSelectionConfiguration.findByMerchantId", query = "SELECT o FROM ApprovalAutoSelectionConfiguration o, Merchants m WHERE m.merchant_id = o.merchantid AND o.merchantid = ?1"),
@NamedQuery(name = "ApprovalAutoSelectionConfiguration.findByMerchantIdAndUri", query = "SELECT o FROM ApprovalAutoSelectionConfiguration o, Merchants m WHERE m.merchant_id = o.merchantid AND o.merchantid = ?1 AND o.uri = ?2")})
public class ApprovalAutoSelectionConfiguration implements Serializable
{
private static final long serialVersionUID = 1604255007323958024L;
@Id
@SequenceGenerator(allocationSize = 1, name = "seq_approvalautoselectionconfig_id", sequenceName = "seq_approvalautoselectionconfig_id")
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator="seq_approvalautoselectionconfig_id")
private Long id;
private Merchants company;
private Lob costCentre;
private Long createUser;
private String approvalStrategy;
private String uri;
private boolean active;
@OneToMany(fetch=FetchType.EAGER, mappedBy = "approvalAutoSelectionConfiguration",cascade = CascadeType.ALL,
targetEntity = ApprovalAutoSelectionCriteria.class)
private Set<ApprovalAutoSelectionCriteria> approvalCriteriaList;
public Long getId()
{
return id;
}
public void setId(Long id)
{
this.id = id;
}
@OneToOne(cascade = CascadeType.REFRESH, targetEntity = Merchants.class)
@JoinColumn(name = "merchant_id")
public entity.Merchants getCompany()
{
return company;
}
public void setCompany(entity.Merchants company)
{
this.company = company;
}
和
@Entity(name = "Merchants")
//@TableGenerator(name = "merchant_ids", table = "primary_keys", pkColumnName = "key", pkColumnValue = "merchants", valueColumnName = "value")
@NamedQueries({
@NamedQuery(name="Merchants.findAll", query="select o from Merchants as o"),
@NamedQuery(name="Merchants.findByName", query="select o from Merchants as o where o.company_name = ?1"),
@NamedQuery(name="Merchants.findByURI", query="select o from Merchants as o where o.url = ?1"),
@NamedQuery(name="Merchants.findById", query="select o from Merchants as o where o.merchant_id = ?1"),
@NamedQuery(name="Merchants.findAllClients", query="select o from Merchants as o where o.merchantType = ?1 and o.url <> '' and o.url <> '0'")
})
public class Merchants implements Serializable {
private Long merchant_id;
private String company_name;
private String trading_as;
private String store_name;
我正在尝试在 ApprovalAutoSelectionConfiguration 实体中编写一个命名查询,以便在加入商家实体时填充它。
例如:
@NamedQuery(name = "ApprovalAutoSelectionConfiguration.findByMerchantIdAndUri", query = "SELECT o FROM ApprovalAutoSelectionConfiguration o, Merchants m WHERE m.merchant_id = o.merchantid AND o.merchantid = ?1 AND o.uri = ?2")})
但是,我收到以下错误:
Error in named query: ApprovalAutoSelectionConfiguration.findByMerchantIdAndUri: org.hibernate.QueryException: could not resolve property: merchantid of: entity.approval.ApprovalAutoSelectionConfiguration [SELECT o FROM entity.approval.ApprovalAutoSelectionConfiguration o, entity.Merchants m WHERE m.merchant_id = o.merchantid AND o.merchantid = ?1 AND o.uri = ?2] at org.hibernate.persister.entity.AbstractPropertyMapping.propertyException(AbstractPropertyMapping.java:82) [hibernate-core-4.0.0.CR2.jar:4.0.0.CR2]
问题
请您告诉我我做错了什么。我认为问题是我的 @NamedQuery
语法错误或者我的@JoinColumn(name = "merchant_id")
是错误的。
它说无法解析 merchantid
。 ApprovalAutoSelectionConfiguration
实体没有merchantid
,但确实有private Merchants company;
,这是 Merchant
的连接实体。
谢谢
最佳答案
首先,在ApprovalAutoSelectionConfiguration
类中为商户指定外键类型:
@ManyToOne
@JoinColumn(name = "merchantid")
private Merchants company;
那么你必须使用HQL and JPQL写下您的查询:
@NamedQuery(name = "ApprovalAutoSelectionConfiguration.findByMerchantIdAndUri", query = "SELECT o FROM ApprovalAutoSelectionConfiguration o join o.company c WHERE o.merchantid = ?1 AND o.uri = ?2")})
了解如何在 HQL 中使用联接 here .
否则,例如对于您编写的查询,您可以尝试使用@NamedNativeQuery
:https://docs.oracle.com/javaee/7/api/javax/persistence/NamedNativeQuery.html .
关于java - Hibernate @NamedQuery 加入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60668007/
什么是 hibernate 和n- hibernate ?我可以在 Visual Studio 2008 中使用它进行 C# Web 应用程序开发吗?请给我建议...我是 asp.net Web 应用
我有一个不系统地发生的异常(exception)。 我试图通过在每次迭代中刷新和清理 session 来解决此问题,但没有成功。 [quartzScheduler_Worker-7] ERROR jd
使用 Hibernate 在数据库中存储 IP 地址的最佳类型是什么? 我虽然是 Byte[] 或 String,但有没有更好的方法,或者你用什么? @Column(name = "range_fr
我正在尝试制定一个公式来选择用户个人资料的用户友好名称。它选择名字 + ' ' + 姓氏 如果其中至少有一个不为空且不为空(包含非空白字符),否则选择 短名称 (条件相同),最后,如果 短名称 为空或
在hibernate中,是否可以将鉴别器作为一个实体?例如,如果我将 Department 作为基类,将 AdminDepartment 和 ProcessingDepartment 作为子类。 De
我只想从表中获取一些列值。因此,我已经使用投影来实现这一目标。该代码有效,但我认为它无效。 我的问题是当我使用ProjectionsList并将标准条件列表设置为ArrayList时-Bulletin
你好: 我对 hibernate 缓存缓存的内容感到困惑。 从文档中,我知道 hibernate 中有缓存类型。 一级 :交易级别。 似乎要被 session 持久化的实体被缓存在这里。 二级缓存 :
我遇到了一个情况: save或update hibernate 的目标表中的某些数据 在目标表上有一个触发器,该触发器将在目标表的insert或update操作之前执行 由 hibernate 将此记
我有一个名为 Master_Info_tbl 的表。它是一个查询表: 这是该表的代码: @Entity @Table(name="MASTER_INFO_T") public class Code
我想知道如何在 Hibernate 查询语言中使用日期文字。我在我的 JPA 项目中做了如下操作(作为 Eclipselink 提供者)并且它工作正常。 SELECT m FROM Me m WHER
@Entity public class Troop { @OneToMany(mappedBy="troop") public Set getSoldiers() { ...
我正在尝试使用 hibernate 查询删除表 'user_role' 中的所有行。但每次我都会出错。有人可以帮我吗。 DaoImpl @Override public void deleteAll(
不是将数据库操作分散在四个 (osgi) 包中,而是在那里做略有不同的事情。我想创建一个负责所有持久性问题的(简单的)OSGi 包。我觉得这并不像听起来那么简单,因为“每个包都有独特的类加载器”。 因
这就是我使用生成器的方式: private Integer id; 我看到的行为是: 创建第一个对象 hibernate 分配 id = 1 删除该对象 关闭服务
对象级别的实体和值类型有什么区别。我知道实体将有一个 id 但值不会,但为什么我们需要不同的方法来映射实体与值类型? 这样做是为了让hibernate可以对值类型应用任何优化吗? 最佳答案 一个实体已
我正在使用 HibernateTemplate.findByCriteria 方法进行一些查询。现在我想在标准上创建一些 SQL 限制,比如 criteria.add(Restrictions.sql
所以我有以下代码: Query query = session.createQuery("from Weather"); List list = query.list();
如何使用Hibernate映射具有多个实体的 View ? 问候, 混沌 最佳答案 请参见Hibernate文档中第5.1.3节“类”,紧接在“Id”节之前: There is no differen
据我所知,Hibernate 有两种类型的实现 JPA的实现(2)(@Entity,@Table注解) 扩展到旧的(传统的) hibernate (没有 JPA),使用 HSQL 查询,没有注释 如果
我需要一个将条目存储为键值对的集合(因此我可以通过键查找值),但我需要一个允许多个值使用 hibernate 共享同一个键的集合 最佳答案 一个键具有多个值的映射称为多映射 - 在 Apache 公共
我是一名优秀的程序员,十分优秀!