Expand description
ModulesΒ§
- error π
- explain π
- EXPLAINsupport for structures defined in this crate.
- hir π
- This file houses HIR, a representation of a SQL plan that is parallel to MIR, but represents an earlier phase of planning. Itβs structurally very similar to MIR, with some differences which are noted below. It gets turned into MIR via a call to lower().
- literal π
- lowering π
- Lowering is the process of transforming a HirRelationExprinto aMirRelationExpr.
- notice π
- plan_utils π
- Helper code used throughout the planner.
- query π
- SQL Querys are the declarative, computational part of SQL. This module turnsQuerys intoHirRelationExprs - a more explicit, algebraic way of describing computation. Functions named plan_* are typically responsible for handling a single node of the SQL ast. E.g.plan_queryis responsible for handlingsqlparser::ast::Query. plan_* functions which correspond to operations on relations typically return aHirRelationExpr. plan_* functions which correspond to operations on scalars typically return aHirScalarExprand aSqlScalarType. (The latter is because itβs not always possible to infer from aHirScalarExprwhat the intended type is - notably in the case of decimals where the scale/precision are encoded only in the type). Aggregates are particularly twisty.
- scope π
- Handles SQLβs scoping rules.
- side_effecting_ πfunc 
- Support for side-effecting functions.
- statement π
- Statement planning.
- transform_ast π
- Transformations of SQL ASTs.
- transform_hir π
- Transformations of SQL IR, before decorrelation.
- typeconv π
- Maintains a catalog of valid casts between mz_repr::SqlScalarTypes, as well as other cast-related functions.
- with_options π
- Provides tooling to handle WITHoptions.
StructsΒ§
- AbortTransaction Plan 
- AggregateExpr 
- AlterCluster Plan 
- AlterCluster Rename Plan 
- AlterCluster Replica Rename Plan 
- AlterCluster Swap Plan 
- AlterConnection Plan 
- AlterDefault Privileges Plan 
- AlterItem Rename Plan 
- AlterNetwork Policy Plan 
- AlterNoop Plan 
- Generated by ALTER ... IF EXISTSif the named object did not exist.
- AlterOwner Plan 
- AlterRetain History Plan 
- AlterRole Plan 
- AlterSchema Rename Plan 
- AlterSchema Swap Plan 
- AlterSecret Plan 
- AlterSetCluster Plan 
- AlterSink Plan 
- AlterSource AddSubsource Option Extracted 
- AlterSource Plan 
- AlterSystem Reset AllPlan 
- AlterSystem Reset Plan 
- AlterSystem SetPlan 
- AlterTable Plan 
- ClosePlan 
- CommentPlan 
- CommitTransaction Plan 
- ComputeReplica Config 
- ComputeReplica Introspection Config 
- Configuration of introspection for a cluster replica.
- Connection
- CopyFrom Plan 
- CopyToPlan 
- CreateCluster Managed Plan 
- CreateCluster Plan 
- CreateCluster Replica Plan 
- CreateCluster Unmanaged Plan 
- CreateConnection Plan 
- CreateContinual Task Plan 
- CreateDatabase Plan 
- CreateIndex Plan 
- CreateMaterialized View Plan 
- CreateNetwork Policy Plan 
- CreateRole Plan 
- CreateSchema Plan 
- CreateSecret Plan 
- CreateSink Plan 
- CreateSource Plan 
- CreateSource Plan Bundle 
- A CreateSourcePlanand the metadata necessary to sequence it.
- CreateTable Plan 
- CreateType Plan 
- CreateView Plan 
- DeallocatePlan 
- DeclarePlan 
- DropObjects Plan 
- DropOwned Plan 
- ExecutePlan 
- ExplainPlan Plan 
- ExplainPushdown Plan 
- ExplainSink Schema Plan 
- ExplainTimestamp Plan 
- ExprContext 
- A bundle of unrelated things that we need for planning Exprs.
- FetchPlan 
- GrantPrivileges Plan 
- GrantRole Plan 
- Hir
- HirToMirConfig 
- Index
- InsertPlan 
- InspectShard Plan 
- MaterializedView 
- MySqlConfig Option Extracted 
- NetworkPolicy Rule 
- Params
- A vector of values to which parameter references should be bound.
- PgConfigOption Extracted 
- PlanCluster Option 
- PlanContext 
- Controls planning of a SQL query.
- PolicyAddress 
- PreparePlan 
- QueryContext 
- The state required when planning a Query.
- RaisePlan 
- ReadThen Write Plan 
- ReassignOwned Plan 
- ResetVariable Plan 
- RevokePrivileges Plan 
- RevokeRole Plan 
- Scope
- Secret
- SelectPlan 
- A plan for select statements.
- SendDiffs Plan 
- SetTransactionPlan 
- SetVariablePlan 
- ShowColumns Plan 
- ShowCreate Plan 
- ShowVariable Plan 
- Sink
- Source
- SourceReference 
- An available external reference for a source and if possible to retrieve, any column names it contains.
- SourceReferences 
- SqlServerConfig Option Extracted 
- StartTransaction Plan 
- StatementContext 
- Immutable state that applies to the planning of an entire Statement.
- StatementDesc 
- Describes the output of a SQL statement.
- SubscribePlan 
- Table
- Type
- UpdatePrivilege 
- ValidateConnection Plan 
- View
- WebhookHeader Filters 
- WebhookHeaders 
- WebhookValidation 
- WebhookValidation Secret 
EnumsΒ§
- AlterCluster Plan Strategy 
- AlterConnection Action 
- AlterOption Parameter 
- AlterSource Action 
- ClusterSchedule 
- CoercibleScalar Expr 
- A CoercibleScalarExpris aHirScalarExprwhose type is not fully determined. Several SQL expressions can be freely coerced based upon where in the expression tree they appear. For example, the string literal β42β will be automatically coerced to the integer 42 if used in a numeric context:
- ConnectionDetails 
- CopyFormat 
- CopyFrom Filter 
- CopyFrom Source 
- CreateCluster Variant 
- DataSource Desc 
- ExecuteTimeout 
- Explainee
- The type of object to be explained
- ExplaineeStatement 
- Explainee types that are statements.
- ExplaineeStatement Kind 
- HirRelationExpr 
- Just like mz_expr::MirRelationExpr, except where otherwise noted below.
- HirScalarExpr 
- Just like mz_expr::MirScalarExpr, except where otherwise noted below.
- IndexOption 
- JoinKind 
- MutationKind 
- NetworkPolicy Rule Action 
- NetworkPolicy Rule Direction 
- OnTimeoutAction 
- Plan
- Instructions for executing a SQL query.
- PlanError 
- PlanKind 
- PlanNotice 
- Notices that can occur in the adapter layer.
- PlannedAlter Role Option 
- PlannedRole Variable 
- QueryLifetime 
- Specifies how long a query will live.
- QueryWhen 
- Specifies when a PeekorSubscribeshould occur.
- ReplicaConfig 
- SideEffecting Func 
- A side-effecting function is a function whose evaluation triggers side effects.
- SshKey
- StatementClassification 
- Statement classification as documented by plan.
- SubscribeFrom 
- SubscribeOutput 
- TableData Source 
- TableOption 
- TransactionType 
- VariableValue 
- WebhookBody Format 
- WindowExpr Type 
- A window function with its parameters.
FunctionsΒ§
- describe
- Creates a description of the purified statement stmt.
- normalize_subqueries 
- Normalize the way subqueries appear in HirScalarExpr::ExistsorHirScalarExpr::Selectvariants.
- plan
- Produces a Planfrom the purified statementstmt.
- plan_copy_ from 
- resolve_cluster_ for_ materialized_ view