当前位置: 首页 > 面试题库 >

Criteria.DISTINCT_ROOT_ENTITY与Projections.distinct

公冶谦
2023-03-14
问题内容

我对hibernate很陌生。我发现我们可以通过以下两种不同方式获得不同的结果。谁能告诉我他们之间有什么区别?什么时候可以使用一个?

Projections.distinct(Projections.property("id"));

criteria.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);

问题答案:

虽然名称相似,但用法不同。

一世。 Projections.distinct(Projections.property("id"));

该语句将转换为SQL语句。它将被传递到DB Engine并作为SQL执行DISTINCT。看到:

  • 17.9。投影,汇总和分组

所以例如这个例子:

List results = session.createCriteria(Cat.class)
    .setProjection( Projections.projectionList()
        .add( Projections.distinct(Projections.property("id")) )
    )
    .list();

看起来像:

SELECT DISTINCT(cat_id) FROM cat_table

二。 criteria.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);

该语句是 事后 执行 。一旦html" target="_blank">返回了来自数据库引擎的SQL查询,Hibernate就会迭代结果集以将其转换为我们的实体列表。

但是是否总是需要它?不,大多数不需要。

唯一的情况是,如果必须在查询中使用关联,则必须使用它-JOINING one-to-manyend。

因为如果我们确实有一个 cat 和它的两个 kittens ,这将返回 2 行,而cat只有 一个:

SELECT cat.*, kitten.*
FROM cat_table as cat 
  INNER JOIN kitten_table kitten ON kitten.cat_id = cat.cat_id

因此,末尾的语句criteriaQuery

... // criteriaQuery joining root and some one-to-many
.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY)

只会列出一只猫。



 类似资料:
  • 在C语言中,假设每个算法被赋予完全相同的一组进程,那么先到先得、最短作业优先和循环之间的周转时间是否相等?还是调度算法不同?

  • 问题内容: 为了为 HTML5 Doctype 定义字符集,我应该使用哪种表示法? 短: 长: 问题答案: 在HTML5中,它们是等效的。使用较短的一个,更容易记住和键入。浏览器支持很好,因为它是为向后兼容而设计的。

  • 连接的多个输入都相当于Yes的时候才会输出Yes。 用法 Your browser does not support the video tag. 案例:小闹钟 功能:今天15:10:00,响起猫叫声小闹钟 工作原理 当所有的输入都是Yes的时候,与节点才输出Yes。

  • 问题内容: 似乎有三种 相同的 方法可以独立于平台获取依赖于平台的“文件分隔符”: 我们如何决定何时使用哪个? 它们之间甚至有什么区别吗? 问题答案: 可以通过调用命令行参数或使用命令行参数覆盖 获取默认文件系统的分隔符。 获取默认文件系统。 获取文件系统的分隔符。请注意,作为一种实例方法,在需要代码在一个JVM中对多个文件系统进行操作的情况下,可以使用该方法将不同的文件系统传递给代码(而不是默认