所以我有一个数据模型,其中设置了一个表,其中包含一系列对象的NAME
,ID
和CONDITION
列(每个对象都有一个唯一的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连接上所做的研究,我相信这种情况正在发生:
圈子" 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
列。
提前感谢您的回复。
答案 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'