Использование BETWEEN в собственном запросе в JPQL

Я пытался сделать запрос, используя BETWEEN в JPQL, я уже протестировал его в SQL, и он работает, но когда я реализовал в JPQL, я получил ошибку:

Caused by: javax.persistence.PersistenceException: 
Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.7.0.v20170811-d680af5): 
org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: com.microsoft.sqlserver.jdbc.SQLServerException: 
Incorrect syntax near ':'.
Error Code: 102"

Я не понимаю, почему рядом с : ошибка, кто-нибудь может помочь мне разобраться?

Вот мой код:

public List<Object[]> reportPendapatan(String tahun) {
    String tahun1 = tahun +"-01-01";
    String tahun2 = tahun +"-12-31";
    return em.createNativeQuery("SELECT p.tanggal, m.nama, pg.nama_jenis, g.nama_guru,pg.harga_masuk FROM Pendaftaran p, Murid m, pengajian pg, Guru g  WHERE p.id_murid = m.id_murid and p.tanggal between :tahun and :tahun2 and p.id_guru = g.id_guru and p.id_jenis = pg.id_jenis and p.status=4")       
            .setParameter("tahun", tahun1)
            .setParameter("tahun2", tahun2)
            .getResultList(); 
}

person newbie3    schedule 07.09.2020    source источник
comment
Что такое JSQL? Вы имеете в виду JPQL?   -  person a_horse_with_no_name    schedule 07.09.2020


Ответы (1)


Согласно этот ответ, EclipseLink имеет немного другой синтаксис установки именованных параметров в собственных запросах с использованием префикса ? вместо :

public List<Object[]> reportPendapatan(String tahun) {
    String tahun1 = tahun +"-01-01";
    String tahun2 = tahun +"-12-31";
    return em.createNativeQuery(
        "SELECT p.tanggal, m.nama, pg.nama_jenis, g.nama_guru,pg.harga_masuk "
        + "FROM Pendaftaran p, Murid m, pengajian pg, Guru g "
        + "WHERE p.id_murid = m.id_murid and p.tanggal between ?tahun and ?tahun2 "
        + "and p.id_guru = g.id_guru and p.id_jenis = pg.id_jenis and p.status=4")
        .setParameter("tahun", tahun1)
        .setParameter("tahun2", tahun2)
        .getResultList(); 
}

Другой вариант — использовать позиционные параметры 1 и 2 для tahun1 и tahun2 соответственно:

    // ...
    return em.createNativeQuery(
        "SELECT p.tanggal, m.nama, pg.nama_jenis, g.nama_guru,pg.harga_masuk "
        + "FROM Pendaftaran p, Murid m, pengajian pg, Guru g "
        + "WHERE p.id_murid = m.id_murid and p.tanggal between ? and ? "
        + "and p.id_guru = g.id_guru and p.id_jenis = pg.id_jenis and p.status=4")
        .setParameter(1, tahun1)
        .setParameter(2, tahun2)
        .getResultList(); 

person Alex Rudenko    schedule 07.09.2020