Discussions
Categories
- 197K All Categories
- 2.5K Data
- 546 Big Data Appliance
- 1.9K Data Science
- 450.8K Databases
- 221.9K General Database Discussions
- 3.8K Java and JavaScript in the Database
- 31 Multilingual Engine
- 552 MySQL Community Space
- 479 NoSQL Database
- 7.9K Oracle Database Express Edition (XE)
- 3.1K ORDS, SODA & JSON in the Database
- 556 SQLcl
- 4K SQL Developer Data Modeler
- 187.2K SQL & PL/SQL
- 21.4K SQL Developer
- 296.4K Development
- 17 Developer Projects
- 139 Programming Languages
- 293K Development Tools
- 110 DevOps
- 3.1K QA/Testing
- 646.1K Java
- 28 Java Learning Subscription
- 37K Database Connectivity
- 158 Java Community Process
- 105 Java 25
- 22.1K Java APIs
- 138.2K Java Development Tools
- 165.3K Java EE (Java Enterprise Edition)
- 19 Java Essentials
- 162 Java 8 Questions
- 86K Java Programming
- 81 Java Puzzle Ball
- 65.1K New To Java
- 1.7K Training / Learning / Certification
- 13.8K Java HotSpot Virtual Machine
- 94.3K Java SE
- 13.8K Java Security
- 205 Java User Groups
- 24 JavaScript - Nashorn
- Programs
- 468 LiveLabs
- 39 Workshops
- 10.2K Software
- 6.7K Berkeley DB Family
- 3.5K JHeadstart
- 5.7K Other Languages
- 2.3K Chinese
- 175 Deutsche Oracle Community
- 1.1K Español
- 1.9K Japanese
- 233 Portuguese
Custom aggregate function: Collapse vertex rows to polyline
Answers
-
Isn't it just a matter of CONCAT them together?
WITH vertices (line_id,part_num,vertex_num,x,y,m) AS (SELECT '001',1,1, 0, 5, 0 FROM dual UNION ALL SELECT '001',1,2,10,10,11.18 FROM dual UNION ALL SELECT '001',1,3,30, 0,33.54 FROM dual UNION ALL SELECT '001',2,1,50,10,33.54 FROM dual UNION ALL SELECT '001',2,2,60,10,43.54 FROM dual), t1 AS (SELECT x coord, line_id, part_num, vertex_num, 1 weight FROM vertices UNION ALL SELECT y , line_id, part_num, vertex_num,2 weight FROM vertices UNION ALL SELECT m , line_id, part_num, vertex_num,3 weight FROM vertices ) , t2 as ( SELECT line_id, part_num , sdo_geometry(2002, NULL, NULL , sdo_elem_info_array(1,2,1) , CAST(collect (coord ORDER BY line_id, part_num, vertex_num,weight) AS sdo_ordinate_array)) line FROM t1 GROUP BY line_id, part_num ) select line_id , sdo_aggr_concat_lines(line) from t2 group by line_id ;