โ12-10-2022 03:22 AM
Migrating some on-premise SQL views to Databricks and struggling to find conversions for some functions. the main one is the string_agg function.
string_agg(field_name, ', ')
โ
Anyone know how to convert that to Databricks SQL?
โ
Thanks in advance.
โ12-10-2022 03:24 AM
The rough equivalent would be using collect_set and array_join but note you have lost the order:
Use this โ
SELECT col1, array_join(collect_set(col2), ',') j
FROM tmp
GROUP BY col1
โ
โ12-10-2022 09:40 AM
Hi @Harish Kโ you can use the below query in spark SQL-
%sql
SELECT col1, array_join(collect_set(col2), ',') j
FROM tmp
GROUP BY col1
โ08-06-2024 01:33 PM
Here's a way that preserves ordering. It seems way to complicated to me, I'm hoping there is a more elegant way someone else can provide in a subsequent comment.
%sql
;WITH Blah(col1, i) as
(
SELECT 'abc',1
UNION SELECT 'def',2
UNION SELECT 'ghi',3
)
SELECT
array_join(collect_set(col1), ',') as combined_string
FROM Blah;
--ghi,def,abc
---------------------
--but what if you want to preserve ordering?
;WITH Blah(col1, i) as
(
SELECT 'abc',1
UNION SELECT 'def',2
UNION SELECT 'ghi',3
)
SELECT
ARRAY_JOIN
(
TRANSFORM
(
ARRAY_SORT
(
ARRAY_AGG( (col1, i) ),
(left, right) -> CASE WHEN left.i < right.i THEN -1 WHEN left.i > right.i THEN 1 ELSE 0 END
),
x -> x.col1
),
','
) as combined_string
FROM Blah;
--abc,def,ghi
3 weeks ago
Note: it would be great if support was added for a STRING_AGG function. Here's how simple it is to write the same order-preserving query in Postgres SQL (as an example):
;WITH Blah(col1, i) as
(
SELECT 'abc',1
UNION SELECT 'def',2
UNION SELECT 'ghi',3
)
SELECT STRING_AGG(col1, ',' ORDER BY i ASC)
FROM Blah
2 weeks ago
On a support case there is now a Databricks Aha Idea request created for an order-preserving string_agg function (reference number DB-I-11734).
Join a Regional User Group to connect with local Databricks users. Events will be happening in your city, and you wonโt want to miss the chance to attend and share knowledge.
If there isnโt a group near you, start one and help create a community that brings people together.
Request a New Group