- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想知道使用 hibernate 是否可以实现以下目标。考虑以下 DTO:
public class ClassDTO {
private String className;
private List<String> studentNames;
//getters & setters
}
以及以下包含 sql 查询的 hbm 文件:
<hibernate-mapping>
<class name="app.ClassDTO">
<id name="className" type="java.lang.String" />
<property name="studentNames" type="java.lang.List" />
</class>
<sql-query name="classQuery">
<return alias="class" class="app.ClassDTO" />
select classTable.CLASS_NAME AS {class.className}, ST.STUDENT_NAME
from CLASS classTable
join STUDENT ST on ST.CLASS_ID=classTable.CLASS_ID
where ST.age<18
</sql-query>
</hibernate-mapping>
如果我们在数据库中运行查询,我们将得到以下结果:
+----------+------------+
|CLASS_NAME|STUDENT_NAME|
+----------+------------+
| CS106 | BILL |
| CS106 | GEORGE |
| CS106 | MICHEL |
| ELEC8 | WILL |
| ELEC8 | MIKE |
| ELEC8 | BETTY |
+----------+------------+
如果我们在 hibernate 中运行查询,我们应该获得 ClassDTO 对象的列表。但是否可以通过以下方式初始化这些对象?
List<ClassDTO> result = getHibernateTemplate.findByNamedQuery("classQuery").;
resul.size(); //<-- the list size should be 2 (one entry for CS106 and another for ELEC8)
result.get(0).getStudentNames().size(); //<-- the size should be 3 for BILL, GEORGE and MICHEL who are linked to the class CS106
我已经搜索了 hibernate 文档,但尚未成功找到任何答案。非常感谢任何帮助。提前谢谢大家。
最佳答案
如果您进一步规范化数据并调整映射,您可以让 Hibernate 自动执行此操作:
<class name="app.ClassDTO">
<id name="className" type="java.lang.String" />
<list name="studentNames" table="class_student">
<key column="class_name" />
<element type="string"/>
</list>
</class>
我承认,如果唯一存在的数据确实是这两列,那么标准化似乎很愚蠢。但在很大程度上,让 Hibernate 自动将平面表数据转换为复杂的对象结构需要遵循某些规则(在这种特殊情况下,我不会将其称为最佳实践)。
如果您想让表保持原样,那么您需要自己创建 ClassDTO,这实际上并不难:
final List<Object[]> resultObjects = getSession().getNamedQuery().list();
public Map<String, ClassDTO> resultMap = new HashMap<>(String, ClassDTO);
for (Object[] result : resultObjects) {
// find ClassDTO in map for class, or create new one
// add student name to class dto instance
}
关于java - 使用 hibernate 命名查询和 spring 填充 DTO 的 List 属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13957324/
我看到 DTO 类型在域模型中的类型内创建并在类型之间传递。这是好习惯吗? 我一直认为 DTO 主要用于上下文边界(即对象图的边缘)以解耦上下文实现(例如域/ui 边界)。 最佳答案 你的问题有点主观
我们将使用 DTO 向表示层发送数据或从表示层发送数据。我们有这样的层: 外观 应用服务 域名 我们使用 Dozer 来帮助我们将实体转换为 dto。但我现在有两个问题: 从entity到dto我们可
我对术语有疑问。根据 Fowler 的说法,DTO 是“在进程之间传输数据以减少方法调用次数的对象”。 (http://martinfowler.com/eaaCatalog/dataTransfer
我们使用 spring-boot 开发的应用程序遵循微服务架构。为了解释这个问题,让我们考虑 3 个不同的服务 A、B、C。服务 A 和 B 也使用服务 C 的一些 API。 我在项目 C(服务 C)
所以基本上我正在编写一个使用 DTO 的 API,但我在返回 DTO 内的另一个实体时遇到了问题。 这是我的 DTO: public class DirectoryDTO { String per
我尝试从方法响应正文中获取派生类字段。请求体参数是基类的类型。请求带有派生类字段,但我无法将其转换为派生类。 这是我的 Controller 方法和 DTO 类: 方法: @PostMapping(
这更多的是一个理论问题,而不是一个实际问题。 我们有一个分层架构,类似于: UI UI_JavaHandler Backend DTO1 需要比 DTO2 多一点的数据,并且恰好是一个额外的字符串
我在 Wildfly 10.1.0-Final 上使用带有 Java 8 和 Hibernate (5.0.X) 的 Java EE 7,我需要使用投影将 JPQL 查询结果加载到 DTO 中,但我找
有一个建议是transfer objects should not contain object references to other transfer objects .相反,他们应该使用其他传输
我们正在开始一个新项目并正在设计 DTO,这些 DTO 将被注入(inject)到具有行为的相应 POCO 中。然而,我能找到的每个 DTO 示例都只包含值类型,例如: public class Cu
这可能是一个一般的java问题 DTO1 属性1 属性2 属性3 DTO2 属性1 属性2 属性3 属性4 属性5 属性6 属性7 属性8 属性9 属性10 属性11 属性12 我将在屏幕上的 gxt
我在一个项目中遇到了一个问题,并在一个裸测试项目中成功地重现了它。 我有以下 dto: public class AppUserDto { public int Id { get; set;
我正在研究 RESTful API,但在为 API 提供输入的过程中遇到了一些麻烦。 假设我有一个可以像这样获取的“人”资源:api/person/{id}并返回一个这样的对象: public cla
我正在使用 DTO 构建我的第一个应用程序 - 我目前有一个 DTO 用于获取特定对象的数据,另一个不同的 DTO 用于更新(PUTting)数据 - 因为只有少数字段可以从任何客户端更新,我决定为
private void writeData(HSSFSheet sheet) { for (int i = 0; i 并动态获取 DTO 属性值?,我们在Stack Overflo
我正在尝试使用 Jackson 和 Kotlin 将 YAML 文档映射到复杂的 DTO 结构,但似乎在某处遇到了误解。 我正在解析的 YAML 文档是 item_names: - item:
这个问题在这里已经有了答案: How to efficiently create a list of objects inside of a generic method? (2 个答案) 关闭 9
我们将使用 DTO 向表示层发送数据或从表示层发送数据。 我在名为 PostAd 的服务对象上有一个方法,它发布用户输入的广告。 Ad 与另一个名为 AdValues 的对象相关联,该对象包含 Ad
我的应用程序服务中有验证逻辑,用于确定请求的操作是否成功,如果没有,原因。我质疑这是否是代码异味,因为它在应用程序服务中而不是域服务中,它围绕检查域模型是否存在、dto 中的属性是否可以为空等展开。代
我有以下域模型: public class Playlist { public long Id { get; set; } public string Title { get; set
我是一名优秀的程序员,十分优秀!