manifoldb-query 0.1.4

Query parsing, planning, and execution for ManifoldDB
Documentation
//! `ManifoldDB` Query
//!
//! This crate provides query parsing, planning, and execution for `ManifoldDB`.
//!
//! # Overview
//!
//! The query system consists of several layers:
//!
//! - **AST**: Abstract syntax tree representation of parsed queries
//! - **Parser**: SQL parser with graph and vector extensions
//! - **Plan**: Query planning (logical and physical plans)
//! - **Exec**: Query execution engine
//!
//! # Modules
//!
//! - [`ast`] - Query abstract syntax tree types
//! - [`parser`] - SQL parser with graph/vector extensions
//! - [`plan`] - Query planning (logical and physical)
//! - [`exec`] - Query execution
//! - [`error`] - Error types for parsing and execution
//!
//! # Quick Start
//!
//! Parse a simple SQL query:
//!
//! ```
//! use manifoldb_query::parser::parse_sql;
//!
//! let statements = parse_sql("SELECT * FROM users WHERE id = 1").unwrap();
//! ```
//!
//! Parse a query with graph patterns:
//!
//! ```
//! use manifoldb_query::parser::ExtendedParser;
//!
//! let statements = ExtendedParser::parse(
//!     "SELECT * FROM users MATCH (u)-[:FOLLOWS]->(f) WHERE u.id = 1"
//! ).unwrap();
//! ```
//!
//! Build AST programmatically:
//!
//! ```
//! use manifoldb_query::ast::{
//!     Expr, QualifiedName, SelectItem, SelectStatement, TableRef,
//! };
//!
//! let query = SelectStatement::new(vec![SelectItem::Wildcard])
//!     .from(TableRef::table(QualifiedName::simple("users")))
//!     .where_clause(
//!         Expr::column(QualifiedName::simple("id"))
//!             .eq(Expr::integer(1))
//!     );
//! ```
//!
//! Build a logical plan from a parsed query:
//!
//! ```
//! use manifoldb_query::parser::parse_single_statement;
//! use manifoldb_query::plan::logical::PlanBuilder;
//!
//! let stmt = parse_single_statement("SELECT * FROM users WHERE id = 1").unwrap();
//! let plan = PlanBuilder::new().build_statement(&stmt).unwrap();
//! println!("{}", plan.display_tree());
//! ```

// Deny unwrap in library code to ensure proper error handling
#![deny(clippy::unwrap_used)]

pub mod ast;
pub mod error;
pub mod exec;
pub mod parser;
pub mod plan;

// Re-export commonly used items at the crate root
pub use error::{ParseError, ParseResult};
pub use exec::{ExecutionContext, Executor, Operator, QueryResult, ResultSet, Row, RowBatch};
pub use parser::{parse_single_statement, parse_sql, ExtendedParser};
pub use plan::{
    LogicalExpr, LogicalPlan, PhysicalPlanner, PlanBuilder, PlanError, PlanResult, PlannerCatalog,
    PlannerIndexInfo, PlannerIndexType, TableStats,
};