IN子句中的JPA EclipseLink“Characters”

时间:2013-09-03 10:04:51

标签: oracle eclipselink jpql

如何在JPQL中使用JPA的IN子句中的字符? 例如在oracle DB中我有这个查询:

select * from channel o where channel_mode IN ('O','R')

频道模式是DB中的字符列。

我从JPQL收到invalid IN argument[o]的错误,它是一个字符。

@克里斯 这是JPQL:

typeMasterList = em.createQuery("select object(o) from ChannelRequest as o where     o.crqState IN ('O','R') and o.crqMode = 'B' ").getResultList();

实体频道请求是:

@Entity
@Table(name = "CHANNEL_REQUEST")
@XmlRootElement

public class ChannelRequest implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@Basic(optional = false)
@NotNull
@Column(name = "CRQ_ID")
private Long crqId;
@Size(max = 100)
@Column(name = "CRQ_QUEUE")
private String crqQueue;
@Size(max = 160)
@Column(name = "CRQ_DATA")
private String crqData;
@Column(name = "CRQ_STATE")
private Character crqState;
@Column(name = "ACTIVE_FLAG")
private Short activeFlag;
@Column(name = "ENABLED")
private Short enabled;
@Size(max = 100)
@Column(name = "CRQ_ADDRESS")
private String crqAddress;
@Column(name = "CRQ_MODE")
private Character crqMode;
@Column(name = "DCO")
@Temporal(TemporalType.TIMESTAMP)
private Date dco;
@Column(name = "DLUO")
@Temporal(TemporalType.TIMESTAMP)
private Date dluo;
@OneToMany(mappedBy = "rpmrqCrId")
private Collection<RpmRequest> rpmRequestCollection;
@JoinColumn(name = "MM_ID", referencedColumnName = "MM_ID")
@ManyToOne
private MediumMaster mmId;
@JoinColumn(name = "MC_ID", referencedColumnName = "MC_ID")
@ManyToOne
private MediumChannel mcId;`enter code here`

这是我得到的错误: 无效的IN表达式参数[O],类型为[java.lang.Character]

的预期参数

2 个答案:

答案 0 :(得分:1)

JPA规范声明字符串文字用单引号括起来(例如'X'是一个长度为1而不是字符X的字符串)。

看起来在你的情况下,JPQL期望一个字符列表,而不是字符串。您可以通过将字符列表作为参数传入来解决此问题:

typeMasterList = em.createQuery("... o.crqState IN :states ...")
                   .setParameter("states", Arrays.asList('O', 'R'))
                   .getResultList();

旁注:通过使用枚举而不是字符,您可以让您的生活更轻松。然后,您可以直接在查询中引用枚举值而不会出现问题。在数据库级别,枚举仍然可以映射到单个字符。

答案 1 :(得分:0)

您是否尝试使用字符串而不是字符,即“O”,“R”。