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

时间:2013-07-24 16:48:44

标签: sql jasper-reports inner-join multiple-tables

所以我有一个数据模型,其中设置了一个表,其中包含一系列对象的NAMEIDCONDITION列(每个对象都有一个唯一的ID号)。这些对象的其余属性包含在基于对象类型的几个相应表的列中(每种类型都有一些不同的属性)。所有特定于类型的表都有一个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|

如您所见,NAME与类型或ID和类型之间没有相关性。 我目前正在 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'

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

圈子" 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)

我认为表格表示如下:

| NAME |  HEIGHT  |  WEIGHT  |
------------------------------
|  obj1|  o1height|      null|
|  obj3|      null|  o3weight|
|  obj5|  o5height|      null|

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

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

提前感谢您的回复。

1 个答案:

答案 0 :(得分:3)

您可以通过以下方式使用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'

SQL Fiddle