PostgreSQL

PL/PRQL is a PostgreSQL extension that lets you write functions with PRQL.

PL/PRQL functions serve as intermediaries, compiling the user’s PRQL code into SQL statements that PostgreSQL executes. The extension is based on the pgrx framework for developing PostgreSQL extensions in Rust. This framework manages the interaction with PostgreSQL’s internal APIs, type conversions, and other function hooks necessary to integrate PRQL with PostgreSQL.

Examples

PL/PRQL functions are defined using the plprql language specifier:

  1. create function match_stats(int) returns table(player text, kd_ratio float) as $$
  2. from matches
  3. filter match_id == $1
  4. group player (
  5. aggregate {
  6. total_kills = sum kills,
  7. total_deaths = sum deaths
  8. }
  9. )
  10. filter total_deaths > 0
  11. derive kd_ratio = total_kills / total_deaths
  12. select { player, kd_ratio }
  13. $$ language plprql;
  14. select * from match_stats(1001)
  15. player | kd_ratio
  16. ---------+----------
  17. Player1 | 0.625
  18. Player2 | 1.6
  19. (2 rows)

You can also run PRQL code directly with the prql function which is useful for custom SQL in ORMs:

  1. select prql('from matches | filter player == ''Player1''')
  2. as (id int, match_id int, round int, player text, kills int, deaths int)
  3. limit 2;
  4. id | match_id | round | player | kills | deaths
  5. ----+----------+-------+---------+-------+--------
  6. 1 | 1001 | 1 | Player1 | 4 | 1
  7. 3 | 1001 | 2 | Player1 | 1 | 7
  8. (2 rows)
  9. -- Same as above without the need for the static types, but returns cursor
  10. select prql('from matches | filter player == ''Player1''', 'player1_cursor');
  11. fetch 2 from player1_cursor;

Getting Started

For installation instructions and more information on the extension, see the PL/PRQL repository.