Skip to main content

An interpreted relational query language that compiles to SQL

Project description

alt text

Preql (pronounced: Prequel) is an interpreted relational query language.

It is designed for use by data engineers, analysts and data scientists.

  • Compiles to SQL at runtime. It has the performance and abilities of SQL, and much more.

    • Support for Postgres, MySQL and Sqlite. (more planned!)

    • Escape hatch to SQL, for all those database-specific features we didn't think to include

  • Programmer-friendly syntax and semantics, with gradual type-checking, inspired by Typescript and Python

  • Interface through Python, HTTP or a terminal environment with autocompletion

Note: Preql is still work in progress, and isn't ready for production use, or any serious use yet

Documentation

Read here

Get started

Simply install via pip:

    pip install -U prql

Then just run the interpreter:

    preql

Requires Python 3.8+

Read more

Quick Example

// Sum up all the squares of an aggregated list of numbers
// Grouped by whether they are odd or even
func sqrsum(x) = sum(x * x)
func is_even(x) = x % 2 == 0

print [1..100]{
        is_even(item) => sqrsum(item)
      }
// Result is:
┏━━━━━━━━━┳━━━━━━━━┓
 is_even  sqrsum 
┡━━━━━━━━━╇━━━━━━━━┩
       0  166650 
       1  161700 
└─────────┴────────┘

In the background, this was run by executing the following SQL code (reformatted):

  WITH range1 AS (SELECT 1 AS item UNION ALL SELECT item+1 FROM range1 WHERE item+1<100)
     , subq_3(is_even, sqrsum) AS (SELECT ((item % 2) = 0) AS is_even, SUM(item * item) AS sqrsum FROM range1 GROUP BY 1)
  SELECT * FROM subq_3

License

Preql uses an “Interface-Protection Clause” on top of the MIT license.

See: LICENSE

In simple words, it can be used for any commercial or non-commercial purpose, as long as your product doesn't base its value on exposing the Preql language itself to your users.

If you want to add the Preql language interface as a user-facing part of your commercial product, contact us for a commercial license.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

prql-0.1.12.tar.gz (69.0 kB view details)

Uploaded Source

Built Distribution

prql-0.1.12-py3-none-any.whl (78.3 kB view details)

Uploaded Python 3

File details

Details for the file prql-0.1.12.tar.gz.

File metadata

  • Download URL: prql-0.1.12.tar.gz
  • Upload date:
  • Size: 69.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.2 CPython/3.8.2 Windows/10

File hashes

Hashes for prql-0.1.12.tar.gz
Algorithm Hash digest
SHA256 0d6ef7827c2b1654cf98091ba0a79c52c728e48574373762d62a0d3bd330af99
MD5 82bbf995aca73ea98daa9548245c9d04
BLAKE2b-256 296b9b1f0fb4b7cd28d0f148611e9a5aca9da5df72d91c74ee92c9f9fe9c75c9

See more details on using hashes here.

File details

Details for the file prql-0.1.12-py3-none-any.whl.

File metadata

  • Download URL: prql-0.1.12-py3-none-any.whl
  • Upload date:
  • Size: 78.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.2 CPython/3.8.2 Windows/10

File hashes

Hashes for prql-0.1.12-py3-none-any.whl
Algorithm Hash digest
SHA256 535b733f934d0f9bbcadc5332caf37716799063c11c3d47b98d606bf1ad3425f
MD5 1869e921e2e646e2e90e8e3f60139853
BLAKE2b-256 e0a3bf707fa134fe78cf02f2bb483e9240a926def4cc7a17b4fe0f914fa57310

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page