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.52.tar.gz (142.7 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.52-py3-none-any.whl (121.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: flyql-0.0.52.tar.gz
  • Upload date:
  • Size: 142.7 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.52.tar.gz
Algorithm Hash digest
SHA256 9d4d7b4abd7a7d1b9164d3b4d0171becc9718c8dbef0fc903f4e8b39ffb8b2e3
MD5 b6c6c403d4f0ef8cfd67c4cb75b9bf1d
BLAKE2b-256 3780008b4ba39221b7942d80929d7dffd797317fd5591d4e0e1632d35a49f872

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: flyql-0.0.52-py3-none-any.whl
  • Upload date:
  • Size: 121.8 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.52-py3-none-any.whl
Algorithm Hash digest
SHA256 7826435babbe0185b4ab49fb82f57822651cf7a57528a05c0bbaf0c84af2d110
MD5 98dd05f0e3aa6ccd82a7c8a0cc5d7b7b
BLAKE2b-256 6929a8baaa72e845969463f75b1a2bbc822d47d834e1376421363228fecc8248

See more details on using hashes here.

Provenance

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