diff options
| author | Mohammad Sajid Anwar <Mohammad.Anwar@yahoo.com> | 2024-07-16 11:48:42 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-07-16 11:48:42 +0100 |
| commit | c65f28455c8900599032071d018e679d67cbee1f (patch) | |
| tree | 086b3286d7c97a8cda6bb7057e8d3e072fc40cd0 /challenge-278/luca-ferrari/plpgsql/ch-2.sql | |
| parent | 452785082337f497c33a2f9ce1ed96b35d9a3d4c (diff) | |
| parent | d5c82371fcc0e58f01b3457e71d7fff99a709eb4 (diff) | |
| download | perlweeklychallenge-club-c65f28455c8900599032071d018e679d67cbee1f.tar.gz perlweeklychallenge-club-c65f28455c8900599032071d018e679d67cbee1f.tar.bz2 perlweeklychallenge-club-c65f28455c8900599032071d018e679d67cbee1f.zip | |
Merge pull request #10446 from fluca1978/PWC278
PWC 278
Diffstat (limited to 'challenge-278/luca-ferrari/plpgsql/ch-2.sql')
| -rw-r--r-- | challenge-278/luca-ferrari/plpgsql/ch-2.sql | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/challenge-278/luca-ferrari/plpgsql/ch-2.sql b/challenge-278/luca-ferrari/plpgsql/ch-2.sql new file mode 100644 index 0000000000..b271d36da0 --- /dev/null +++ b/challenge-278/luca-ferrari/plpgsql/ch-2.sql @@ -0,0 +1,44 @@ +-- +-- Perl Weekly Challenge 278 +-- Task 2 +-- See <https://perlweeklychallenge.org/blog/perl-weekly-challenge-278> +-- + +CREATE SCHEMA IF NOT EXISTS pwc278; + +CREATE OR REPLACE FUNCTION +pwc278.task2_plpgsql( w text, c char ) +RETURNS text +AS $CODE$ + + WITH letters( l, i ) AS ( + SELECT * + FROM regexp_split_to_table( w, '' ) + WITH ORDINALITY AS v( text, int ) + ) + , first_part AS ( + SELECT l + FROM letters + WHERE i <= position( c IN w ) + ORDER BY l + ) + , second_part AS ( + + SELECT l + FROM letters + WHERE i > position( c IN w ) + ORDER BY i + ) + , all_letters AS ( + SELECT l + FROM first_part + UNION ALL + SELECT l + FROM second_part + ) + SELECT string_agg( l, '' ) + FROM all_letters + ; + +$CODE$ +LANGUAGE sql; |
