- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将一些新功能添加到使用 iBatis 的现有应用程序中,但我对其中一个设计决策有些犹豫。
有一个现有的类(称之为 A 类),我想向其添加一些新字段。这些字段将是 B 类型。
查询将通过外部连接连接 B。
所以它会是这样的
public class A {
//... existing fields
private List<B> bList; // may use a Map rather than a list?
// etc.
}
public class B {
private int id; // primary key
private int type;
private String description;
// etc.
我在网络应用程序中使用它。在第一页上,我想返回“A”列表,然后在旁边放置 B 的链接。
例如:
LinktoRecordA1 - LinktoB1 LinktoB2 LinktoB3
LinktoRecordA2 - LinktoB1 LinktoB3
LinktoRecordA3 - LinktoB1 LinktoB2 LinktoB3
LinktoRecordA4
等等
(注意:记录 A4 没有指向任何 B 的链接 - 因此是上面提到的外部连接)
在“A”的初始提取中,我只想知道 B 记录是否存在,它的主键是显示 B 详细记录的链接。所以我的问题是,如果不在“A”对象上创建一个完全填充的“B”列表,我该如何做到这一点?
最佳答案
关于您的评论:
How else should I do it? I think what I'm having trouble understading is
this- should I return a list of "A" objects with only minimal data
populated, or would should I create some kind of new object?
在您描述的情况下(当返回列表并且用户可以从中选择内容时),我注意到用户通常选择一两个记录以查看更多详细信息。在这种情况下,您最终会白白返回一个完全填充的对象列表。
在那种情况下,我所做的是回退到只选择对象标识符而不是完整的对象。
所以你可以创建一个只有这些数据的新类:
public class C {
private Integer idForA;
private List<Integer> listOfIdsForB = new ArrayList<Integer>();
//...
}
然后您使用外连接编写查询以返回 A 和 B 的标识符并返回类似于此的结果:
IDtoRecordA1 | IDtoB1
IDtoRecordA1 | IDtoB2
IDtoRecordA1 | IDtoB3
IDtoRecordA2 | IDtoB1
IDtoRecordA2 | IDtoB3
IDtoRecordA3 | IDtoB1
IDtoRecordA3 | IDtoB2
IDtoRecordA3 | IDtoB3
IDtoRecordA4 | null
在这个阶段,resultMap
标签的 groupBy
属性会派上用场,可以将结果转换为包含以下内容的 C
对象列表:
C1: IDtoRecordA1, [IDtoB1, IDtoB2, IDtoB3]
C2: IDtoRecordA2, [IDtoB1, IDtoB3]
C3: IDtoRecordA3, [IDtoB1, IDtoB2, IDtoB3]
C4: IDtoRecordA4, []
这对于避免 N+1 查询也非常有用。当您返回带有 B 列表的 A 对象时,您可能已经这样做了,但是如果您使用单独的查询来检索列表(即 result
标记上的 select
属性),我建议您查看 iBatis Data Mapper 开发人员指南中的“避免 N+1 选择”部分,以最大程度地减少返回数据所需的查询数量。
底线是...
...如果您处理大量数据,那么返回完全加载的对象只是为了显示少量信息,这可能有点矫枉过正。
..另一方面,如果您处理少量数据,引入另一个处理 ID 的类可能会使事情复杂化,因此您最好返回 A 的完整对象和 B(当然要避免 N+1 查询)。
关于java - iBatis - 标题细节问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2061004/
前言 本文主要介绍了关于MySQL主键为0与主键自排约束的关系,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。 开始不设置主键表的设计如下: 如果id的位置有好几个0
我已经阅读了一些关于将消息从一个线程冒泡到所有其他线程以正常退出的正确方法的来源(每个线程都执行它自己的退出例程)。其中,我喜欢全局原子 bool 值的想法,它可以从任何线程进行标记,所有其他线程检查
本文深入探讨Go语言中的流程控制语法,包括基本的 if-else 条件分支、 for 循环、 switch-case 多条件分支,以及与特定数据类型相关的流程控制,如 for-r
我是 MVC 和 XCode 的新手,在将我对 MVC 的概念理解转化为设计和实现具体类时遇到了困难。我希望就如何构建 Controller 和 View 以获得预期的 UI 获得一些建议。这是针对
如果我尝试在 View 中打开 DeatilFragement,我的应用程序崩溃并收到以下错误: Caused by: java.lang.IllegalStateException: Require
我正在尝试构建我的 iOS 应用程序的界面。一遍又一遍地开始新项目我仍然遇到细节 View 控件的问题(见图)。 在这里我得到了截图: 详细 View 显示当用户触摸 UITableView 行时。您
我在与我正在处理的项目的类(class)中遇到问题。该类是一个接受标签和值的 GUI 组件。这里的想法是,用户可以指定一个标签,然后从任何地方链接一个值(更具体地说,该值的 ToString 方法),
嗯.. 我在我的应用程序中设置了表格 View - 详细 View 。 主视图使用常规代码将数据传递给详细 View - (void)tableView:(UITableView *)tableVie
我有 celery 任务,队列中有 100 个输入数据,需要使用 5 个 worker 来执行。 如何获取哪个工作人员正在执行哪个输入? 每个 worker 执行了多少输入及其状态? 如果任何任务失败
我有一个 .net github 项目,它基本上是一个 Web API 的包装器。在测试项目中,我使用 API key 调用 API。我需要将此 key 保密,如何在 Visual Studio 项目
我遇到一个问题,从 Ag-Grid 导出网格只会导出主网格的详细信息,而不会导出子网格。这是一个显示问题的 plunkr: https://next.plnkr.co/edit/jVcvWDJ1NKP
我在详细 View 中有一个不会消失的额外空间。该 View 来自 NavigationLink,但我已经尝试过使用或不使用 NavigationView。我试图包装它用 NavigationView
几天来,我一直在关注猫效应和 IO。我觉得我对这种效果有一些误解,或者只是我错过了它的重点。 首先——如果IO可以替代Scala的Future,我们如何创建异步IO任务?使用 IO.shift ?使用
如何将标高添加到主视图/详细 View 的详细信息 Pane 中,以在其下方提供阴影,同时定位为部分覆盖工具栏(如下面的底部图片)?我尝试使用 android:elevation="4dp" 但这对我
我试图在我的 UISplitViewController 的细节 View 上设置一个阴影,我希望在 iOS 6 中的主 View 上可见。 在我的细节 View Controller 中: sel
我正在阅读 std::basic_string::reserve(size_type res_arg=0) 上的标准.它是这样说的: void reserve(size_type res_arg=0)
Boost 文档说 Starting with Boost release 1.53, shared_ptr can be used to hold a pointer to a dynamicall
我用 OpenGL 编写了一个简单的 24 位位图加载器。我打开一个位图文件并读取它的像素,然后从中创建一个 RGB 像素数据数组,然后将其传递给 glDrawPixels()。 问题:我需要使图像的
for x in ...循环 就是把每个元素代入变量x,然后执行缩进块的语句。 range()函数,可以生成一个整数序列,再通过list()函数可以转换为list。 比如我们想计算1-10的整数
场景 我有一个 DevExpress XtraGrid。 显示的数据采用主/详细信息格式,点击行开头的“+”可展开该主行的详细信息。 我通过将网格数据源绑定(bind)到包含自己的字典属性(以保存详细
我是一名优秀的程序员,十分优秀!