I have 3 tables with data and corresponding intermediate tables:
Example:
select *, ->directions_services->services.* as services from directions;
select *, ->services_responsibles->responsibles.* as responsibles from services;
out:
------Query 1------
[
{
id: directions:first,
...
services: [
{
id: services:serv1,
...
}
]
},
{
id: directions:second,
...
services: []
}
]
------Query 2------
[
{
id: services:serv1,
...
responsibles: [
{
id: responsibles:fj0qqith86mnwszvav2s,
...
},
{
id: responsibles:qfotzpu81j4beza0cd84,
...
}
]
},
{
id: services:serv2,
...
responsibles: []
}
]
How I can get all data in one request?
Example:
[
{
id: directions:first,
...
services: [
[
{
id: services:serv1,
...
responsibles: [
{
id: responsibles:fj0qqith86mnwszvav2s,
...
},
{
id: responsibles:qfotzpu81j4beza0cd84,
...
}
]
},
{
id: services:serv2,
...
responsibles: []
}
]
]
},
{
id: directions:second,
...
services: []
}
]
I tried:
SELECT
*,
(
SELECT
*,
(
SELECT
*
FROM
responsibles
WHERE
<-services_responsibles<-services.id
) AS responsibles
FROM
services
WHERE
<-directions_services<-directions.id
) AS services
FROM
directions;
And I get this:
[
{
id: directions:first,
...
services: [
{
id: services:serv1,
...
responsibles: [
{
id: responsibles:fj0qqith86mnwszvav2s,
...
},
{
id: responsibles:qfotzpu81j4beza0cd84,
...
}
]
}
]
},
{
id: directions:second,
...
services: [
{
id: services:serv1,
...
responsibles: [
{
id: responsibles:fj0qqith86mnwszvav2s,
...
},
{
id: responsibles:qfotzpu81j4beza0cd84,
...
}
]
}
]
}
]
I don't understand why direction 2-d have a service and responsible. BUT!!! I can use this code and get the correct answer:
select *,
<-directions_services<-directions.* as directions,
->services_responsibles->responsibles.* as responsibles
from services;
I've been working with surrealQL and surrealDB recently, don't judge strictly:)
I did it! 😎
$tmp = (select
*,
->services_responsibles->responsibles.* as responsibles
from services);
select
*,
$tmp.filter(|$v| $v.id in ->directions_services->services.id) as services
from directions;