Я хочу задать вопрос, как я могу ОБЪЕДИНИТЬ эти два рекурсивных SELECT вместе в один набор результатов. Спасибо за ответ
WITH sub_tree (Item_id,Item_name,Item_fyz,Item_fyz_hodnotaID)
AS
(Select A.id,A.name,A.fyz1_x_id,A.fyz_hodnota_id
from fyz_hodnota AS A
where A.id = 29
UNION ALL
SELECT BF.id, BF.name,BF.fyz1_x_id, BF.fyz_hodnota_id
from fyz_hodnota AS BF
inner join sub_tree st on st.Item_id = BF.fyz_hodnota_id)
SELECT DISTINCT * from sub_tree
WITH sub_tree (Item_id,Item_name,Item_fyz,Item_fyz_hodnotaID)
AS
(Select A.id,A.name,A.fyz1_x_id,A.fyz_hodnota_id
from fyz_hodnota AS A
where A.id=27
UNION ALL
SELECT BF.id, BF.name,BF.fyz1_x_id, BF.fyz_hodnota_id
from fyz_hodnota BF
inner join sub_tree st on st.Item_fyz_hodnotaID = BF.id)
SELECT * from sub_tree
Объявите 2 CTE в одном и том же пункте WITH
и примените UNION
:
WITH
sub_tree1(Item_id,Item_name,Item_fyz,Item_fyz_hodnotaID) AS (
Select A.id,A.name,A.fyz1_x_id,A.fyz_hodnota_id
from fyz_hodnota AS A where A.id = 29
UNION ALL
SELECT BF.id, BF.name,BF.fyz1_x_id, BF.fyz_hodnota_id
from fyz_hodnota AS BF inner join sub_tree1 st
on st.Item_id = BF.fyz_hodnota_id
),
sub_tree2(Item_id,Item_name,Item_fyz,Item_fyz_hodnotaID) AS (
Select A.id,A.name,A.fyz1_x_id,A.fyz_hodnota_id
from fyz_hodnota AS A
where A.id=27
UNION ALL
SELECT BF.id, BF.name,BF.fyz1_x_id, BF.fyz_hodnota_id
from fyz_hodnota BF inner join sub_tree2 st
on st.Item_fyz_hodnotaID = BF.id
)
SELECT DISTINCT * from sub_tree1
UNION ALL
SELECT * from sub_tree2
ПОЖАЛУЙСТА, НЕ ВОРИ