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.54.tar.gz (148.3 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.54-py3-none-any.whl (125.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: flyql-0.0.54.tar.gz
  • Upload date:
  • Size: 148.3 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.54.tar.gz
Algorithm Hash digest
SHA256 c2b78254bb4013697b0d8cc452918b1d1d45710dba07b6c308a3dc358cbb4b2a
MD5 4d3362cad756f514f6495c78c431a1be
BLAKE2b-256 5fe9fccbef92bfcbbab52b3470d8f53d98021f69a6d4f2a6b6b1567caae38a64

See more details on using hashes here.

Provenance

The following attestation bundles were made for flyql-0.0.54.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.54-py3-none-any.whl.

File metadata

  • Download URL: flyql-0.0.54-py3-none-any.whl
  • Upload date:
  • Size: 125.2 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.54-py3-none-any.whl
Algorithm Hash digest
SHA256 316b374c8168befcd19976beb7756108b56f0f97d6c575ab47c879119607de06
MD5 5b554c3f2d2dc88e70c1ebe7abf95e4e
BLAKE2b-256 6eac705c3dc898451fb7d667ab7fa22aba19a861320b0498b0a381ee1da9bed5

See more details on using hashes here.

Provenance

The following attestation bundles were made for flyql-0.0.54-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