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

时间:2014-09-22 09:03:03

标签: java hibernate hql

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

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

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

我有选择

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

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

是否有可能排除Bean的列值?

2 个答案:

答案 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;
    }

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

希望这有帮助。