Bird
Raised Fist0
PostgreSQLquery~20 mins

Why advanced PL/pgSQL matters in PostgreSQL - Challenge Your Understanding

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Challenge - 5 Problems
🎖️
PL/pgSQL Mastery
Get all challenges correct to earn this badge!
Test your skills under time pressure!
query_result
intermediate
2:00remaining
What is the output of this PL/pgSQL function call?
Consider the following PL/pgSQL function that calculates factorial recursively. What will be the output of SELECT factorial(4);?
PostgreSQL
CREATE OR REPLACE FUNCTION factorial(n integer) RETURNS integer AS $$
BEGIN
  IF n <= 1 THEN
    RETURN 1;
  ELSE
    RETURN n * factorial(n - 1);
  END IF;
END;
$$ LANGUAGE plpgsql;
A24
B10
CError: function calls itself infinitely
D1
Attempts:
2 left
💡 Hint
Think about how factorial is defined mathematically and how recursion works.
🧠 Conceptual
intermediate
1:30remaining
Why use PL/pgSQL over plain SQL for complex logic?
Which of the following is the best reason to use PL/pgSQL instead of plain SQL for database operations?
APL/pgSQL automatically creates indexes for tables.
BPL/pgSQL runs faster than SQL for simple SELECT queries.
CPL/pgSQL allows procedural logic like loops and conditionals inside the database.
DPL/pgSQL replaces the need for any SQL queries.
Attempts:
2 left
💡 Hint
Think about what plain SQL can and cannot do inside the database.
📝 Syntax
advanced
2:00remaining
Identify the syntax error in this PL/pgSQL block
What is the syntax error in the following PL/pgSQL code snippet?
PostgreSQL
DO $$
DECLARE
  counter integer := 0;
BEGIN
  WHILE counter < 5 LOOP
    RAISE NOTICE 'Counter is %', counter;
    counter := counter + 1;
  END LOOP;
END;
$$ LANGUAGE plpgsql;
AMissing semicolon after variable declaration
BIncorrect loop syntax
CRAISE NOTICE requires double quotes
DMissing BEGIN keyword
Attempts:
2 left
💡 Hint
Check punctuation after DECLARE section variables.
optimization
advanced
2:00remaining
Which PL/pgSQL approach improves performance for bulk inserts?
You want to insert 10,000 rows efficiently using PL/pgSQL. Which method is best for performance?
AUse a FOR loop with individual INSERT statements inside
BUse RAISE NOTICE to log each insert
CUse EXECUTE inside the loop for each insert
DUse a single INSERT with multiple VALUES rows
Attempts:
2 left
💡 Hint
Minimize the number of separate insert commands.
🔧 Debug
expert
2:30remaining
Why does this PL/pgSQL function raise an exception?
Given this function, why does calling SELECT divide(10, 0); raise an error?
PostgreSQL
CREATE OR REPLACE FUNCTION divide(a integer, b integer) RETURNS numeric AS $$
BEGIN
  RETURN a / b;
END;
$$ LANGUAGE plpgsql;
AFunction syntax is invalid due to missing RETURN type
BDivision by zero error occurs because no check prevents dividing by zero
CPL/pgSQL does not support division operator
DFunction must use EXECUTE for arithmetic operations
Attempts:
2 left
💡 Hint
Think about what happens when dividing by zero in SQL.

Practice

(1/5)
1. What is one main benefit of using advanced PL/pgSQL in PostgreSQL?
easy
A. It replaces the need for any SQL queries.
B. It disables database transactions.
C. It automatically creates user interfaces.
D. It allows writing complex logic inside the database for better performance.

Solution

  1. Step 1: Understand PL/pgSQL purpose

    PL/pgSQL is designed to write procedural code inside PostgreSQL to handle complex logic.
  2. Step 2: Identify the benefit

    Writing logic inside the database improves performance by reducing data transfer and centralizing processing.
  3. Final Answer:

    It allows writing complex logic inside the database for better performance. -> Option D
  4. Quick Check:

    Advanced PL/pgSQL improves performance [OK]
Hint: Think about why logic inside DB helps speed [OK]
Common Mistakes:
  • Thinking PL/pgSQL replaces all SQL queries
  • Confusing PL/pgSQL with UI tools
  • Assuming it disables transactions
2. Which of the following is the correct way to declare a variable in PL/pgSQL?
easy
A. DECLARE myvar INTEGER := 10;
B. myvar INTEGER := 10;
C. DECLARE myvar := 10 INTEGER;
D. VAR myvar INTEGER = 10;

Solution

  1. Step 1: Recall PL/pgSQL variable declaration syntax

    Variables are declared inside a DECLARE block with type and optional initialization.
  2. Step 2: Check each option

    DECLARE myvar INTEGER := 10; correctly uses DECLARE, variable name, type, and initialization. Others have syntax errors.
  3. Final Answer:

    DECLARE myvar INTEGER := 10; -> Option A
  4. Quick Check:

    Variable declaration needs DECLARE and type [OK]
Hint: Remember DECLARE block is mandatory for variables [OK]
Common Mistakes:
  • Omitting DECLARE keyword
  • Placing type after initialization
  • Using VAR instead of DECLARE
3. What will be the output of this PL/pgSQL function?
CREATE OR REPLACE FUNCTION add_numbers(a INTEGER, b INTEGER) RETURNS INTEGER AS $$
BEGIN
  RETURN a + b;
END;
$$ LANGUAGE plpgsql;

SELECT add_numbers(3, 5);
medium
A. 8
B. 35
C. Syntax error
D. NULL

Solution

  1. Step 1: Understand function logic

    The function takes two integers and returns their sum using RETURN a + b.
  2. Step 2: Evaluate the SELECT call

    Calling add_numbers(3, 5) returns 3 + 5 = 8.
  3. Final Answer:

    8 -> Option A
  4. Quick Check:

    3 + 5 = 8 [OK]
Hint: Add the two input numbers as the function returns sum [OK]
Common Mistakes:
  • Concatenating numbers as strings
  • Expecting syntax error due to missing semicolon
  • Assuming NULL return without explicit return
4. Identify the error in this PL/pgSQL block:
DO $$
DECLARE
  counter INTEGER := 0
BEGIN
  counter := counter + 1;
  RAISE NOTICE 'Counter: %', counter;
END;
$$ LANGUAGE plpgsql;
medium
A. Variable counter cannot be initialized
B. RAISE NOTICE syntax is incorrect
C. Missing semicolon after variable declaration
D. LANGUAGE plpgsql is not allowed in DO blocks

Solution

  1. Step 1: Check variable declaration syntax

    In PL/pgSQL, each statement must end with a semicolon. The declaration line lacks a semicolon.
  2. Step 2: Verify other parts

    RAISE NOTICE syntax is correct, variable initialization is allowed, and LANGUAGE plpgsql is required.
  3. Final Answer:

    Missing semicolon after variable declaration -> Option C
  4. Quick Check:

    Statements must end with semicolon [OK]
Hint: Check semicolons after DECLARE lines [OK]
Common Mistakes:
  • Ignoring missing semicolon errors
  • Misreading RAISE NOTICE syntax
  • Thinking variable initialization is disallowed
5. You want to create a PL/pgSQL function that returns the factorial of a number using recursion. Which of these function definitions correctly implements this?
hard
A. CREATE FUNCTION factorial(n INTEGER) RETURNS INTEGER AS $$ BEGIN RETURN n * factorial(n - 1); END; $$ LANGUAGE plpgsql;
B. CREATE FUNCTION factorial(n INTEGER) RETURNS INTEGER AS $$ BEGIN IF n <= 1 THEN RETURN 1; ELSE RETURN n * factorial(n - 1); END IF; END; $$ LANGUAGE plpgsql;
C. CREATE FUNCTION factorial(n INTEGER) RETURNS INTEGER AS $$ BEGIN IF n = 0 THEN RETURN 0; ELSE RETURN n * factorial(n - 1); END IF; END; $$ LANGUAGE plpgsql;
D. CREATE FUNCTION factorial(n INTEGER) RETURNS INTEGER AS $$ BEGIN WHILE n > 1 LOOP RETURN n * factorial(n - 1); END LOOP; END; $$ LANGUAGE plpgsql;

Solution

  1. Step 1: Understand factorial base case

    Factorial of 0 or 1 is 1, so base case must return 1 when n <= 1.
  2. Step 2: Check recursive call correctness

    CREATE FUNCTION factorial(n INTEGER) RETURNS INTEGER AS $$ BEGIN IF n <= 1 THEN RETURN 1; ELSE RETURN n * factorial(n - 1); END IF; END; $$ LANGUAGE plpgsql; correctly returns 1 for base case and multiplies n by factorial(n-1) otherwise.
  3. Step 3: Identify errors in other options

    CREATE FUNCTION factorial(n INTEGER) RETURNS INTEGER AS $$ BEGIN RETURN n * factorial(n - 1); END; $$ LANGUAGE plpgsql; lacks base case, causing infinite recursion. CREATE FUNCTION factorial(n INTEGER) RETURNS INTEGER AS $$ BEGIN IF n = 0 THEN RETURN 0; ELSE RETURN n * factorial(n - 1); END IF; END; $$ LANGUAGE plpgsql; returns 0 for n=0, which is incorrect. CREATE FUNCTION factorial(n INTEGER) RETURNS INTEGER AS $$ BEGIN WHILE n > 1 LOOP RETURN n * factorial(n - 1); END LOOP; END; $$ LANGUAGE plpgsql; misuses WHILE loop and RETURN inside loop.
  4. Final Answer:

    Correctly implements recursive factorial with base case and recursion. -> Option B
  5. Quick Check:

    Base case + recursion needed for factorial [OK]
Hint: Always include base case in recursion [OK]
Common Mistakes:
  • Missing base case causing infinite recursion
  • Returning wrong value for factorial(0)
  • Using loops incorrectly with RETURN inside