Expand description
SQL Abstract Syntax Tree (AST) types
Modules§
- defs 🔒
- This module houses the definitions of the structs and enums that are formally part of the AST.
- display
- fold
- Transformation of an owned AST.
- metadata 🔒
- visit
- Traversal of an immutable AST.
- visit_mut 
- Traversal of a mutable AST.
Structs§
- AbbreviatedGrant Statement 
- AbbreviatedRevoke Statement 
- AlterCluster Statement 
- ALTER CLUSTER .. SET ...
- AlterConnection Option 
- An option in an ALTER CONNECTION...statement.
- AlterConnection Statement 
- ALTER CONNECTION
- AlterDefault Privileges Statement 
- ALTER DEFAULT PRIVILEGES ...
- AlterIndex Statement 
- ALTER INDEX ... {RESET, SET}
- AlterNetwork Policy Statement 
- AN ALTER NETWORK POLICYstatement.
- AlterObject Rename Statement 
- ALTER <OBJECT> ... RENAME TO
- AlterObject Swap Statement 
- ALTER <OBJECT> SWAP ...
- AlterOwner Statement 
- ALTER <OBJECT> ... OWNER TO
- AlterRetain History Statement 
- ALTER <OBJECT> ... [RE]SET (RETAIN HISTORY [FOR ...])
- AlterRole Statement 
- ALTER ROLE
- AlterSecret Statement 
- ALTER SECRET ... AS
- AlterSetCluster Statement 
- ALTER SET CLUSTER
- AlterSink Statement 
- AlterSource AddSubsource Option 
- An option in an ALTER SOURCE...ADD SUBSOURCEstatement.
- AlterSource Statement 
- AlterSystem Reset AllStatement 
- ALTER SYSTEM RESET ALL
- AlterSystem Reset Statement 
- ALTER SYSTEM RESET ...
- AlterSystem SetStatement 
- ALTER SYSTEM SET ...
- AlterTable AddColumn Statement 
- ALTER TABLE ... ADD COLUMN ...
- Assignment
- SQL assignment foo = expras used in SQLUpdate
- AvroDocOn 
- AvroSchema Option 
- CloseStatement 
- CLOSE ...
- ClusterAlter Option 
- An option in a ALTER CLUSTER... WITHstatement.
- ClusterAlter Until Ready Option 
- ClusterFeature 
- ClusterOption 
- An option in a CREATE CLUSTERstatement.
- ColumnDef 
- SQL column definition
- ColumnName 
- ColumnOption Def 
- An optionally-named ColumnOption:[ CONSTRAINT <name> ] <column-option>.
- CommentStatement 
- COMMENT ON ...
- CommitStatement 
- COMMIT [ TRANSACTION | WORK ] [ AND [ NO ] CHAIN ]
- ConnectionDefault AwsPrivatelink 
- ConnectionOption 
- An option in a CREATE CONNECTION.
- ContinualTask Option 
- CopyOption 
- CopyStatement 
- COPY
- CreateCluster Replica Statement 
- CREATE CLUSTER REPLICA ..
- CreateCluster Statement 
- CREATE CLUSTER ..
- CreateConnection Option 
- An option in a CREATE CONNECTION...statement.
- CreateConnection Statement 
- CREATE CONNECTIONrefactor WIP
- CreateContinual Task Statement 
- CREATE CONTINUAL TASK
- CreateDatabase Statement 
- CREATE DATABASE
- CreateIndex Statement 
- CREATE INDEX
- CreateMaterialized View Statement 
- CREATE MATERIALIZED VIEW
- CreateNetwork Policy Statement 
- A CREATE NETWORK POLICYstatement.
- CreateRole Statement 
- A CREATE ROLEstatement.
- CreateSchema Statement 
- CREATE SCHEMA
- CreateSecret Statement 
- A CREATE SECRETstatement.
- CreateSink Option 
- CreateSink Statement 
- CREATE SINK
- CreateSource Option 
- An option in a CREATE SOURCE...statement.
- CreateSource Statement 
- CREATE SOURCE
- CreateSubsource Option 
- CreateSubsource Statement 
- CREATE SUBSOURCE
- CreateTable From Source Statement 
- CREATE TABLE .. FROM SOURCE
- CreateTable Statement 
- CREATE TABLE
- CreateType List Option 
- CreateType MapOption 
- CreateType Statement 
- CREATE TYPE ..
- CreateView Statement 
- CREATE VIEW
- CreateWebhook Source Body 
- BODY [AS ...] [BYTES]
- CreateWebhook Source Check 
- CHECK ( ... )
- CreateWebhook Source Check Options 
- CHECK ( WITH ( ... ) )
- CreateWebhook Source Filter Header 
- CreateWebhook Source Header 
- HEADER [AS ...] [BYTES]
- CreateWebhook Source Include Headers 
- INCLUDE [HEADER | HEADERS]
- CreateWebhook Source MapHeader 
- INCLUDE HEADER <name> [AS <alias>] [BYTES]
- CreateWebhook Source Secret 
- SECRET ... [AS ...] [BYTES]
- CreateWebhook Source Statement 
- CREATE (SOURCE | TABLE) <name> FROM WEBHOOK
- CsrConfigOption 
- An option in a {FROM|INTO} CONNECTION ...statement.
- CsrConnection
- CsrConnectionAvro 
- CsrConnectionProtobuf 
- CsrSeedAvro 
- CsrSeedProtobuf 
- CsrSeedProtobuf Schema 
- Cte
- A single CTE (used after WITH):alias [(col1, col2, ...)] AS ( query )The names in the column list beforeAS, when specified, replace the names of the columns returned by the query. The parser does not validate that the number of columns in the query matches the number of columns in the query.
- CteMutRec 
- CteMutRecColumn Def 
- A column definition in a CteMutRec.
- DeallocateStatement 
- DEALLOCATE ...
- DeclareStatement 
- DECLARE ...
- DeleteStatement 
- DELETE
- DiscardStatement 
- DropObjects Statement 
- DROP
- DropOwned Statement 
- DROP OWNED BY ...
- ExecuteStatement 
- EXECUTE ...
- ExplainAnalyze Statement 
- ExplainPlan Option 
- ExplainPlan Statement 
- ExplainPushdown Statement 
- ExplainSink Schema Statement 
- ExplainTimestamp Statement 
- ExternalReference Export 
- A selected external reference in a FOR TABLES (..) statement
- FetchOption 
- FetchStatement 
- FETCH ...
- Function
- A function call
- GrantPrivileges Statement 
- GRANT ...
- GrantRole Statement 
- GRANT ...
- IcebergSink Config Option 
- Ident
- An identifier.
- IndexOption 
- InsertStatement 
- INSERT
- InspectShard Statement 
- INSPECT SHARD <id>
- IntervalValue 
- An intermediate value for Intervals, which tracks all data from the user, as well as the computed ParsedDateTime.
- Join
- KafkaBroker 
- KafkaBroker AwsPrivatelink 
- KafkaBroker AwsPrivatelink Option 
- KafkaSink Config Option 
- KafkaSource Config Option 
- Limit
- LoadGenerator Option 
- An option in a CREATE CONNECTION...SSH.
- MapEntry
- MaterializedView Option 
- MutRecBlock 
- MutRecBlock Option 
- MySqlConfig Option 
- An option in a {FROM|INTO} CONNECTION ...statement.
- NetworkPolicy Option 
- NetworkPolicy Rule Definition 
- NetworkPolicy Rule Option 
- Op
- A reference to an operator.
- OrderByExpr 
- SQL ORDER BY expression
- PgConfigOption 
- An option in a {FROM|INTO} CONNECTION ...statement.
- PrepareStatement 
- PREPARE ...
- QualifiedReplica 
- Query
- The most complete variant of a SELECTquery expression, optionally includingWITH,UNION/ other set operations, andORDER BY.
- RaiseStatement 
- RAISE ...
- Raw
- ReassignOwned Statement 
- REASSIGN OWNED ...
- RefreshAtOption Value 
- RefreshEvery Option Value 
- ReplicaDefinition 
- ReplicaOption 
- An option in a CREATE CLUSTER REPLICAstatement.
- ResetVariable Statement 
- RESET <variable>
- RevokePrivileges Statement 
- REVOKE ...
- RevokeRole Statement 
- REVOKE ...
- RollbackStatement 
- ROLLBACK [ TRANSACTION | WORK ] [ AND [ NO ] CHAIN ]
- Schema
- Select
- A restricted variant of SELECT(without CTEs/ORDER BY), which may appear either as the only body item of anSQLQuery, or as an operand to a set operation likeUNION.
- SelectOption 
- SelectStatement 
- SELECT
- SetTransactionStatement 
- SET TRANSACTION ...
- SetVariableStatement 
- SET <variable>
- ShowColumns Statement 
- SHOW COLUMNS
- ShowCreate Cluster Statement 
- ShowCreate Connection Statement 
- SHOW [REDACTED] CREATE CONNECTION <connection>
- ShowCreate Index Statement 
- SHOW [REDACTED] CREATE INDEX <index>
- ShowCreate Materialized View Statement 
- SHOW [REDACTED] CREATE MATERIALIZED VIEW <name>
- ShowCreate Sink Statement 
- SHOW [REDACTED] CREATE SINK <sink>
- ShowCreate Source Statement 
- SHOW [REDACTED] CREATE SOURCE <source>
- ShowCreate Table Statement 
- SHOW [REDACTED] CREATE TABLE <table>
- ShowCreate Type Statement 
- SHOW [REDACTED] CREATE TYPE <type>
- ShowCreate View Statement 
- SHOW [REDACTED] CREATE VIEW <view>
- ShowObjects Statement 
- SHOW <object>S
- ShowVariable Statement 
- SHOW <variable>
- SinkKey
- SqlServerConfig Option 
- An option in a {FROM|INTO} CONNECTION ...statement.
- StartTransaction Statement 
- { BEGIN [ TRANSACTION | WORK ] | START TRANSACTION } ...
- SubscribeOption 
- SubscribeStatement 
- SUBSCRIBE
- SubscriptPosition 
- TableAlias 
- TableFrom Source Option 
- TableOption 
- TableWith Joins 
- UnresolvedDatabase Name 
- A name of a database
- UnresolvedItem Name 
- A name of a table, view, custom type, etc. that lives in a schema, possibly multi-part, i.e. db.schema.obj
- UnresolvedSchema Name 
- A name of a schema
- UpdateStatement 
- UPDATE
- ValidateConnection Statement 
- VALIDATE CONNECTION
- ValueError 
- Values
- Version
- ViewDefinition 
- WindowFrame 
- Specifies the data processed by a window function, e.g.
RANGE UNBOUNDED PRECEDINGorROWS BETWEEN 5 PRECEDING AND CURRENT ROW.
- WindowSpec 
- A window specification (i.e. OVER (PARTITION BY .. ORDER BY .. etc.)) Includes potential IGNORE NULLS or RESPECT NULLS from before the OVER clause.
Enums§
- AbbreviatedGrant OrRevoke Statement 
- AlterCluster Action 
- AlterConnection Action 
- AlterConnection Option Name 
- AlterIndex Action 
- AlterRole Option 
- ALTER ROLE ... [ WITH | SET ] ...
- AlterSink Action 
- AlterSource Action 
- AlterSource AddSubsource Option Name 
- AsOf
- AvroSchema 
- AvroSchema Option Name 
- CatalogName 
- ClusterAlter Option Name 
- ClusterAlter Option Value 
- ClusterAlter Until Ready Option Name 
- ClusterFeature Name 
- ClusterOption Name 
- ClusterSchedule Option Value 
- ColumnOption 
- ColumnOptions are modifiers that follow a column definition in a- CREATE TABLEstatement.
- ColumnVersioned 
- CommentObject Type 
- ConnectionOption Name 
- ContinualTask Option Name 
- ContinualTask Stmt 
- CopyDirection 
- CopyOption Name 
- CopyRelation 
- CopyTarget 
- CreateConnection Option Name 
- CreateConnection Type 
- CreateContinual Task Sugar 
- CreateSink Connection 
- CreateSink Option Name 
- An option in a CREATE SINKstatement.
- CreateSource Connection 
- CreateSource Option Name 
- CreateSubsource Option Name 
- An option in a CREATE SUBSOURCEstatement.
- CreateType As 
- CREATE TYPE .. AS <TYPE>
- CreateType List Option Name 
- CreateType MapOption Name 
- CsrConfigOption Name 
- CsvColumns
- CteBlock
- A block of common table expressions (CTEs).
- DateTime Field 
- DeferredItem Name 
- DiscardTarget 
- Distinct
- DocOnIdentifier 
- DocOnSchema 
- ExplainAnalyze Computation Property 
- ExplainAnalyze Property 
- ExplainFormat 
- ExplainPlan Option Name 
- ExplainSink Schema For 
- ExplainStage 
- Specifies what Statement::ExplainPlan is actually explained.
- Explainee
- What is being explained. The bools mean whether this is an EXPLAIN BROKEN.
- Expr
- An SQL expression of any type.
- ExternalReferences 
- Specifies which set of external references to generate a source export
for in a CREATE SOURCEstatement.
- FetchDirection 
- FetchOption Name 
- Format
- FormatSpecifier 
- FunctionArgs 
- Arguments for a function call.
- GrantTarget AllSpecification 
- GrantTarget Specification 
- GrantTarget Specification Inner 
- HomogenizingFunction 
- IcebergSink Config Option Name 
- IdentError 
- IfExistsBehavior 
- IndexOption Name 
- An option in a CREATE CLUSTERstatement.
- InsertSource 
- IsExprConstruct 
- JoinConstraint 
- JoinOperator 
- KafkaBroker AwsPrivatelink Option Name 
- KafkaBroker Tunnel 
- KafkaSink Config Option Name 
- KafkaSource Config Option Name 
- KeyConstraint
- A key constraint, specified in a CREATE SOURCE.
- LoadGenerator 
- LoadGenerator Option Name 
- MaterializedView Option Name 
- MutRecBlock Option Name 
- MySqlConfig Option Name 
- NamedPlan 
- An enum of named plans that identifies specific stages in an optimizer trace where these plans can be found.
- NetworkPolicy Option Name 
- NetworkPolicy Rule Option Name 
- NoticeSeverity 
- ObjectType 
- PgConfigOption Name 
- Privilege
- PrivilegeSpecification 
- ProtobufSchema 
- RawClusterName 
- RawDataType 
- SQL data types
- RawItemName 
- RawNetworkPolicy Name 
- ReaderSchema Selection Strategy 
- RefreshOption Value 
- ReplicaOption Name 
- RoleAttribute 
- Attributes that can be attached to roles.
- SelectItem 
- One item of the comma-separated list following SELECT
- SelectOption Name 
- SetExpr
- A node in a tree, representing a “query body” expression, roughly:
SELECT ... [ {UNION|EXCEPT|INTERSECT} SELECT ...]
- SetOperator
- SetRoleVar 
- ALTER ROLE role_name [SET | RESET] ...
- SetVariableTo 
- SetVariableValue 
- ShowObject Type 
- ShowStatement 
- ShowStatement Filter 
- SinkEnvelope 
- SourceEnvelope 
- SourceError Policy 
- SourceInclude Metadata 
- SqlServerConfig Option Name 
- Statement
- A top-level statement (SELECT, INSERT, CREATE, etc.)
- StatementKind 
- SubscribeOption Name 
- SubscribeOutput 
- SubscribeRelation 
- SystemObject Type 
- TableConstraint 
- A table-level constraint, specified in a CREATE TABLEor anALTER TABLE ADD <constraint>statement.
- TableFactor 
- A table name or a parenthesized subquery with an optional alias
- TableFrom Source Columns 
- CREATE TABLE .. FROM SOURCEcolumns specification can have 3 states: Before purification they can be- NotSpecifiedor- Namedby the user to specify the column names to use. After purification they can be in any of the 3 states. For some source types we define the columns during purification and for others the columns are defined during planning based on the encoding option of the source.
- TableFrom Source Option Name 
- TableOption Name 
- TargetRole Specification 
- TransactionAccess Mode 
- TransactionIsolation Level 
- TransactionMode 
- UnresolvedObject Name 
- Value
- Primitive SQL values.
- WindowFrame Bound 
- Specifies WindowFrame’s start_boundandend_bound
- WindowFrame Units 
- WithOption Value 
Traits§
- AstInfo
- This represents the metadata that lives next to an AST, as we take it through various stages in the planning process.
Functions§
- statement_kind_ label_ value 
- A static str for each statement kind