- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有 2 个实体 - 电影和 Actor - 具有 M:N 关系。在为这些实体设计 DTO 对象时,我不确定正确的方法是什么。
电影
@Entity
@Table(name = "Movies")
public class Movie extends AbstractBusinessObject {
private String name;
private String short_info;
@ManyToMany
private Map<String, Actor> cast;
}
Actor
@Entity
@Table(name = "Actors")
public class Actor extends Person{
private String name;
@ManyToMany(mappedBy = "cast")
private Set<Movie> movies;
}
现在关于 DTO:我遇到过两种不同的方式来处理 1:N 和 M:N 关系。
仅保存 ID:
public class MovieDto {
private String name;
private String short_info;
// Long represents Actor's ID
private Map<String, Long> cast;
}
然而如前所述here我认为 与其在 EJB 上执行许多远程调用,不如将数据封装在一个值对象中
,这种方法显然违反了规则。
在 DTO 中保存 DTO:另一种方法是存储 Actor 的 Dto,而不是其 ID。
public class MovieDto {
private String name;
private String short_info;
private Map<String, ActorDto> cast;
}
在我看来,这种方法会更快,因为我不必每次需要显示 Actor 姓名时都调用数据库。
这个假设是否正确,还是只存储 ID 会更好(即使考虑到第二种方法的空间消耗)?
此外,第二种方法会导致一个实体有多个 DTO。例如,在查看“电影页面”时我不需要知道 Actor 演过哪些电影,但在查看“ Actor 页面”时我需要知道。
最佳答案
在父 DTO 中嵌入其他 DTO 实例是完全可以接受的。当然,如果对象最终变得非常大,这可能会让人望而却步。因此,这是您必须做出某种权衡的地方。
解决这个问题的一种方法是使用部分表示和完整表示。在不需要完整数据的情况下,可以使用部分表示。在确实需要完整数据的情况下,可以使用完整表示。您甚至可以拥有它,以便完整表示将部分表示嵌入其中(组合)并简单地推迟对其的调用(对于部分数据)。
我之前使用的另一种方法是告诉我的映射器(将实体转换为 DTO)我是否需要完整数据。通过这种方式,映射器可以决定 DTO 是否需要填充额外的数据。
关于java - 具有 M :N or 1:N relationships 的实体的数据传输对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19773753/
我需要将数据从一个表传输到另一台已截断的服务器中的同一个表。最简单的方法是什么? 最佳答案 设置 linked servers然后在目标数据库上使用以下内容: INSERT INTO existing
我尝试从 mysql 服务器获取数据到 ms sql 服务器。我已经在本地主机(使用 ODBC 连接器)中完成了这个过程。 但是现在这些服务器作为在线数据库托管。谁能告诉我这样做的方法吗? 我想我不能
我有一个论坛在这里或http://neue.st/index.php 我想将数据从该论坛转移到不同目录中的新论坛http://neue.st/forums 我也只想选择要传输的数据,例如用户、帖子、主
我正在 Android 操作系统上开发 BLE 应用程序。我必须通过我的应用程序在 BLE 硬件上写入数据。我对必须发送的传输数据的类型感到困惑。下面的图像显示了我必须发送的字节数据。对于每个字节,它
我正在尝试将 RabbitMQ 用于分布式系统,其工作原理如下: 生产者将 JSON 格式的订单 ID 列表放入队列 多个消费者从该队列中取出,使用该订单 ID 执行业务逻辑,并将结果(JSON 格式
我正在将 ARM ComputeLibrary 集成到一个项目中。 这不是我所熟悉的语义的 API,但我正在研究文档和示例。 目前,我正在尝试将 std::vector 的内容复制到 CLTensor
我正在使用面向连接的 channel 开发 BLE 应用程序。我使用 nordic semiconductor nrf52 作为外围设备,iPhone 6 作为中央管理器。 我使用了蓝牙 SIG 提供
我有一个 redis 数据库、logstash 和两个 elasticsearch 和一个 influxdb。我正在将 key 从 redis 传输到 elasticsearch,它工作正常并且想测试
例如,我们在master1上运行一个主节点 在server2,server3上运行的两个数据节点 我们说分片重定位发生在server2到server3之间 现在要复制数据文件夹,elasticsear
基本上,我想做的是创建一个方法,可以采用任何数据类型,并将其转换为 php 识别的数据或 JSON。假设我想传递一个数组、一个二维数组或只是一些基本字符串。我会调用这个函数,传入参数并将其发送到 ph
我们在 UI 中使用 JSF,在业务层中使用 Spring,在持久层中使用 Hibernate。现在我的问题是如何将数据从 JSF UI 传递到 Spring 业务层。我可以直接在支持 bean 中使
我正在构建一个 android 应用程序(使用 java 1.6) - 这是实际的客户端 它向 Windows 计算机发送和接收数据,该计算机托管使用 networkStream 和 socket T
我将编写一个对用户输入使用react并将用户输入数据发送到服务器的应用程序。如果没有互联网连接,应用程序将批量数据并尽快发送。加密并不重要,因为只是发送了一堆关键信息,如果没有相应的真实数据,这些信息
我知道 Javascriptbridge 可以将数据从 js 发送到 tizen。 Is there any way to pass data from native to javascript 最佳
几年前,我编写了一个小实用程序,用于将数据从 Oracle 数据库移动到 Postgres 数据库。我使用 Java 和 JDBC 来完成此任务,因为我希望 Java 处理准备好的语句中使用的数据的数
我最近加入了 Facebook(我知道我迟到了),昨晚我带着一个奇迹醒来。看起来像实时聊天模块大约每秒“寻找”新的应答消息。在我看来,这有点太快了。我不知道他们是如何设法不得到他们的服务器处于事件状态
因此,我正在使用 jdbc 与 MySQL 数据库通信。对于许多表和许多查询/ View ,我创建了一个类,它封装了表的一行或查询/表结果。对 DB 的访问返回此类的一个对象(当我确切知道只有一个匹配
我尝试创建一个在我的虚拟机中运行的程序,以便我可以将数据从目录传输到我的 azure blob 存储帐户。每当我在程序外部(在命令行上)运行该命令时,它都会起作用,但是,如果我运行包含运行该命令的子进
我正在尝试建立一个小型系统,让一台服务器(也称为传感器)在发现另一台服务器(也称为服务器)可用时将数据文件传输到另一台服务器(也称为服务器)(都运行 node.js 应用程序)。 理想情况下,服务器应
我有一个带有两个按钮和两个文本字段的 DialogFragment。 我只希望当我在两个文本字段中输入数据并按下“确定”按钮时,它可以匹配两个字段的数据并将结果保存到 String。 Toast ms
我是一名优秀的程序员,十分优秀!