我有一个Hibernate(JPA)的应用程序,我和Jinq一起使用它.我有一个列出实体的表,我希望用户能够过滤它.表中列出了人员.
@Entity
public class Person {
private String firstName;
private String surName;
@Id
private int id;
public Person() {
}
public Person(final String pFirstName, final String pSurName, final int pID) {
firstName = pFirstName;
surName = pSurName;
id = pID;
}
public int getId() {
return id;
}
public void setId(final int pID) {
id = pID;
}
public String getFirstName() {
return firstName;
}
public void setFirstName(final String pFirstName) {
return firstName = pFirstName;
}
public String getSurName() {
return surName;
}
public void setSurName(final String pSurName) {
surName = pSurName;
}
}
Run Code Online (Sandbox Code Playgroud)
我正在使用JavaFX,但这无关紧要.我尝试的第一件事是用他们的姓氏来过滤这些人.对于过滤,我将Jinq与lambda结合使用.我的过滤代码如下所示:
private List<Person> getFilteredPersons(final String pSurName){
JPAJinqStream<Person> stream = streamProvider.streamAll(Person.class);
stream.where(person -> person.getSurName().contains(pSurName));
List<Person> filteredList = stream.toList();
stream.close();
return filteredList;
}
Run Code Online (Sandbox Code Playgroud)
所以我操作的对象是普通的String.我不认为我的Person类与此有任何关系.我的第一个想法是,你不能boolean contains(...)在lambda中使用该方法,因为当错误出现时,它说:
Caused by: java.lang.IllegalArgumentException: Could not analyze lambda code
Run Code Online (Sandbox Code Playgroud)
所以我的问题是,是否有可能在lambdacode中使用String的contains-method?
您的问题与JPA或lambdas无关,但与jinq有关:它根本不支持转换String.contains()为数据库查询.有关支持的信息,请参见http://www.jinq.org/docs/queries.html#N65890.
| 归档时间: |
|
| 查看次数: |
463 次 |
| 最近记录: |