以下是我从数据库获取用户bean的方法。
session.createCriteria(User.class).list();
返回数据库中的所有用户记录。有趣的是,我不想从DB获取密码字段。只想在检索时排除该字段。
我有选择
1)在其他领域使用投影。这需要更多的代码添加到投影列表中。所以放弃了这个想法。
2)使用Sql我需要编写一个手动查询,它会杀死Hibernate的主题。
是否有可能排除Bean的列值?
答案 0 :(得分:8)
你可以尝试:
Example example = Example.create(cat)
.excludeZeroes() //exclude zero valued properties
.excludeProperty("color") //exclude the property named "color"
.ignoreCase() //perform case insensitive string comparisons
.enableLike(); //use like for string comparisons
List results = session.createCriteria(Cat.class)
.add(example)
.list();
参考: -
答案 1 :(得分:5)
我们假设以下是您的POJO:
<强> User.java 强>
private long id;
private String fName;
private String lName;
// getter - setter of all fields
现在假设您只想获得id
&amp; fName
字段而非lName
。
除了您所描述的两种方法之外,还有第三种实现此目的的方法,即使用HQL。
Query q1 = session.createQuery("Select new User(id, fName) from User");
List<User> users = q1.list();
修改 User.java 以获得另一个构造函数,如下所示:
public User(long id, String fName)
{
this.id = id;
this.fName = fName;
}
简而言之,无论您要检索哪个字段,都可以在构造函数和查询中列出它们。
希望这有帮助。