Я пытаюсь отфильтровать listPage по дате и идентификатору пользователя.Из таблицы данных выбранный идентификатор пользователя и значение даты передаются в listPage с тегом f: param.На странице списка отображается сообщение об ошибке «значение должно быть датой», а фильтр не работает.Это работает, если его просто отфильтровать по идентификатору пользователя без даты.Что я могу делать не так?или как мне заставить это работать?Я также пытался использовать конвертер даты шва JBoss, который тоже не работает.
Вот мой код:
firstPage.xhtml
<h:column>
<f:facet name="header">Date</f:facet>
<h:outputText value="#{_auditEventFact[3]}">
</h:outputText>
</h:column>
<rich:column styleClass="action">
<f:facet name="header">Action</f:facet>
<s:link value="View" view="/AuditEventFactList.xhtml" action="# auditEventFactList.lookUpUserAuditRecords()}">
<f:param name="userid" value="#{_auditEventFact[1]}"/>
<f:param name="ntimestamp" value="#{_auditEventFact[3]}"/>
</s:link>
</rich:column>
pages.xml
<param name="from"/>
<param name="userid" value="#{auditEventFactList.auditEventFact.userid}"/>
<param name="ntimestamp" value="#{auditEventFactList.auditEventFact.ntimestamp}" converterId="javax.faces.DateTime"/>
ListAction.java
private static final String EJBQL = "select auditEventFact from AuditEventFact auditEventFact";
private static final String[] RESTRICTIONS = {
"lower(auditEventFact.userid) like concat(lower(#{auditEventFactList.auditEventFact.userid}),'%')",
"auditEventFact.ntimestamp = #{auditEventFactList.auditEventFact.ntimestamp}",
"lower(auditEventFact.auditid) like concat(lower(#{auditEventFactList.auditEventFact.auditid}),'%')", };
private AuditEventFact auditEventFact = new AuditEventFact();
public AuditEventFactList() {
setEjbql(EJBQL);
setRestrictionExpressionStrings(Arrays.asList(RESTRICTIONS));
setMaxResults(25);
}
EntityBean.java
@Temporal(TemporalType.TIMESTAMP)
@Column(name="NTIMESTAMP#", length=11)
public Date getNtimestamp() {
return this.ntimestamp1;
}
public void setNtimestamp(Date ntimestamp1) {
this.ntimestamp1 = ntimestamp1;
}