From 1b8474304d47325ea5ed22766842849b1c8c0f44 Mon Sep 17 00:00:00 2001 From: Kasper Marstal Date: Thu, 26 Dec 2024 21:42:14 +0100 Subject: [PATCH 1/2] Update README.md --- README.md | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index fa2284f..1054455 100644 --- a/README.md +++ b/README.md @@ -3,17 +3,17 @@ # PRQL in PostgreSQL! -PL/PRQL is a PostgreSQL extension that lets you write functions with [PRQL](https://prql-lang.org/). The extension supports PostgreSQL v12-16 on Linux and macOS. +PL/PRQL is a PostgreSQL extension that lets you write stored procedures with [PRQL](https://prql-lang.org/). The extension supports PostgreSQL v12-16 on Linux and macOS. ## What is PRQL? -PRQL (Pipelined Relational Query Language) is an open source query language for data manipulation and analysis that compiles to SQL. PRQL introduces a pipeline concept (similar to Unix pipes) that transforms data line-by-line. The sequential series of transformations reduces the complexity often encountered with nested SQL queries and makes your data manipulation logic easier to read and write. +PRQL (Pipelined Relational Query Language) is an open source query language for data manipulation and analysis that compiles to SQL. PRQL introduces a pipeline concept (similar to Unix pipes) that transforms data line-by-line. The sequential series of transformations reduces the complexity often encountered with nested SQL queries and makes your data manipulation logic easier to read and write. With PL/PRQL you can write Procedural Language (PL) functions (stored procedures) with PRQL instead of the traditional PL/pgSQL and combine the simplicity of PRQL with the power of stored procedures. ## Key features -- [Write functions with PRQL](#functions) - Useful for large analytical queries -- [PRQL compiler](#prql-compiler) - Useful for development and debugging -- [Inline execution](#inline-execution) - Useful for prototyping and custom queries in ORMs +- [Write functions with PRQL](#write-functions-with-prql) - Useful for large analytical queries +- [Compile PRQL strings to SQL strings](#compile-prql-strings-to-sql-strings) - Useful for development and debugging +- [Execute PRQL queries](#execute-prql-queries) - Useful for prototyping and custom queries in ORMs -### Functions +### Write functions with PRQL PRQL shines when your SQL queries becomes very long and complex. You can manage this complexity by porting your most impressive SQL incantations to PRQL functions, which can then be used in dashboards, business logic or other database code. For example: ```sql @@ -40,7 +40,7 @@ select * from match_stats(1001) (2 rows) ``` -### PRQL Compiler +### Compile PRQL strings to SQL strings You can use `prql_to_sql()` to see the SQL statements that PostgreSQL executes under the hood. This function invokes the PRQL compiler and shows you the resulting SQL code. Using the example above: ```sql @@ -61,7 +61,7 @@ WHERE _expr_1 > 0 (1 row) ``` -### Inline Execution +### Execute PRQL queries You can run PRQL code directly with the `prql` function. This is useful for e.g. custom queries in ORMs: ```sql From d88c0bd4127a03c6692def30c209e9ed2c8bd42c Mon Sep 17 00:00:00 2001 From: Kasper Marstal Date: Thu, 26 Dec 2024 21:46:03 +0100 Subject: [PATCH 2/2] Update README.md --- README.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 1054455..9f45cc0 100644 --- a/README.md +++ b/README.md @@ -10,11 +10,11 @@ PRQL (Pipelined Relational Query Language) is an open source query language for ## Key features - [Write functions with PRQL](#write-functions-with-prql) - Useful for large analytical queries -- [Compile PRQL strings to SQL strings](#compile-prql-strings-to-sql-strings) - Useful for development and debugging +- [Compile PRQL queries to SQL queries](#compile-prql-queries-to-sql-queries) - Useful for development and debugging - [Execute PRQL queries](#execute-prql-queries) - Useful for prototyping and custom queries in ORMs ### Write functions with PRQL -PRQL shines when your SQL queries becomes very long and complex. You can manage this complexity by porting your most impressive SQL incantations to PRQL functions, which can then be used in dashboards, business logic or other database code. For example: +PRQL shines when your SQL queries becomes long and complex. You can manage this complexity by porting your most impressive SQL incantations to PRQL functions, which can then be used in dashboards, business logic or other database code. For example: ```sql create function match_stats(int) returns table(player text, kd_ratio float) as $$ @@ -40,7 +40,7 @@ select * from match_stats(1001) (2 rows) ``` -### Compile PRQL strings to SQL strings +### Compile PRQL queries to SQL queries You can use `prql_to_sql()` to see the SQL statements that PostgreSQL executes under the hood. This function invokes the PRQL compiler and shows you the resulting SQL code. Using the example above: ```sql @@ -62,7 +62,7 @@ WHERE _expr_1 > 0 ``` ### Execute PRQL queries -You can run PRQL code directly with the `prql` function. This is useful for e.g. custom queries in ORMs: +You can run PRQL code directly with the `prql` function. This is useful for e.g. custom queries in application code: ```sql select prql('from matches | filter player == ''Player1''')