在Hibernate标准结果中排除bean的字段

以下是我从数据库中获取用户bean的方法。

session.createCriteria(User.class).list(); 

返回数据库中的所有用户记录。 有趣的是,我不想从DB获取密码字段。 只想在检索时排除该字段。

我有的选择

1)在其他领域使用投影。 这需要更多的代码添加到投影列表中。 所以放弃了这个想法。

2)使用Sql我需要编写一个手动查询,它会杀死Hibernate的主题。

有可能排除Bean的列值吗?

让我们假设以下是您的POJO:

User.java

 private long id; private String fName; private String lName; // getter - setter of all fields 

现在假设您只想获取idfName字段而不是lName

除了您描述的两种方法之外,还有第三种方法可以实现这一点,它使用HQL。

 Query q1 = session.createQuery("Select new User(id, fName) from User"); List users = q1.list(); 

修改User.java以获得另一个构造函数,如下所示:

 public User(long id, String fName) { this.id = id; this.fName = fName; } 

简而言之,无论您要检索哪个字段,都可以在构造函数和查询中列出它们。

希望这可以帮助。

你可以试试:

 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(); 

参考 : –