Tương tự như những gì tôi đã trả lời tại câu hỏi trước
của bạn , chỉ với ARRAY of rows
như bạn đã đề xuất và ký hiệu vị trí ngắn hơn:
SELECT DISTINCT ON (1)
p, groundtruth, array_agg(ROW(anchor_id, id)) AS ids
FROM (
SELECT DISTINCT ON (1, 2, 3)
ps.p, m.groundtruth, m.anchor_id, m.id
FROM (SELECT unnest(point_array) AS p) AS ps
JOIN measurement m ON ST_DWithin(ps.p, m.groundtruth, distance)
ORDER BY 1, 2, 3, random()
) x
GROUP BY 1, 2
ORDER BY 1, random();
Nhưng tôi thích phiên bản khác với mảng 2 chiều hơn.