在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
现在假设您只想获取id
和fName
字段而不是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();
参考 : –
- 如何在具有复合PK的实体中使用“findBy”(Hibernate JPA)
- Hibernate实体存储为HttpSession属性值
- 使用Spring Boot和Logback无法避免hibernate将SQL记录到控制台
- Java / Hibernate JPA:InheritanceType.TABLE_PER_CLASS和ID
- 无法创建PoolableConnectionFactory
- 使用TIMESTAMPDIFF的JPA Hibernate公式中的SQL Literal
- Hibernate:如何使用Criteria Query从复合键获取记录
- Oracle hibernate ORA-01461 CLOB
- JBoss Seam:如何在视图中打开jpa / hibernate会话