Как создать CriteriaQuery из SQL-запросаJAVA

Программисты JAVA общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Как создать CriteriaQuery из SQL-запроса

Сообщение Anonymous »

Итак, я пытаюсь создать CriteriaQuery в Java 8, используя этот SQL-запрос:

Код: Выделить всё

SELECT *
FROM SOLICITUDES
ORDER BY CASE WHEN TECNICO = 'test' THEN 0 ELSE 1 END,
CASE WHEN TECNICO = 'test' THEN CREACION_DATE END DESC,
CREACION_DATE DESC;
Но пока безуспешно
Сейчас мой orderBy выглядит так:

Код: Выделить всё

final EntityManager em = getEntityManager();
final Class cl = Solicitud.class;
final CriteriaBuilder cb = em.getCriteriaBuilder();
final CriteriaQuery cq = cb.createQuery(cl);
final Root r = cq.from(cl);

cq.select(r);
cq.orderBy(
cb.asc(
cb.selectCase()
.when(cb.equal(r.get("tecnico"), "test"), 0)
.otherwise(1)
),
cb.desc(
cb.selectCase()
.when(cb.equal(r.get("tecnico"), "test"), r.get("creacionDate"))
),
cb.desc(r.get("creacionDate"))
);

TypedQuery  query = em.createQuery(cq);
return query.getResultList();
Но при загрузке данных я получаю эту ошибку:

Код: Выделить всё

[dpv-web] 2024-03-19 10:05 : [ERROR] {es.juntadeandalucia.cfv.dpv.web.webapp.bean.datamodel.LazyFiltrableDataModelv3.load()} es.juntadeandalucia.cfv.dpv.web.webapp.bean.datamodel.LazyFiltrableDataModelv3 () - Error en la carga de la rejilla
es.juntadeandalucia.cfv.dpv.negocio.exception.DPVNegocioException:  Error no especificado.
at es.juntadeandalucia.cfv.dpv.negocio.bo.impl.SolicitudManagerImpl.consultarElementoByFiltro(SolicitudManagerImpl.java:1891)
at es.juntadeandalucia.cfv.dpv.negocio.bo.impl.SolicitudManagerImpl.consultarElementoByFiltro(SolicitudManagerImpl.java:248)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:333)
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:207)
at com.sun.proxy.$Proxy146.consultarElementoByFiltro(Unknown Source)
at es.juntadeandalucia.cfv.dpv.web.webapp.bean.datamodel.LazySolicitudVODataModel.cargar(LazySolicitudVODataModel.java:263)
at es.juntadeandalucia.cfv.dpv.web.webapp.bean.datamodel.LazySolicitudVODataModel.cargar(LazySolicitudVODataModel.java:203)
at es.juntadeandalucia.cfv.dpv.web.webapp.bean.datamodel.LazyFiltrableDataModelv3.load(LazyFiltrableDataModelv3.java:352)
at org.primefaces.component.datatable.DataTable.loadLazyData(DataTable.java:731)
at org.primefaces.component.datatable.DataTableRenderer.encodeEnd(DataTableRenderer.java:79)
at javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:875)
at com.sun.faces.renderkit.html_basic.HtmlBasicRenderer.encodeRecursive(HtmlBasicRenderer.java:312)
at com.sun.faces.renderkit.html_basic.HtmlBasicRenderer.encodeRecursive(HtmlBasicRenderer.java:309)
at com.sun.faces.renderkit.html_basic.GroupRenderer.encodeChildren(GroupRenderer.java:105)
at javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:845)
at javax.faces.component.UIComponent.encodeAll(UIComponent.java:1756)
at org.primefaces.component.panelgrid.PanelGridRenderer.encodeDynamicBody(PanelGridRenderer.java:92)
at org.primefaces.component.panelgrid.PanelGridRenderer.encodeBody(PanelGridRenderer.java:60)
at org.primefaces.component.panelgrid.PanelGridRenderer.encodeEnd(PanelGridRenderer.java:49)
at javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:875)
at javax.faces.component.UIComponent.encodeAll(UIComponent.java:1763)
at javax.faces.render.Renderer.encodeChildren(Renderer.java:168)
at javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:845)
at com.sun.faces.renderkit.html_basic.HtmlBasicRenderer.encodeRecursive(HtmlBasicRenderer.java:304)
at com.sun.faces.renderkit.html_basic.GroupRenderer.encodeChildren(GroupRenderer.java:105)
at javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:845)
at com.sun.faces.renderkit.html_basic.HtmlBasicRenderer.encodeRecursive(HtmlBasicRenderer.java:304)
at com.sun.faces.renderkit.html_basic.GridRenderer.renderRow(GridRenderer.java:185)
at com.sun.faces.renderkit.html_basic.GridRenderer.encodeChildren(GridRenderer.java:129)
at javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:845)
at javax.faces.component.UIComponent.encodeAll(UIComponent.java:1756)
at javax.faces.component.UIComponent.encodeAll(UIComponent.java:1759)
at javax.faces.component.UIComponent.encodeAll(UIComponent.java:1759)
at com.sun.faces.application.view.FaceletViewHandlingStrategy.renderView(FaceletViewHandlingStrategy.java:401)
at com.sun.faces.application.view.MultiViewHandler.renderView(MultiViewHandler.java:131)
at com.sun.faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:121)
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
at com.sun.faces.life
Моя сущность выглядит так:

Код: Выделить всё

@Entity
@Table(name = "SOLICITUDES")
public class Solicitud implements Serializable, IAuditoriaDTO, IDTO {

private static final long serialVersionUID = -4355851440179505416L;

@Id
@SequenceGenerator(name = "QSOLICITUD_GENERATOR", sequenceName = "SEQ_SOLICITUD",
initialValue = 1, allocationSize = 1)
@GeneratedValue(strategy = GenerationType.SEQUENCE,  generator = "QSOLICITUD_GENERATOR")
@Column(name = "Q_SOLICITUD")
private Long codigo;

@Column(name = "TECNICO")
private String tecnico;

@Temporal(TemporalType.DATE)
@Column(name = "CREACION_DATE")
private Date creacionDate;

public final String getTecnico() {
return tecnico;
}
public final void setTecnico(final String tecnico) {
this.tecnico = tecnico;
}

public final Date getCreacionDate() {
return this.creacionDate = (this.creacionDate == null) ? null : new Date(this.creacionDate.getTime());
}

public final void setCreacionDate(final Date creacionDate) {
this.creacionDate = (creacionDate == null) ? null : (Date) creacionDate.clone();
}
}
Я попробовал несколько вариантов этого и подтвердил, что SQL-запрос работает хорошо. Я совершенно растерян, поэтому буду очень признателен за любой совет или помощь


Подробнее здесь: https://stackoverflow.com/questions/781 ... -sql-query
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «JAVA»