Skip to main content

A lightweight, injection-proof query language for multi-dialect SQL generation

Project description

FlyQL

A lightweight, injection-proof query language that parses human-readable filter expressions into a portable AST, transpiles to SQL across ClickHouse, PostgreSQL, and StarRocks, and evaluates in-memory.

Installation

pip install flyql

Requires Python 3.10+.

Quick Start

Parse a query

from flyql import parse

result = parse("status = 200 and active")
print(result.root)

Generate SQL

from flyql import parse
from flyql.generators.clickhouse.generator import to_sql_where
from flyql.generators.clickhouse.column import Column

result = parse("status >= 400 and host like 'prod%'")

columns = {
    "status": Column("status", "UInt32"),
    "host": Column("host", "String"),
}

sql = to_sql_where(result.root, columns)
print(sql)

Generators are available for ClickHouse, PostgreSQL, and StarRocks:

from flyql.generators.clickhouse.generator import to_sql_where
from flyql.generators.postgresql.generator import to_sql_where
from flyql.generators.starrocks.generator import to_sql_where

Match in-memory data

from flyql import parse
from flyql.matcher import Evaluator, Record

result = parse("status = 200 and active")

data = {
    "status": 200,
    "active": True,
    "host": "prod-api-01",
}

evaluator = Evaluator()
matches = evaluator.evaluate(result.root, Record(data))
print(f"Matches: {matches}")  # True

Transformers

from flyql import parse
from flyql.generators.clickhouse.generator import to_sql_where
from flyql.generators.clickhouse.column import Column

result = parse("message|upper = 'ERROR'")

columns = {"message": Column("message", "String")}
sql = to_sql_where(result.root, columns)
print(sql)  # equals(upper(message), 'ERROR')

Column parsing

from flyql.columns import parse, parse_to_json

parsed = parse("message, status")
for col in parsed:
    print(f"{col.name} (display: {col.display_name!r}, segments: {col.segments})")

# Enable transformers
with_transforms = parse(
    "message|chars(25) as msg, status", capabilities={"transformers": True}
)

# Serialize to JSON
json_str = parse_to_json("message, status|upper", capabilities={"transformers": True})
print(json_str)

Query Syntax

Queries consist of conditions connected by boolean operators (and, or, not):

status=200 and active and not archived
service!=api or user="john doe"
message~"error.*" and not debug
(a=1 or b=2) and not (c=3 and d=4)
status in [200, 201] and method not in ['DELETE', 'PUT']

Operators

Operator Syntax
Equals =
Not equals !=
Regex match ~
Not regex match !~
Greater than >
Less than <
Greater or equals >=
Less or equals <=
In list in
Not in list not in
Like like
Not like not like
Case-insensitive like ilike
Case-insensitive not like not ilike

Documentation

Full documentation: docs.flyql.dev

License

MIT

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

flyql-0.0.48.tar.gz (124.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

flyql-0.0.48-py3-none-any.whl (109.6 kB view details)

Uploaded Python 3

File details

Details for the file flyql-0.0.48.tar.gz.

File metadata

  • Download URL: flyql-0.0.48.tar.gz
  • Upload date:
  • Size: 124.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for flyql-0.0.48.tar.gz
Algorithm Hash digest
SHA256 38c1b3cd33930aef2516935ecede8451e004745734f95915911814bc83e1b6f6
MD5 a161d882c13d20a9c1e2b1a3e9d0aed8
BLAKE2b-256 9d3159509f5bdb9c2003f86a61b81fd0884f1c32b56a368b94115c26dd89da54

See more details on using hashes here.

Provenance

The following attestation bundles were made for flyql-0.0.48.tar.gz:

Publisher: publish.yaml on iamtelescope/flyql

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flyql-0.0.48-py3-none-any.whl.

File metadata

  • Download URL: flyql-0.0.48-py3-none-any.whl
  • Upload date:
  • Size: 109.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for flyql-0.0.48-py3-none-any.whl
Algorithm Hash digest
SHA256 a228c692219046199c122685176491b7b363aeecb8799e70a2d6158f81d89ccf
MD5 f39540719cdf77575b26ae935e9574ca
BLAKE2b-256 89e0dda4890a1d4c093978c606aef3631ca3a57edc616ab1de592b48faf84770

See more details on using hashes here.

Provenance

The following attestation bundles were made for flyql-0.0.48-py3-none-any.whl:

Publisher: publish.yaml on iamtelescope/flyql

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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