Sam*_*ton 5 sql inner-join jasper-reports multiple-tables
所以我有一个数据模型,它设置有一个表,其中包含一系列对象的 、 和 列(每个对象都有一个唯一的 ID 号NAME)ID。CONDITION这些对象的其余属性包含在基于对象类型的几个相应表的列中(每种类型都有一些不同的属性)。所有特定于类型的表都有一个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 连接所做的研究,我相信这种情况正在发生:

其中圆圈“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列添加到主列表中。
预先感谢您的回复。
您可以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)
| 归档时间: |
|
| 查看次数: |
15676 次 |
| 最近记录: |