aboutsummaryrefslogtreecommitdiff
path: root/challenge-263/luca-ferrari/plpgsql
diff options
context:
space:
mode:
authorLuca Ferrari <fluca1978@gmail.com>2024-04-04 13:03:27 +0200
committerLuca Ferrari <fluca1978@gmail.com>2024-04-04 15:05:03 +0200
commit44a92ee6dd0ca577889cc1489e1237d5084a1efc (patch)
tree49d7ea43e0763e88f5812ddb0932336209f02b97 /challenge-263/luca-ferrari/plpgsql
parentc2aa18d20881e4079d3858c0218ff99a07032d33 (diff)
downloadperlweeklychallenge-club-44a92ee6dd0ca577889cc1489e1237d5084a1efc.tar.gz
perlweeklychallenge-club-44a92ee6dd0ca577889cc1489e1237d5084a1efc.tar.bz2
perlweeklychallenge-club-44a92ee6dd0ca577889cc1489e1237d5084a1efc.zip
PWC 263
Task 1 Raku done Task 2 Raku done Task 1 PL/Perl done Task 2 PL/Perl done Task 1 PL/PgSQL done Task 2 PL/PgSQL done Task 1 PL/Java done Task 2 PL/Java done Task 1 Python done Task 2 PYthon done
Diffstat (limited to 'challenge-263/luca-ferrari/plpgsql')
-rw-r--r--challenge-263/luca-ferrari/plpgsql/ch-1.sql21
-rw-r--r--challenge-263/luca-ferrari/plpgsql/ch-2.sql45
2 files changed, 66 insertions, 0 deletions
diff --git a/challenge-263/luca-ferrari/plpgsql/ch-1.sql b/challenge-263/luca-ferrari/plpgsql/ch-1.sql
new file mode 100644
index 0000000000..94d1bc7dc0
--- /dev/null
+++ b/challenge-263/luca-ferrari/plpgsql/ch-1.sql
@@ -0,0 +1,21 @@
+--
+-- Perl Weekly Challenge 263
+-- Task 1
+-- See <https://perlweeklychallenge.org/blog/perl-weekly-challenge-263>
+--
+
+CREATE SCHEMA IF NOT EXISTS pwc263;
+
+CREATE OR REPLACE FUNCTION
+pwc263.task1_plpgsql( k int, nums int[] )
+RETURNS SETOF int
+AS $CODE$
+
+ SELECT x
+ FROM (
+ SELECT v, row_number() over ( order by v ) as x
+ FROM unnest( nums ) v
+ WHERE v = k
+ )
+$CODE$
+LANGUAGE sql;
diff --git a/challenge-263/luca-ferrari/plpgsql/ch-2.sql b/challenge-263/luca-ferrari/plpgsql/ch-2.sql
new file mode 100644
index 0000000000..ed18e9b8e2
--- /dev/null
+++ b/challenge-263/luca-ferrari/plpgsql/ch-2.sql
@@ -0,0 +1,45 @@
+--
+-- Perl Weekly Challenge 263
+-- Task 2
+-- See <https://perlweeklychallenge.org/blog/perl-weekly-challenge-263>
+--
+
+CREATE SCHEMA IF NOT EXISTS pwc263;
+
+CREATE OR REPLACE FUNCTION
+pwc263.task2_plpgsql( i int[], j int[] )
+RETURNS TABLE( item int, qty int )
+AS $CODE$
+DECLARE
+
+BEGIN
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS q( item int, qty int );
+ TRUNCATE TABLE q;
+
+ FOR x IN 1 .. array_length( i, 1 ) LOOP
+ IF mod( x, 2 ) = 0 THEN
+ CONTINUE;
+ END IF;
+ INSERT INTO q( item, qty )
+ VALUES ( i[ x ], i[ x + 1 ] );
+
+ END LOOP;
+
+ FOR x IN 1 .. array_length( j, 1 ) LOOP
+ IF mod( x, 2 ) = 0 THEN
+ CONTINUE;
+ END IF;
+ INSERT INTO q( item, qty )
+ VALUES ( j[ x ], j[ x + 1 ] );
+
+ END LOOP;
+
+ RETURN QUERY
+ SELECT q.item, sum( q.qty )::int
+ FROM q
+ GROUP BY q.item;
+
+END
+$CODE$
+LANGUAGE plpgsql;