- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我一直在使用标准 MVC 架构(例如域层作为 POJO 和存储库)来设计 Spring Rest api,以从数据库表中获取域数据。到目前为止,这些实体是隔离的,因此设计充当每个实体的单独 RestController、服务和存储库流。我一直在寻求了解领域对象(即 ORM)关联的最佳实践。例如,让我们用下面的伪代码来说明域类(仅用于表达相关设计。我没有提供完整的类):
public class Customer {
@Column
private int id;
@Column;
private String name;
@OneToMany
private List<Order> orders;
//...getters setters
}
public class Order {
@Column
private int id;
@Column;
private String orderNumber;
@OneToMany
private List<Product> products;
@ManyToOne
private Customer customer;
//...getters setters
}
public class Product {
@Column
private int id;
@Column;
private String productName;
@ManyToOne
private Order order;
//...getters setters
}
从设计角度来看我面临的困境。我有以下方法,但很可能都是错误的:
为客户定义一个 RestController 并提供所有 api 资源,例如/customers、/customers/id/orders、/customers/id/orders/id/products 等。拥有一个负责处理这些域的服务。每个域都有单独的 JPARepository。这里“保持简单”的事情是,我为每个域都有单独的存储库,因此我只需在相应的 Repository 类中提供查询方法,以便查找特定域的详细信息,即获取给定客户 ID 的订单。然而,这让我觉得扼杀了使用 ORM 模型的目的,因为我是通过它们的 Repository 类获取各个域。此选项将使所有 3 个存储库类连接到服务类中,我认为这也不是一个好的设计。 3 在这里看起来不错,但在我的实际需求中,ORM 图中有 6 到 7 个域,因此这意味着在一个服务类中 Autowiring 6 个存储库。
一个 RestController 和一个 Service 类,如上面的选项,但 Repository 类也是单一的。仅为客户域创建存储库。通过这种方式,我检索具有其他延迟加载域的客户。这是为了满足“/customers”的 GET 请求。为了满足“/customers/id/orders”的 GET 请求,我将再次使用客户存储库,检索给定 ID 的客户,然后返回订单列表。此外,对于“/customers/id/orders/id/products”的 GET 请求,我需要在 Customer 域中编写手动数据获取机制,以便它负责检索给定 customerId 和 orderId 的产品列表。这样我就使用了一个Repository,满足了使用ORM的目的,然后在Customer域中添加了手动获取数据的方法。我看到的另一个负面因素是,即使我有 customerId 和 orderId 可用,我也需要获取客户域中的完整订单列表。如果我使用单独的订单存储库,我会根据 customerId 和 orderId 获取一个订单。
两者都不正确,但存在更好的方法。
我已经浏览过spring docs用于 ORM 的存储库和 hibernate 文档。我浏览了多个使用 Spring Data Rest 进行一对多映射的教程,但我在不同的教程中发现了混合方法。
这个问题对你来说看起来是重复的,因为我已经阅读了 stackoverflow 上关于这个设计问题的多篇文章,但没有一个答案给我提供了我上面提到的权衡和选项的理由。因此,我重新发布这个问题。
最佳答案
这是一种混合方法。例如在您的情况下,产品实体不需要与订单有 @ManyToOne 关系。想象一下,如果您的产品是 100 万份订单的一部分!您会查询产品多少次来查找订单?您将查询 findOrdersByProduct(Product) 而不是 findProductByOrder(Order)
思考你的用例。有时,如果您永远不会从关系所有者之外获取信息,那么使用一种定向映射是有意义的
考虑一下在查询实体时将获取的数据量(包括联接)。
例如,如果我要获取一个组织,我是否需要获取其所有员工?你的系统会折腾(延迟加载会节省你大部分时间,但如果你有 Angular 那么它会绑定(bind)并获取整个模型)。但与员工实体的组织建立多对一关系确实有意义。
关于java - 为 ORM 域图设计 JPARepository 的最佳实践,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45306819/
这是我的本地域名 http://10.10.1.101/uxsurvey/profile/dashboard 在 Controller 中,我为用户列表设置了一个操作 redirect(control
要处理 Canonical URL,最佳做法是执行 301 重定向还是更好地为 www 和非 www 域使用相同的 IP 地址? 例如: 想要的规范 URL/域是 http://example.com
1 内网基础 内网/局域网(Local Area Network,LAN),是指在某一区域内有多台计算机互联而成的计算机组,组网范围通常在数千米以内。在局域网中,可以实现文件管理、应用软件共享、打印机
1 内网基础 内网/局域网(Local Area Network,LAN),是指在某一区域内有多台计算机互联而成的计算机组,组网范围通常在数千米以内。在局域网中,可以实现文件管理、应用软件共享、打印机
我想创建一个 weblogic 集群,其中有两个托管服务器,每个服务器在物理上独立的远程计算机上运行 根据weblogic文档 All Managed Servers in a cluster mus
我正在运行 grails 3.1.4,但在创建允许我将多个域对象绑定(bind)到其他几个域对象的模式时遇到了问题。作为我正在尝试做的一个例子: 我有三个类(class)。书籍、作者和阅读列表。 作者
我试图使用@count函数来根据它获取数据,但是在没有崩溃报告的情况下它以某种方式崩溃了。 这是代码 class PSMedia: Object { @objc dynamic var id
有谁知道是否有办法只输入字母字符而不输入数字?我想过这样的事情 CREATE DOMAIN countryDomain AS VARCHAR(100) CHECK( VALUE ??? );
我的代码: const checkoutUrl = 'https://example.com/checkout/*' window.onload = startup() function st
一些不是我编写的应用程序,也不是用 PHP 编写的,它为域 www.example.com 创建了一个 cookie。 我正在尝试替换该 cookie。所以在 PHP 中我做到了: setcookie
什么是 oauth 域?是否有任何免费的 oauth 服务?我可以将它用于 StackApps registration 吗? ?我在谷歌上搜索了很多,但找不到答案。 最佳答案 这是redirect_
自从 In October 2009, the Internet Corporation for Assigned Names and Numbers (ICANN) approved the cre
我使用 apache 作为我的应用程序 Web 服务器的代理,并希望即时更改与 sessionid cookie 关联的域名。 该cookie有一个与之关联的.company.com域,我想使用apa
我只想托管一个子域到cloudflare。我不想将主域名的域名服务器更改为他们的域名服务器。真的有可能吗? 最佳答案 是的,这是可能的,但是需要通过CloudFlare合作伙伴进行设置,或者您需要采用
When using socket in the UNIX domain, it is advisable to use path name for the directory directory m
想象两个共享一个域类的 Grails 应用程序。也许是 Book 域类。 一个应用程序被标识为数据的所有者,一个应用程序必须访问域数据。类似于亚马逊和亚马逊网络服务。 我想拥有的应用程序将使用普通的域
我有一个包含字段“URL”的表单。第一部分需要用户在文本框中填写。第二部分是预定义的,显示在文本框的右侧。 例如,用户在文本框中输入“test”。第二部分预定义为“.example.com”。因此,总
如果我要关闭并取消分配 azure 中的域 Controller ,从而生成新的 vm Generationid,我需要采取哪些步骤来恢复它? 最佳答案 what steps do I need to
我想尝试使用 Azure 作为托管提供商(我有一个域)。我读过那篇文章https://learn.microsoft.com/en-us/azure/app-service-web/web-sites
所以.... 我想知道是否有人可以在这方面协助我? 基本上,我已经创建了一个自托管的Docker容器,用作构建代理(Azure DevOps) 现在,我已经开始测试代理,并且由于我们的放置文件夹位于W
我是一名优秀的程序员,十分优秀!