如何使用单个查询将多个对象表中的记录连接到主表?

Sam*_*ton 5 sql inner-join jasper-reports multiple-tables

所以我有一个数据模型,它设置有一个表,其中包含一系列对象的 、 和 列(每个对象都有一个唯一的 ID 号NAMEIDCONDITION这些对象的其余属性包含在基于对象类型的几个相应表的列中(每种类型都有一些不同的属性)。所有特定于类型的表都有一个ID列,以便对象可以与主列表相匹配。

我想编写一个 sql 查询,它将根据与CONDITION唯一的ID.

这是我正在使用的简化示例:

object_master_list
| ID | NAME | CONDITION |
-------------------------
|1234|  obj1|       true|
|0000|  obj2|      false|
|1236|  obj3|       true|
|0001|  obj4|      false|
|5832|  obj5|       true|
|6698|  obj6|      false|
|6699|  obj7|      false|


obj_type_one
| ID | NAME |   HEIGHT   |
-------------------------
|1234|  obj1|    o1height|
|0000|  obj2|    o2height|
|5832|  obj5|    o5height|
|6699|  obj7|    o7height|


obj_type_two
| ID | NAME |   WEIGHT   |
-------------------------
|1236|  obj3|    o3height|
|0001|  obj4|    o4height|
|6698|  obj6|    o6height|
Run Code Online (Sandbox Code Playgroud)

NAME正如您所看到的, and 类型或IDand 类型之间没有相关性。我目前正在iReport工作,我一直在使用查询设计器并根据需要手动编辑它。

现在,示例查询如下所示:

SELECT 
    object_master_list."NAME" AS NAME,
    obj_type_one."HEIGHT" AS HEIGHT,
    obj_type_two."WEIGHT" AS WEIGHT
FROM
    object_master_list INNER JOIN obj_type_one ON object_master_list."ID" =    
obj_type_one."ID"
    INNER JOIN obj_type_two ON obj_type_two."ID" = object_master_list."ID"
WHERE
    object_master_list."CONDITION" = 'true'
Run Code Online (Sandbox Code Playgroud)

我的数据没有返回任何结果。根据我对 sql 连接所做的研究,我相信这种情况正在发生: sql连接问题

其中圆圈“A”代表我的主列表。

iReport 逐行存储和利用从查询返回的值,每列都有一个字段。所以理想情况下我应该这样结束:

$F{NAME} which will receive the following values in succession ("obj1", "obj3", "obj5") 
$F{HEIGHT}  with value series (o1hieght, null, o5height)
$F{HEIGHT} with value series (null, o3weight, null)
Run Code Online (Sandbox Code Playgroud)

我想表格表示如下:

| NAME |  HEIGHT  |  WEIGHT  |
------------------------------
|  obj1|  o1height|      null|
|  obj3|      null|  o3weight|
|  obj5|  o5height|      null|
Run Code Online (Sandbox Code Playgroud)

我的问题是我该如何实现这一目标?

我之前在较小的规模上遇到过这个问题,所以我知道我可以使用子报表或创建多个数据集,但坦率地说,我有很多对象类型,如果可以的话我宁愿不这样做。我也不允许将TYPE列添加到主列表中。

预先感谢您的回复。

Gri*_*aub 2

您可以left join通过以下方式使用:

select o1.name, o2.height, o3.weight
from object_master_list o1 left join obj_type_one o2 on o1.id = o2.id 
                           left join obj_type_two o3 on o1.id = o3.id
where o1.condition = 'true'
Run Code Online (Sandbox Code Playgroud)

SQL小提琴

  • @GrishaWeintraub 感谢您的链接。我还尝试了您的链接,我认为双左连接可能不符合 San 的要求?例如,如果主表的iD从1到10,表一有1-4,表二有6-9,那么双左连接的结果将包括从1-10,我认为这与Sam不同想要 1-4 和 6-9 中的哪一个(没有 5 和 10)? (2认同)