Ich verwende Spring Boot und Data Rest, um einen einfachen Microservice in Java8 zu erstellen und eine Postgres-Ausnahme zu erhalten.Spring Data Rest: Abfrage "Datum ist Null" löst eine Postgres-Ausnahme aus
Meine Einheit:
@Entity
public class ArchivedInvoice implements Serializable {
...
@Column
private String invoiceNumber;
@Column
private java.sql.Date invoiceDate;
...
}
Meine Repository-Schnittstelle:
@RepositoryRestResource(collectionResourceRel = "archivedinvoices", path = "archivedinvoices")
public interface ArchivedInvoiceRepository extends PagingAndSortingRepository < ArchivedInvoice, Long > {
...
@RestResource(rel = "findByXYZ", path = "findByXYZ")
@Query(value = "SELECT ai FROM #{#entityName} ai WHERE "
+ "(:invoiceNumber IS NULL OR ai.invoiceNumber LIKE :invoiceNumber) AND "
+ "(:invoiceDate IS NULL OR ai.invoiceDate = :invoiceDate)"
)
public Page <ArchivedInvoice> findByXYZ(
@Param("invoiceNumber") @Nullable String invoiceNumber,
@Param("invoiceDate") @Nullable Date invoiceDate,
Pageable p);
...
}
Wenn ich „? .../findByXYZ invoiceDate = 2016.02.22" nennen, ich werde die folgende bekommen Fehlermeldung:
org.springframework.dao.InvalidDataAccessResourceUsageException: could not extract ResultSet; SQL [n/a]; nested exception is org.hibernate.exception.SQLGrammarException: could not extract ResultSet
...
Caused by: org.hibernate.exception.SQLGrammarException: could not extract ResultSet
...
Caused by: org.postgresql.util.PSQLException: FEHLER: could not determine data type of parameter
Aber es funktioniert, wenn ich das entfernen: Teil "invoiceDate IS NULL". Wie kann ich überprüfen, ob der Parameter invoiceDate null ist?
du http://stackoverflow.com/a/27193644/2055854 man versuchen könnte –