aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuca Ferrari <fluca1978@gmail.com>2023-05-02 13:38:53 +0200
committerLuca Ferrari <fluca1978@gmail.com>2023-05-03 08:08:15 +0200
commite4adfc4dc5b53f1737acb03decbdfe29f53911a7 (patch)
treeb0c81d6eecfccf4ed009a654783dfbc7a8c969a6
parent6d8b4e1644734f35a7fc570eb409f9db1a22c12b (diff)
downloadperlweeklychallenge-club-e4adfc4dc5b53f1737acb03decbdfe29f53911a7.tar.gz
perlweeklychallenge-club-e4adfc4dc5b53f1737acb03decbdfe29f53911a7.tar.bz2
perlweeklychallenge-club-e4adfc4dc5b53f1737acb03decbdfe29f53911a7.zip
Task 1 plpgsql done
-rw-r--r--challenge-215/luca-ferrari/postgresql/ch-1.sql42
1 files changed, 42 insertions, 0 deletions
diff --git a/challenge-215/luca-ferrari/postgresql/ch-1.sql b/challenge-215/luca-ferrari/postgresql/ch-1.sql
new file mode 100644
index 0000000000..fd7b028c30
--- /dev/null
+++ b/challenge-215/luca-ferrari/postgresql/ch-1.sql
@@ -0,0 +1,42 @@
+--
+-- Perl Weekly Challenge 215
+-- Task 1
+--
+-- See <https://perlweeklychallenge.org/blog/perl-weekly-challenge-215/>
+--
+
+CREATE SCHEMA IF NOT EXISTS pwc215;
+
+CREATE OR REPLACE FUNCTION
+pwc215.task1_plpgsql( words text[] )
+RETURNS SETOF text
+AS $CODE$
+DECLARE
+ current_word text;
+ sorted_word text;
+ current_letter text;
+BEGIN
+ FOREACH current_word IN ARRAY words LOOP
+ /*
+ sorted_word := '';
+ FOR current_letter IN SELECT l FROM regexp_split_to_table( current_word, '' ) l ORDER BY 1 LOOP
+ sorted_word := sorted_word || current_letter;
+ END LOOP;
+ */
+
+ SELECT string_agg( c, '' )
+ INTO sorted_word
+ FROM ( SELECT c
+ FROM regexp_split_to_table( current_word, '' ) c
+ ORDER BY 1
+ ) c;
+
+ IF sorted_word = current_word THEN
+ RETURN NEXT current_word;
+ END IF;
+ END LOOP;
+
+RETURN;
+END
+$CODE$
+LANGUAGE plpgsql;