Documentation
¶
Index ¶
- Constants
- Variables
- func AllowScatterDirective(stmt Statement) bool
- func Append(buf *strings.Builder, node SQLNode)
- func CachePlan(stmt Statement) bool
- func CanNormalize(stmt Statement) bool
- func CanonicalString(node SQLNode) string
- func CloneRefOfBool(n *bool) *bool
- func CloneRefOfInt(n *int) *int
- func CloneSliceOfString(n []string) []string
- func ContainsAggregation(e SQLNode) bool
- func EqualsAlterOption(inA, inB AlterOption) bool
- func EqualsCallable(inA, inB Callable) bool
- func EqualsCharacteristic(inA, inB Characteristic) bool
- func EqualsColIdent(a, b ColIdent) bool
- func EqualsColTuple(inA, inB ColTuple) bool
- func EqualsColumnCharset(a, b ColumnCharset) bool
- func EqualsColumnType(a, b ColumnType) bool
- func EqualsColumns(a, b Columns) bool
- func EqualsComments(a, b Comments) bool
- func EqualsConstraintInfo(inA, inB ConstraintInfo) bool
- func EqualsDBDDLStatement(inA, inB DBDDLStatement) bool
- func EqualsDDLStatement(inA, inB DDLStatement) bool
- func EqualsDatabaseOption(a, b DatabaseOption) bool
- func EqualsExplain(inA, inB Explain) bool
- func EqualsExpr(inA, inB Expr) bool
- func EqualsExprs(a, b Exprs) bool
- func EqualsGroupBy(a, b GroupBy) bool
- func EqualsIndexHints(a, b IndexHints) bool
- func EqualsInsertRows(inA, inB InsertRows) bool
- func EqualsJSONObjectParam(a, b JSONObjectParam) bool
- func EqualsJSONPathParam(inA, inB JSONPathParam) bool
- func EqualsOnDup(a, b OnDup) bool
- func EqualsOrderBy(a, b OrderBy) bool
- func EqualsPartitions(a, b Partitions) bool
- func EqualsRefOfAddColumns(a, b *AddColumns) bool
- func EqualsRefOfAddConstraintDefinition(a, b *AddConstraintDefinition) bool
- func EqualsRefOfAddIndexDefinition(a, b *AddIndexDefinition) bool
- func EqualsRefOfAliasedExpr(a, b *AliasedExpr) bool
- func EqualsRefOfAliasedTableExpr(a, b *AliasedTableExpr) bool
- func EqualsRefOfAlterCharset(a, b *AlterCharset) bool
- func EqualsRefOfAlterCheck(a, b *AlterCheck) bool
- func EqualsRefOfAlterColumn(a, b *AlterColumn) bool
- func EqualsRefOfAlterDatabase(a, b *AlterDatabase) bool
- func EqualsRefOfAlterIndex(a, b *AlterIndex) bool
- func EqualsRefOfAlterMigration(a, b *AlterMigration) bool
- func EqualsRefOfAlterTable(a, b *AlterTable) bool
- func EqualsRefOfAlterView(a, b *AlterView) bool
- func EqualsRefOfAlterVschema(a, b *AlterVschema) bool
- func EqualsRefOfAndExpr(a, b *AndExpr) bool
- func EqualsRefOfAutoIncSpec(a, b *AutoIncSpec) bool
- func EqualsRefOfBegin(a, b *Begin) bool
- func EqualsRefOfBetweenExpr(a, b *BetweenExpr) bool
- func EqualsRefOfBinaryExpr(a, b *BinaryExpr) bool
- func EqualsRefOfBool(a, b *bool) bool
- func EqualsRefOfCallProc(a, b *CallProc) bool
- func EqualsRefOfCaseExpr(a, b *CaseExpr) bool
- func EqualsRefOfChangeColumn(a, b *ChangeColumn) bool
- func EqualsRefOfCheckConstraintDefinition(a, b *CheckConstraintDefinition) bool
- func EqualsRefOfColIdent(a, b *ColIdent) bool
- func EqualsRefOfColName(a, b *ColName) bool
- func EqualsRefOfCollateExpr(a, b *CollateExpr) bool
- func EqualsRefOfColumnCharset(a, b *ColumnCharset) bool
- func EqualsRefOfColumnDefinition(a, b *ColumnDefinition) bool
- func EqualsRefOfColumnType(a, b *ColumnType) bool
- func EqualsRefOfColumnTypeOptions(a, b *ColumnTypeOptions) bool
- func EqualsRefOfCommit(a, b *Commit) bool
- func EqualsRefOfCommonTableExpr(a, b *CommonTableExpr) bool
- func EqualsRefOfComparisonExpr(a, b *ComparisonExpr) bool
- func EqualsRefOfConstraintDefinition(a, b *ConstraintDefinition) bool
- func EqualsRefOfConvertExpr(a, b *ConvertExpr) bool
- func EqualsRefOfConvertType(a, b *ConvertType) bool
- func EqualsRefOfConvertUsingExpr(a, b *ConvertUsingExpr) bool
- func EqualsRefOfCreateDatabase(a, b *CreateDatabase) bool
- func EqualsRefOfCreateTable(a, b *CreateTable) bool
- func EqualsRefOfCreateView(a, b *CreateView) bool
- func EqualsRefOfCurTimeFuncExpr(a, b *CurTimeFuncExpr) bool
- func EqualsRefOfDatabaseOption(a, b *DatabaseOption) bool
- func EqualsRefOfDeallocateStmt(a, b *DeallocateStmt) bool
- func EqualsRefOfDefault(a, b *Default) bool
- func EqualsRefOfDefiner(a, b *Definer) bool
- func EqualsRefOfDelete(a, b *Delete) bool
- func EqualsRefOfDerivedTable(a, b *DerivedTable) bool
- func EqualsRefOfDropColumn(a, b *DropColumn) bool
- func EqualsRefOfDropDatabase(a, b *DropDatabase) bool
- func EqualsRefOfDropKey(a, b *DropKey) bool
- func EqualsRefOfDropTable(a, b *DropTable) bool
- func EqualsRefOfDropView(a, b *DropView) bool
- func EqualsRefOfExecuteStmt(a, b *ExecuteStmt) bool
- func EqualsRefOfExistsExpr(a, b *ExistsExpr) bool
- func EqualsRefOfExplainStmt(a, b *ExplainStmt) bool
- func EqualsRefOfExplainTab(a, b *ExplainTab) bool
- func EqualsRefOfExtractFuncExpr(a, b *ExtractFuncExpr) bool
- func EqualsRefOfExtractedSubquery(a, b *ExtractedSubquery) bool
- func EqualsRefOfFlush(a, b *Flush) bool
- func EqualsRefOfForce(a, b *Force) bool
- func EqualsRefOfForeignKeyDefinition(a, b *ForeignKeyDefinition) bool
- func EqualsRefOfFuncExpr(a, b *FuncExpr) bool
- func EqualsRefOfGroupConcatExpr(a, b *GroupConcatExpr) bool
- func EqualsRefOfIndexColumn(a, b *IndexColumn) bool
- func EqualsRefOfIndexDefinition(a, b *IndexDefinition) bool
- func EqualsRefOfIndexHint(a, b *IndexHint) bool
- func EqualsRefOfIndexInfo(a, b *IndexInfo) bool
- func EqualsRefOfIndexOption(a, b *IndexOption) bool
- func EqualsRefOfInsert(a, b *Insert) bool
- func EqualsRefOfInt(a, b *int) bool
- func EqualsRefOfIntervalExpr(a, b *IntervalExpr) bool
- func EqualsRefOfIntroducerExpr(a, b *IntroducerExpr) bool
- func EqualsRefOfIsExpr(a, b *IsExpr) bool
- func EqualsRefOfJSONArrayExpr(a, b *JSONArrayExpr) bool
- func EqualsRefOfJSONAttributesExpr(a, b *JSONAttributesExpr) bool
- func EqualsRefOfJSONContainsExpr(a, b *JSONContainsExpr) bool
- func EqualsRefOfJSONContainsPathExpr(a, b *JSONContainsPathExpr) bool
- func EqualsRefOfJSONExtractExpr(a, b *JSONExtractExpr) bool
- func EqualsRefOfJSONKeysExpr(a, b *JSONKeysExpr) bool
- func EqualsRefOfJSONObjectExpr(a, b *JSONObjectExpr) bool
- func EqualsRefOfJSONObjectParam(a, b *JSONObjectParam) bool
- func EqualsRefOfJSONOverlapsExpr(a, b *JSONOverlapsExpr) bool
- func EqualsRefOfJSONPrettyExpr(a, b *JSONPrettyExpr) bool
- func EqualsRefOfJSONQuoteExpr(a, b *JSONQuoteExpr) bool
- func EqualsRefOfJSONRemoveExpr(a, b *JSONRemoveExpr) bool
- func EqualsRefOfJSONSchemaValidFuncExpr(a, b *JSONSchemaValidFuncExpr) bool
- func EqualsRefOfJSONSchemaValidationReportFuncExpr(a, b *JSONSchemaValidationReportFuncExpr) bool
- func EqualsRefOfJSONSearchExpr(a, b *JSONSearchExpr) bool
- func EqualsRefOfJSONStorageFreeExpr(a, b *JSONStorageFreeExpr) bool
- func EqualsRefOfJSONStorageSizeExpr(a, b *JSONStorageSizeExpr) bool
- func EqualsRefOfJSONTableExpr(a, b *JSONTableExpr) bool
- func EqualsRefOfJSONUnquoteExpr(a, b *JSONUnquoteExpr) bool
- func EqualsRefOfJSONValueExpr(a, b *JSONValueExpr) bool
- func EqualsRefOfJSONValueMergeExpr(a, b *JSONValueMergeExpr) bool
- func EqualsRefOfJSONValueModifierExpr(a, b *JSONValueModifierExpr) bool
- func EqualsRefOfJoinCondition(a, b *JoinCondition) bool
- func EqualsRefOfJoinTableExpr(a, b *JoinTableExpr) bool
- func EqualsRefOfJtColumnDefinition(a, b *JtColumnDefinition) bool
- func EqualsRefOfJtNestedPathColDef(a, b *JtNestedPathColDef) bool
- func EqualsRefOfJtOnResponse(a, b *JtOnResponse) bool
- func EqualsRefOfJtOrdinalColDef(a, b *JtOrdinalColDef) bool
- func EqualsRefOfJtPathColDef(a, b *JtPathColDef) bool
- func EqualsRefOfKeyState(a, b *KeyState) bool
- func EqualsRefOfLimit(a, b *Limit) bool
- func EqualsRefOfLiteral(a, b *Literal) bool
- func EqualsRefOfLoad(a, b *Load) bool
- func EqualsRefOfLockOption(a, b *LockOption) bool
- func EqualsRefOfLockTables(a, b *LockTables) bool
- func EqualsRefOfMatchExpr(a, b *MatchExpr) bool
- func EqualsRefOfMemberOfExpr(a, b *MemberOfExpr) bool
- func EqualsRefOfModifyColumn(a, b *ModifyColumn) bool
- func EqualsRefOfNextval(a, b *Nextval) bool
- func EqualsRefOfNotExpr(a, b *NotExpr) bool
- func EqualsRefOfNullVal(a, b *NullVal) bool
- func EqualsRefOfOptLike(a, b *OptLike) bool
- func EqualsRefOfOrExpr(a, b *OrExpr) bool
- func EqualsRefOfOrder(a, b *Order) bool
- func EqualsRefOfOrderByOption(a, b *OrderByOption) bool
- func EqualsRefOfOtherAdmin(a, b *OtherAdmin) bool
- func EqualsRefOfOtherRead(a, b *OtherRead) bool
- func EqualsRefOfParenTableExpr(a, b *ParenTableExpr) bool
- func EqualsRefOfParsedComments(a, b *ParsedComments) bool
- func EqualsRefOfPartitionDefinition(a, b *PartitionDefinition) bool
- func EqualsRefOfPartitionDefinitionOptions(a, b *PartitionDefinitionOptions) bool
- func EqualsRefOfPartitionEngine(a, b *PartitionEngine) bool
- func EqualsRefOfPartitionOption(a, b *PartitionOption) bool
- func EqualsRefOfPartitionSpec(a, b *PartitionSpec) bool
- func EqualsRefOfPartitionValueRange(a, b *PartitionValueRange) bool
- func EqualsRefOfPrepareStmt(a, b *PrepareStmt) bool
- func EqualsRefOfReferenceDefinition(a, b *ReferenceDefinition) bool
- func EqualsRefOfRelease(a, b *Release) bool
- func EqualsRefOfRenameIndex(a, b *RenameIndex) bool
- func EqualsRefOfRenameTable(a, b *RenameTable) bool
- func EqualsRefOfRenameTableName(a, b *RenameTableName) bool
- func EqualsRefOfRenameTablePair(a, b *RenameTablePair) bool
- func EqualsRefOfRevertMigration(a, b *RevertMigration) bool
- func EqualsRefOfRollback(a, b *Rollback) bool
- func EqualsRefOfRootNode(a, b *RootNode) bool
- func EqualsRefOfSRollback(a, b *SRollback) bool
- func EqualsRefOfSavepoint(a, b *Savepoint) bool
- func EqualsRefOfSelect(a, b *Select) bool
- func EqualsRefOfSelectInto(a, b *SelectInto) bool
- func EqualsRefOfSet(a, b *Set) bool
- func EqualsRefOfSetExpr(a, b *SetExpr) bool
- func EqualsRefOfSetTransaction(a, b *SetTransaction) bool
- func EqualsRefOfShow(a, b *Show) bool
- func EqualsRefOfShowBasic(a, b *ShowBasic) bool
- func EqualsRefOfShowCreate(a, b *ShowCreate) bool
- func EqualsRefOfShowFilter(a, b *ShowFilter) bool
- func EqualsRefOfShowMigrationLogs(a, b *ShowMigrationLogs) bool
- func EqualsRefOfShowOther(a, b *ShowOther) bool
- func EqualsRefOfShowThrottledApps(a, b *ShowThrottledApps) bool
- func EqualsRefOfStarExpr(a, b *StarExpr) bool
- func EqualsRefOfStream(a, b *Stream) bool
- func EqualsRefOfSubPartition(a, b *SubPartition) bool
- func EqualsRefOfSubPartitionDefinition(a, b *SubPartitionDefinition) bool
- func EqualsRefOfSubPartitionDefinitionOptions(a, b *SubPartitionDefinitionOptions) bool
- func EqualsRefOfSubquery(a, b *Subquery) bool
- func EqualsRefOfSubstrExpr(a, b *SubstrExpr) bool
- func EqualsRefOfTableAndLockType(a, b *TableAndLockType) bool
- func EqualsRefOfTableIdent(a, b *TableIdent) bool
- func EqualsRefOfTableName(a, b *TableName) bool
- func EqualsRefOfTableOption(a, b *TableOption) bool
- func EqualsRefOfTableSpec(a, b *TableSpec) bool
- func EqualsRefOfTablespaceOperation(a, b *TablespaceOperation) bool
- func EqualsRefOfTimestampFuncExpr(a, b *TimestampFuncExpr) bool
- func EqualsRefOfTrimFuncExpr(a, b *TrimFuncExpr) bool
- func EqualsRefOfTruncateTable(a, b *TruncateTable) bool
- func EqualsRefOfUnaryExpr(a, b *UnaryExpr) bool
- func EqualsRefOfUnion(a, b *Union) bool
- func EqualsRefOfUnlockTables(a, b *UnlockTables) bool
- func EqualsRefOfUpdate(a, b *Update) bool
- func EqualsRefOfUpdateExpr(a, b *UpdateExpr) bool
- func EqualsRefOfUse(a, b *Use) bool
- func EqualsRefOfVStream(a, b *VStream) bool
- func EqualsRefOfValidation(a, b *Validation) bool
- func EqualsRefOfValuesFuncExpr(a, b *ValuesFuncExpr) bool
- func EqualsRefOfVindexParam(a, b *VindexParam) bool
- func EqualsRefOfVindexSpec(a, b *VindexSpec) bool
- func EqualsRefOfWeightStringFuncExpr(a, b *WeightStringFuncExpr) bool
- func EqualsRefOfWhen(a, b *When) bool
- func EqualsRefOfWhere(a, b *Where) bool
- func EqualsRefOfWith(a, b *With) bool
- func EqualsRefOfXorExpr(a, b *XorExpr) bool
- func EqualsRootNode(a, b RootNode) bool
- func EqualsSQLNode(inA, inB SQLNode) bool
- func EqualsSelectExpr(inA, inB SelectExpr) bool
- func EqualsSelectExprs(a, b SelectExprs) bool
- func EqualsSelectStatement(inA, inB SelectStatement) bool
- func EqualsSetExprs(a, b SetExprs) bool
- func EqualsShowInternal(inA, inB ShowInternal) bool
- func EqualsSimpleTableExpr(inA, inB SimpleTableExpr) bool
- func EqualsSliceOfAlterOption(a, b []AlterOption) bool
- func EqualsSliceOfCharacteristic(a, b []Characteristic) bool
- func EqualsSliceOfColIdent(a, b []ColIdent) bool
- func EqualsSliceOfDatabaseOption(a, b []DatabaseOption) bool
- func EqualsSliceOfJSONPathParam(a, b []JSONPathParam) bool
- func EqualsSliceOfRefOfColumnDefinition(a, b []*ColumnDefinition) bool
- func EqualsSliceOfRefOfCommonTableExpr(a, b []*CommonTableExpr) bool
- func EqualsSliceOfRefOfConstraintDefinition(a, b []*ConstraintDefinition) bool
- func EqualsSliceOfRefOfIndexColumn(a, b []*IndexColumn) bool
- func EqualsSliceOfRefOfIndexDefinition(a, b []*IndexDefinition) bool
- func EqualsSliceOfRefOfIndexOption(a, b []*IndexOption) bool
- func EqualsSliceOfRefOfJSONObjectParam(a, b []*JSONObjectParam) bool
- func EqualsSliceOfRefOfJtColumnDefinition(a, b []*JtColumnDefinition) bool
- func EqualsSliceOfRefOfPartitionDefinition(a, b []*PartitionDefinition) bool
- func EqualsSliceOfRefOfRenameTablePair(a, b []*RenameTablePair) bool
- func EqualsSliceOfRefOfWhen(a, b []*When) bool
- func EqualsSliceOfString(a, b []string) bool
- func EqualsSliceOfTableExpr(a, b []TableExpr) bool
- func EqualsSliceOfVindexParam(a, b []VindexParam) bool
- func EqualsStatement(inA, inB Statement) bool
- func EqualsSubPartitionDefinitions(a, b SubPartitionDefinitions) bool
- func EqualsTableAndLockTypes(a, b TableAndLockTypes) bool
- func EqualsTableExpr(inA, inB TableExpr) bool
- func EqualsTableExprs(a, b TableExprs) bool
- func EqualsTableIdent(a, b TableIdent) bool
- func EqualsTableName(a, b TableName) bool
- func EqualsTableNames(a, b TableNames) bool
- func EqualsTableOptions(a, b TableOptions) bool
- func EqualsUpdateExprs(a, b UpdateExprs) bool
- func EqualsValTuple(a, b ValTuple) bool
- func EqualsValues(a, b Values) bool
- func EqualsVindexParam(a, b VindexParam) bool
- func ExtractMysqlComment(sql string) (string, string)
- func IgnoreMaxMaxMemoryRowsDirective(stmt Statement) bool
- func IgnoreMaxPayloadSizeDirective(stmt Statement) bool
- func IsAggregation(node SQLNode) bool
- func IsColName(node Expr) bool
- func IsDML(sql string) bool
- func IsDMLStatement(stmt Statement) bool
- func IsLockingFunc(node Expr) bool
- func IsMySQL80AndAbove() bool
- func IsNull(node Expr) bool
- func IsSimpleTuple(node Expr) bool
- func IsValue(node Expr) bool
- func KeywordString(id int) string
- func LikeToRegexp(likeExpr string) *regexp.Regexp
- func MultiShardAutocommitDirective(stmt Statement) bool
- func MustRewriteAST(stmt Statement, hasSelectLimit bool) bool
- func Parse2(sql string) (Statement, BindVars, error)
- func ParseTable(input string) (keyspace, table string, err error)
- func ParseTokenizer(tokenizer *Tokenizer) int
- func SkipQueryPlanCacheDirective(stmt Statement) bool
- func SplitStatement(blob string) (string, string, error)
- func SplitStatementToPieces(blob string) (pieces []string, err error)
- func String(node SQLNode) string
- func StripLeadingComments(sql string) string
- func ToString(exprs []TableExpr) string
- func TruncateForLog(query string) string
- func TruncateForUI(query string) string
- func VisitAccessMode(in AccessMode, f Visit) error
- func VisitAlgorithmValue(in AlgorithmValue, f Visit) error
- func VisitAlterOption(in AlterOption, f Visit) error
- func VisitArgument(in Argument, f Visit) error
- func VisitBoolVal(in BoolVal, f Visit) error
- func VisitCallable(in Callable, f Visit) error
- func VisitCharacteristic(in Characteristic, f Visit) error
- func VisitColIdent(in ColIdent, f Visit) error
- func VisitColTuple(in ColTuple, f Visit) error
- func VisitColumns(in Columns, f Visit) error
- func VisitConstraintInfo(in ConstraintInfo, f Visit) error
- func VisitDBDDLStatement(in DBDDLStatement, f Visit) error
- func VisitDDLStatement(in DDLStatement, f Visit) error
- func VisitExplain(in Explain, f Visit) error
- func VisitExpr(in Expr, f Visit) error
- func VisitExprs(in Exprs, f Visit) error
- func VisitGroupBy(in GroupBy, f Visit) error
- func VisitIndexHints(in IndexHints, f Visit) error
- func VisitInsertRows(in InsertRows, f Visit) error
- func VisitIsolationLevel(in IsolationLevel, f Visit) error
- func VisitJSONObjectParam(in JSONObjectParam, f Visit) error
- func VisitJSONPathParam(in JSONPathParam, f Visit) error
- func VisitListArg(in ListArg, f Visit) error
- func VisitMatchAction(in MatchAction, f Visit) error
- func VisitOffset(in Offset, f Visit) error
- func VisitOnDup(in OnDup, f Visit) error
- func VisitOrderBy(in OrderBy, f Visit) error
- func VisitPartitions(in Partitions, f Visit) error
- func VisitRefOfAddColumns(in *AddColumns, f Visit) error
- func VisitRefOfAddConstraintDefinition(in *AddConstraintDefinition, f Visit) error
- func VisitRefOfAddIndexDefinition(in *AddIndexDefinition, f Visit) error
- func VisitRefOfAliasedExpr(in *AliasedExpr, f Visit) error
- func VisitRefOfAliasedTableExpr(in *AliasedTableExpr, f Visit) error
- func VisitRefOfAlterCharset(in *AlterCharset, f Visit) error
- func VisitRefOfAlterCheck(in *AlterCheck, f Visit) error
- func VisitRefOfAlterColumn(in *AlterColumn, f Visit) error
- func VisitRefOfAlterDatabase(in *AlterDatabase, f Visit) error
- func VisitRefOfAlterIndex(in *AlterIndex, f Visit) error
- func VisitRefOfAlterMigration(in *AlterMigration, f Visit) error
- func VisitRefOfAlterTable(in *AlterTable, f Visit) error
- func VisitRefOfAlterView(in *AlterView, f Visit) error
- func VisitRefOfAlterVschema(in *AlterVschema, f Visit) error
- func VisitRefOfAndExpr(in *AndExpr, f Visit) error
- func VisitRefOfAutoIncSpec(in *AutoIncSpec, f Visit) error
- func VisitRefOfBegin(in *Begin, f Visit) error
- func VisitRefOfBetweenExpr(in *BetweenExpr, f Visit) error
- func VisitRefOfBinaryExpr(in *BinaryExpr, f Visit) error
- func VisitRefOfCallProc(in *CallProc, f Visit) error
- func VisitRefOfCaseExpr(in *CaseExpr, f Visit) error
- func VisitRefOfChangeColumn(in *ChangeColumn, f Visit) error
- func VisitRefOfCheckConstraintDefinition(in *CheckConstraintDefinition, f Visit) error
- func VisitRefOfColIdent(in *ColIdent, f Visit) error
- func VisitRefOfColName(in *ColName, f Visit) error
- func VisitRefOfCollateExpr(in *CollateExpr, f Visit) error
- func VisitRefOfColumnDefinition(in *ColumnDefinition, f Visit) error
- func VisitRefOfColumnType(in *ColumnType, f Visit) error
- func VisitRefOfCommit(in *Commit, f Visit) error
- func VisitRefOfCommonTableExpr(in *CommonTableExpr, f Visit) error
- func VisitRefOfComparisonExpr(in *ComparisonExpr, f Visit) error
- func VisitRefOfConstraintDefinition(in *ConstraintDefinition, f Visit) error
- func VisitRefOfConvertExpr(in *ConvertExpr, f Visit) error
- func VisitRefOfConvertType(in *ConvertType, f Visit) error
- func VisitRefOfConvertUsingExpr(in *ConvertUsingExpr, f Visit) error
- func VisitRefOfCreateDatabase(in *CreateDatabase, f Visit) error
- func VisitRefOfCreateTable(in *CreateTable, f Visit) error
- func VisitRefOfCreateView(in *CreateView, f Visit) error
- func VisitRefOfCurTimeFuncExpr(in *CurTimeFuncExpr, f Visit) error
- func VisitRefOfDeallocateStmt(in *DeallocateStmt, f Visit) error
- func VisitRefOfDefault(in *Default, f Visit) error
- func VisitRefOfDefiner(in *Definer, f Visit) error
- func VisitRefOfDelete(in *Delete, f Visit) error
- func VisitRefOfDerivedTable(in *DerivedTable, f Visit) error
- func VisitRefOfDropColumn(in *DropColumn, f Visit) error
- func VisitRefOfDropDatabase(in *DropDatabase, f Visit) error
- func VisitRefOfDropKey(in *DropKey, f Visit) error
- func VisitRefOfDropTable(in *DropTable, f Visit) error
- func VisitRefOfDropView(in *DropView, f Visit) error
- func VisitRefOfExecuteStmt(in *ExecuteStmt, f Visit) error
- func VisitRefOfExistsExpr(in *ExistsExpr, f Visit) error
- func VisitRefOfExplainStmt(in *ExplainStmt, f Visit) error
- func VisitRefOfExplainTab(in *ExplainTab, f Visit) error
- func VisitRefOfExtractFuncExpr(in *ExtractFuncExpr, f Visit) error
- func VisitRefOfExtractedSubquery(in *ExtractedSubquery, f Visit) error
- func VisitRefOfFlush(in *Flush, f Visit) error
- func VisitRefOfForce(in *Force, f Visit) error
- func VisitRefOfForeignKeyDefinition(in *ForeignKeyDefinition, f Visit) error
- func VisitRefOfFuncExpr(in *FuncExpr, f Visit) error
- func VisitRefOfGroupConcatExpr(in *GroupConcatExpr, f Visit) error
- func VisitRefOfIndexDefinition(in *IndexDefinition, f Visit) error
- func VisitRefOfIndexHint(in *IndexHint, f Visit) error
- func VisitRefOfIndexInfo(in *IndexInfo, f Visit) error
- func VisitRefOfInsert(in *Insert, f Visit) error
- func VisitRefOfIntervalExpr(in *IntervalExpr, f Visit) error
- func VisitRefOfIntroducerExpr(in *IntroducerExpr, f Visit) error
- func VisitRefOfIsExpr(in *IsExpr, f Visit) error
- func VisitRefOfJSONArrayExpr(in *JSONArrayExpr, f Visit) error
- func VisitRefOfJSONAttributesExpr(in *JSONAttributesExpr, f Visit) error
- func VisitRefOfJSONContainsExpr(in *JSONContainsExpr, f Visit) error
- func VisitRefOfJSONContainsPathExpr(in *JSONContainsPathExpr, f Visit) error
- func VisitRefOfJSONExtractExpr(in *JSONExtractExpr, f Visit) error
- func VisitRefOfJSONKeysExpr(in *JSONKeysExpr, f Visit) error
- func VisitRefOfJSONObjectExpr(in *JSONObjectExpr, f Visit) error
- func VisitRefOfJSONObjectParam(in *JSONObjectParam, f Visit) error
- func VisitRefOfJSONOverlapsExpr(in *JSONOverlapsExpr, f Visit) error
- func VisitRefOfJSONPrettyExpr(in *JSONPrettyExpr, f Visit) error
- func VisitRefOfJSONQuoteExpr(in *JSONQuoteExpr, f Visit) error
- func VisitRefOfJSONRemoveExpr(in *JSONRemoveExpr, f Visit) error
- func VisitRefOfJSONSchemaValidFuncExpr(in *JSONSchemaValidFuncExpr, f Visit) error
- func VisitRefOfJSONSchemaValidationReportFuncExpr(in *JSONSchemaValidationReportFuncExpr, f Visit) error
- func VisitRefOfJSONSearchExpr(in *JSONSearchExpr, f Visit) error
- func VisitRefOfJSONStorageFreeExpr(in *JSONStorageFreeExpr, f Visit) error
- func VisitRefOfJSONStorageSizeExpr(in *JSONStorageSizeExpr, f Visit) error
- func VisitRefOfJSONTableExpr(in *JSONTableExpr, f Visit) error
- func VisitRefOfJSONUnquoteExpr(in *JSONUnquoteExpr, f Visit) error
- func VisitRefOfJSONValueExpr(in *JSONValueExpr, f Visit) error
- func VisitRefOfJSONValueMergeExpr(in *JSONValueMergeExpr, f Visit) error
- func VisitRefOfJSONValueModifierExpr(in *JSONValueModifierExpr, f Visit) error
- func VisitRefOfJoinCondition(in *JoinCondition, f Visit) error
- func VisitRefOfJoinTableExpr(in *JoinTableExpr, f Visit) error
- func VisitRefOfJtColumnDefinition(in *JtColumnDefinition, f Visit) error
- func VisitRefOfJtOnResponse(in *JtOnResponse, f Visit) error
- func VisitRefOfKeyState(in *KeyState, f Visit) error
- func VisitRefOfLimit(in *Limit, f Visit) error
- func VisitRefOfLiteral(in *Literal, f Visit) error
- func VisitRefOfLoad(in *Load, f Visit) error
- func VisitRefOfLockOption(in *LockOption, f Visit) error
- func VisitRefOfLockTables(in *LockTables, f Visit) error
- func VisitRefOfMatchExpr(in *MatchExpr, f Visit) error
- func VisitRefOfMemberOfExpr(in *MemberOfExpr, f Visit) error
- func VisitRefOfModifyColumn(in *ModifyColumn, f Visit) error
- func VisitRefOfNextval(in *Nextval, f Visit) error
- func VisitRefOfNotExpr(in *NotExpr, f Visit) error
- func VisitRefOfNullVal(in *NullVal, f Visit) error
- func VisitRefOfOptLike(in *OptLike, f Visit) error
- func VisitRefOfOrExpr(in *OrExpr, f Visit) error
- func VisitRefOfOrder(in *Order, f Visit) error
- func VisitRefOfOrderByOption(in *OrderByOption, f Visit) error
- func VisitRefOfOtherAdmin(in *OtherAdmin, f Visit) error
- func VisitRefOfOtherRead(in *OtherRead, f Visit) error
- func VisitRefOfParenTableExpr(in *ParenTableExpr, f Visit) error
- func VisitRefOfParsedComments(in *ParsedComments, f Visit) error
- func VisitRefOfPartitionDefinition(in *PartitionDefinition, f Visit) error
- func VisitRefOfPartitionDefinitionOptions(in *PartitionDefinitionOptions, f Visit) error
- func VisitRefOfPartitionEngine(in *PartitionEngine, f Visit) error
- func VisitRefOfPartitionOption(in *PartitionOption, f Visit) error
- func VisitRefOfPartitionSpec(in *PartitionSpec, f Visit) error
- func VisitRefOfPartitionValueRange(in *PartitionValueRange, f Visit) error
- func VisitRefOfPrepareStmt(in *PrepareStmt, f Visit) error
- func VisitRefOfReferenceDefinition(in *ReferenceDefinition, f Visit) error
- func VisitRefOfRelease(in *Release, f Visit) error
- func VisitRefOfRenameIndex(in *RenameIndex, f Visit) error
- func VisitRefOfRenameTable(in *RenameTable, f Visit) error
- func VisitRefOfRenameTableName(in *RenameTableName, f Visit) error
- func VisitRefOfRevertMigration(in *RevertMigration, f Visit) error
- func VisitRefOfRollback(in *Rollback, f Visit) error
- func VisitRefOfRootNode(in *RootNode, f Visit) error
- func VisitRefOfSRollback(in *SRollback, f Visit) error
- func VisitRefOfSavepoint(in *Savepoint, f Visit) error
- func VisitRefOfSelect(in *Select, f Visit) error
- func VisitRefOfSelectInto(in *SelectInto, f Visit) error
- func VisitRefOfSet(in *Set, f Visit) error
- func VisitRefOfSetExpr(in *SetExpr, f Visit) error
- func VisitRefOfSetTransaction(in *SetTransaction, f Visit) error
- func VisitRefOfShow(in *Show, f Visit) error
- func VisitRefOfShowBasic(in *ShowBasic, f Visit) error
- func VisitRefOfShowCreate(in *ShowCreate, f Visit) error
- func VisitRefOfShowFilter(in *ShowFilter, f Visit) error
- func VisitRefOfShowMigrationLogs(in *ShowMigrationLogs, f Visit) error
- func VisitRefOfShowOther(in *ShowOther, f Visit) error
- func VisitRefOfShowThrottledApps(in *ShowThrottledApps, f Visit) error
- func VisitRefOfStarExpr(in *StarExpr, f Visit) error
- func VisitRefOfStream(in *Stream, f Visit) error
- func VisitRefOfSubPartition(in *SubPartition, f Visit) error
- func VisitRefOfSubPartitionDefinition(in *SubPartitionDefinition, f Visit) error
- func VisitRefOfSubPartitionDefinitionOptions(in *SubPartitionDefinitionOptions, f Visit) error
- func VisitRefOfSubquery(in *Subquery, f Visit) error
- func VisitRefOfSubstrExpr(in *SubstrExpr, f Visit) error
- func VisitRefOfTableIdent(in *TableIdent, f Visit) error
- func VisitRefOfTableName(in *TableName, f Visit) error
- func VisitRefOfTableSpec(in *TableSpec, f Visit) error
- func VisitRefOfTablespaceOperation(in *TablespaceOperation, f Visit) error
- func VisitRefOfTimestampFuncExpr(in *TimestampFuncExpr, f Visit) error
- func VisitRefOfTrimFuncExpr(in *TrimFuncExpr, f Visit) error
- func VisitRefOfTruncateTable(in *TruncateTable, f Visit) error
- func VisitRefOfUnaryExpr(in *UnaryExpr, f Visit) error
- func VisitRefOfUnion(in *Union, f Visit) error
- func VisitRefOfUnlockTables(in *UnlockTables, f Visit) error
- func VisitRefOfUpdate(in *Update, f Visit) error
- func VisitRefOfUpdateExpr(in *UpdateExpr, f Visit) error
- func VisitRefOfUse(in *Use, f Visit) error
- func VisitRefOfVStream(in *VStream, f Visit) error
- func VisitRefOfValidation(in *Validation, f Visit) error
- func VisitRefOfValuesFuncExpr(in *ValuesFuncExpr, f Visit) error
- func VisitRefOfVindexParam(in *VindexParam, f Visit) error
- func VisitRefOfVindexSpec(in *VindexSpec, f Visit) error
- func VisitRefOfWeightStringFuncExpr(in *WeightStringFuncExpr, f Visit) error
- func VisitRefOfWhen(in *When, f Visit) error
- func VisitRefOfWhere(in *Where, f Visit) error
- func VisitRefOfWith(in *With, f Visit) error
- func VisitRefOfXorExpr(in *XorExpr, f Visit) error
- func VisitReferenceAction(in ReferenceAction, f Visit) error
- func VisitRootNode(in RootNode, f Visit) error
- func VisitSQLNode(in SQLNode, f Visit) error
- func VisitSelectExpr(in SelectExpr, f Visit) error
- func VisitSelectExprs(in SelectExprs, f Visit) error
- func VisitSelectStatement(in SelectStatement, f Visit) error
- func VisitSetExprs(in SetExprs, f Visit) error
- func VisitShowInternal(in ShowInternal, f Visit) error
- func VisitSimpleTableExpr(in SimpleTableExpr, f Visit) error
- func VisitStatement(in Statement, f Visit) error
- func VisitSubPartitionDefinitions(in SubPartitionDefinitions, f Visit) error
- func VisitTableExpr(in TableExpr, f Visit) error
- func VisitTableExprs(in TableExprs, f Visit) error
- func VisitTableIdent(in TableIdent, f Visit) error
- func VisitTableName(in TableName, f Visit) error
- func VisitTableNames(in TableNames, f Visit) error
- func VisitTableOptions(in TableOptions, f Visit) error
- func VisitUpdateExprs(in UpdateExprs, f Visit) error
- func VisitValTuple(in ValTuple, f Visit) error
- func VisitValues(in Values, f Visit) error
- func VisitVindexParam(in VindexParam, f Visit) error
- func Walk(visit Visit, nodes ...SQLNode) error
- type AccessMode
- type AddColumns
- type AddConstraintDefinition
- type AddIndexDefinition
- type AlgorithmValue
- type AliasedExpr
- type AliasedTableExpr
- type AlterCharset
- type AlterCheck
- type AlterColumn
- type AlterDatabase
- type AlterIndex
- type AlterMigration
- type AlterMigrationType
- type AlterOption
- type AlterTable
- func (node *AlterTable) AffectedTables() TableNames
- func (cached *AlterTable) CachedSize(alloc bool) int64
- func (node *AlterTable) Format(buf *TrackedBuffer)
- func (node *AlterTable) GetAction() DDLAction
- func (node *AlterTable) GetFromTables() TableNames
- func (node *AlterTable) GetIfExists() bool
- func (node *AlterTable) GetIfNotExists() bool
- func (node *AlterTable) GetIsReplace() bool
- func (node *AlterTable) GetOptLike() *OptLike
- func (node *AlterTable) GetParsedComments() *ParsedComments
- func (node *AlterTable) GetTable() TableName
- func (node *AlterTable) GetTableSpec() *TableSpec
- func (node *AlterTable) GetToTables() TableNames
- func (node *AlterTable) IsFullyParsed() bool
- func (node *AlterTable) IsTemporary() bool
- func (node *AlterTable) SetComments(comments Comments)
- func (node *AlterTable) SetFromTables(tables TableNames)
- func (node *AlterTable) SetFullyParsed(fullyParsed bool)
- func (node *AlterTable) SetTable(qualifier string, name string)
- type AlterView
- func (node *AlterView) AffectedTables() TableNames
- func (cached *AlterView) CachedSize(alloc bool) int64
- func (node *AlterView) Format(buf *TrackedBuffer)
- func (node *AlterView) GetAction() DDLAction
- func (node *AlterView) GetFromTables() TableNames
- func (node *AlterView) GetIfExists() bool
- func (node *AlterView) GetIfNotExists() bool
- func (node *AlterView) GetIsReplace() bool
- func (node *AlterView) GetOptLike() *OptLike
- func (node *AlterView) GetParsedComments() *ParsedComments
- func (node *AlterView) GetTable() TableName
- func (node *AlterView) GetTableSpec() *TableSpec
- func (node *AlterView) GetToTables() TableNames
- func (node *AlterView) IsFullyParsed() bool
- func (node *AlterView) IsTemporary() bool
- func (node *AlterView) SetComments(comments Comments)
- func (node *AlterView) SetFromTables(tables TableNames)
- func (node *AlterView) SetFullyParsed(fullyParsed bool)
- func (node *AlterView) SetTable(qualifier string, name string)
- type AlterVschema
- type AndExpr
- type ApplyFunc
- type Argument
- type AtCount
- type AutoIncSpec
- type Begin
- type BetweenExpr
- type BinaryExpr
- type BinaryExprOperator
- type BindVars
- type BoolVal
- type CallProc
- type Callable
- type CaseExpr
- type ChangeColumn
- type Characteristic
- type CheckConstraintDefinition
- type ColIdent
- func (node ColIdent) AtCount() AtCount
- func (cached *ColIdent) CachedSize(alloc bool) int64
- func (node ColIdent) CompliantName() string
- func (node ColIdent) Equal(in ColIdent) bool
- func (node ColIdent) EqualString(str string) bool
- func (node ColIdent) Format(buf *TrackedBuffer)
- func (node ColIdent) IsEmpty() bool
- func (node ColIdent) Lowered() string
- func (node ColIdent) MarshalJSON() ([]byte, error)
- func (node ColIdent) String() string
- func (node *ColIdent) UnmarshalJSON(b []byte) error
- type ColName
- type ColTuple
- type CollateExpr
- type ColumnCharset
- type ColumnDefinition
- type ColumnFormat
- type ColumnKeyOption
- type ColumnStorage
- type ColumnType
- type ColumnTypeOptions
- type Columns
- type CommentDirectives
- type Commented
- type Comments
- type Commit
- type CommonTableExpr
- type ComparisonExpr
- type ComparisonExprOperator
- type ConstraintDefinition
- type ConstraintInfo
- type ConvertExpr
- type ConvertType
- type ConvertUsingExpr
- type CreateDatabase
- type CreateTable
- func (node *CreateTable) AffectedTables() TableNames
- func (cached *CreateTable) CachedSize(alloc bool) int64
- func (node *CreateTable) Format(buf *TrackedBuffer)
- func (node *CreateTable) GetAction() DDLAction
- func (node *CreateTable) GetFromTables() TableNames
- func (node *CreateTable) GetIfExists() bool
- func (node *CreateTable) GetIfNotExists() bool
- func (node *CreateTable) GetIsReplace() bool
- func (node *CreateTable) GetOptLike() *OptLike
- func (node *CreateTable) GetParsedComments() *ParsedComments
- func (node *CreateTable) GetTable() TableName
- func (node *CreateTable) GetTableSpec() *TableSpec
- func (node *CreateTable) GetToTables() TableNames
- func (node *CreateTable) IsFullyParsed() bool
- func (node *CreateTable) IsTemporary() bool
- func (node *CreateTable) SetComments(comments Comments)
- func (node *CreateTable) SetFromTables(tables TableNames)
- func (node *CreateTable) SetFullyParsed(fullyParsed bool)
- func (node *CreateTable) SetTable(qualifier string, name string)
- type CreateView
- func (node *CreateView) AffectedTables() TableNames
- func (cached *CreateView) CachedSize(alloc bool) int64
- func (node *CreateView) Format(buf *TrackedBuffer)
- func (node *CreateView) GetAction() DDLAction
- func (node *CreateView) GetFromTables() TableNames
- func (node *CreateView) GetIfExists() bool
- func (node *CreateView) GetIfNotExists() bool
- func (node *CreateView) GetIsReplace() bool
- func (node *CreateView) GetOptLike() *OptLike
- func (node *CreateView) GetParsedComments() *ParsedComments
- func (node *CreateView) GetTable() TableName
- func (node *CreateView) GetTableSpec() *TableSpec
- func (node *CreateView) GetToTables() TableNames
- func (node *CreateView) IsFullyParsed() bool
- func (node *CreateView) IsTemporary() bool
- func (node *CreateView) SetComments(comments Comments)
- func (node *CreateView) SetFromTables(tables TableNames)
- func (node *CreateView) SetFullyParsed(fullyParsed bool)
- func (node *CreateView) SetTable(qualifier string, name string)
- type CurTimeFuncExpr
- type Cursor
- type DBDDLStatement
- type DDLAction
- type DDLStatement
- type DatabaseOption
- type DatabaseOptionType
- type DeallocateStmt
- type DeallocateStmtType
- type Default
- type Definer
- type Delete
- type DerivedTable
- type DropColumn
- type DropDatabase
- type DropKey
- type DropKeyType
- type DropTable
- func (node *DropTable) AffectedTables() TableNames
- func (cached *DropTable) CachedSize(alloc bool) int64
- func (node *DropTable) Format(buf *TrackedBuffer)
- func (node *DropTable) GetAction() DDLAction
- func (node *DropTable) GetFromTables() TableNames
- func (node *DropTable) GetIfExists() bool
- func (node *DropTable) GetIfNotExists() bool
- func (node *DropTable) GetIsReplace() bool
- func (node *DropTable) GetOptLike() *OptLike
- func (node *DropTable) GetParsedComments() *ParsedComments
- func (node *DropTable) GetTable() TableName
- func (node *DropTable) GetTableSpec() *TableSpec
- func (node *DropTable) GetToTables() TableNames
- func (node *DropTable) IsFullyParsed() bool
- func (node *DropTable) IsTemporary() bool
- func (node *DropTable) SetComments(comments Comments)
- func (node *DropTable) SetFromTables(tables TableNames)
- func (node *DropTable) SetFullyParsed(fullyParsed bool)
- func (node *DropTable) SetTable(qualifier string, name string)
- type DropView
- func (node *DropView) AffectedTables() TableNames
- func (cached *DropView) CachedSize(alloc bool) int64
- func (node *DropView) Format(buf *TrackedBuffer)
- func (node *DropView) GetAction() DDLAction
- func (node *DropView) GetFromTables() TableNames
- func (node *DropView) GetIfExists() bool
- func (node *DropView) GetIfNotExists() bool
- func (node *DropView) GetIsReplace() bool
- func (node *DropView) GetOptLike() *OptLike
- func (node *DropView) GetParsedComments() *ParsedComments
- func (node *DropView) GetTable() TableName
- func (node *DropView) GetTableSpec() *TableSpec
- func (node *DropView) GetToTables() TableNames
- func (node *DropView) IsFullyParsed() bool
- func (node *DropView) IsTemporary() bool
- func (node *DropView) SetComments(comments Comments)
- func (node *DropView) SetFromTables(tables TableNames)
- func (node *DropView) SetFullyParsed(fullyParsed bool)
- func (node *DropView) SetTable(qualifier string, name string)
- type Encodable
- type ExecuteStmt
- type ExistsExpr
- type Explain
- type ExplainStmt
- type ExplainTab
- type ExplainType
- type Expr
- type Exprs
- type ExtractFuncExpr
- type ExtractedSubquery
- func (cached *ExtractedSubquery) CachedSize(alloc bool) int64
- func (node *ExtractedSubquery) Format(buf *TrackedBuffer)
- func (es *ExtractedSubquery) GetArgName() string
- func (es *ExtractedSubquery) GetHasValuesArg() string
- func (es *ExtractedSubquery) SetArgName(n string)
- func (es *ExtractedSubquery) SetHasValuesArg(n string)
- type Flush
- type Force
- type ForeignKeyDefinition
- type FuncExpr
- type GroupBy
- type GroupConcatExpr
- type Ignore
- type IndexColumn
- type IndexDefinition
- type IndexHint
- type IndexHintForType
- type IndexHintType
- type IndexHints
- type IndexInfo
- type IndexOption
- type Insert
- type InsertAction
- type InsertRows
- type InsertValues
- type IntervalExpr
- type IntervalTypes
- type IntroducerExpr
- type IsExpr
- type IsExprOperator
- type IsolationLevel
- type JSONArrayExpr
- type JSONAttributeType
- type JSONAttributesExpr
- type JSONContainsExpr
- type JSONContainsPathExpr
- type JSONContainsPathType
- type JSONExtractExpr
- type JSONKeysExpr
- type JSONObjectExpr
- type JSONObjectParam
- type JSONOverlapsExpr
- type JSONPathParam
- type JSONPrettyExpr
- type JSONQuoteExpr
- type JSONRemoveExpr
- type JSONSchemaValidFuncExpr
- type JSONSchemaValidationReportFuncExpr
- type JSONSearchExpr
- type JSONStorageFreeExpr
- type JSONStorageSizeExpr
- type JSONTableExpr
- type JSONUnquoteExpr
- type JSONValueExpr
- type JSONValueMergeExpr
- type JSONValueMergeType
- type JSONValueModifierExpr
- type JSONValueModifierType
- type JoinCondition
- type JoinTableExpr
- type JoinType
- type JtColumnDefinition
- type JtNestedPathColDef
- type JtOnResponse
- type JtOnResponseType
- type JtOrdinalColDef
- type JtPathColDef
- type KeyState
- type LengthScaleOption
- type Limit
- type ListArg
- type Literal
- func CloneRefOfLiteral(n *Literal) *Literal
- func NewBitLiteral(in string) *Literal
- func NewDecimalLiteral(in string) *Literal
- func NewFloatLiteral(in string) *Literal
- func NewHexLiteral(in string) *Literal
- func NewHexNumLiteral(in string) *Literal
- func NewIntLiteral(in string) *Literal
- func NewStrLiteral(in string) *Literal
- type Load
- type Lock
- type LockOption
- type LockOptionType
- type LockTables
- type LockType
- type MarginComments
- type MatchAction
- type MatchExpr
- type MatchExprOption
- type MemberOfExpr
- type ModifyColumn
- type Nextval
- type NodeFormatter
- type NotExpr
- type NullVal
- type Offset
- type OnDup
- type OptLike
- type OrExpr
- type Order
- type OrderBy
- type OrderByOption
- type OrderDirection
- type OtherAdmin
- type OtherRead
- type ParenTableExpr
- type ParsedComments
- func (node *ParsedComments) AddQueryHint(queryHint string) (Comments, error)
- func (cached *ParsedComments) CachedSize(alloc bool) int64
- func (c *ParsedComments) Directives() CommentDirectives
- func (node *ParsedComments) Format(buf *TrackedBuffer)
- func (c *ParsedComments) Length() int
- func (c *ParsedComments) Prepend(comment string) Comments
- type PartitionByType
- type PartitionDefinition
- type PartitionDefinitionOptions
- type PartitionEngine
- type PartitionOption
- type PartitionSpec
- type PartitionSpecAction
- type PartitionValueRange
- type PartitionValueRangeType
- type Partitions
- type PositionedErr
- type Precendence
- type PrepareStmt
- type RangeCondOperator
- type ReferenceAction
- type ReferenceDefinition
- type Release
- type RenameIndex
- type RenameTable
- func (node *RenameTable) AffectedTables() TableNames
- func (cached *RenameTable) CachedSize(alloc bool) int64
- func (node *RenameTable) Format(buf *TrackedBuffer)
- func (node *RenameTable) GetAction() DDLAction
- func (node *RenameTable) GetFromTables() TableNames
- func (node *RenameTable) GetIfExists() bool
- func (node *RenameTable) GetIfNotExists() bool
- func (node *RenameTable) GetIsReplace() bool
- func (node *RenameTable) GetOptLike() *OptLike
- func (node *RenameTable) GetParsedComments() *ParsedComments
- func (node *RenameTable) GetTable() TableName
- func (node *RenameTable) GetTableSpec() *TableSpec
- func (node *RenameTable) GetToTables() TableNames
- func (*RenameTable) IsFullyParsed() bool
- func (*RenameTable) IsTemporary() bool
- func (node *RenameTable) SetComments(comments Comments)
- func (node *RenameTable) SetFromTables(tables TableNames)
- func (node *RenameTable) SetFullyParsed(fullyParsed bool)
- func (node *RenameTable) SetTable(qualifier string, name string)
- type RenameTableName
- type RenameTablePair
- type RevertMigration
- type Rollback
- type RootNode
- type SQLNode
- type SRollback
- type Savepoint
- type Scope
- type Select
- func (node *Select) AddGroupBy(expr Expr)
- func (node *Select) AddHaving(expr Expr)
- func (node *Select) AddOrder(order *Order)
- func (node *Select) AddWhere(expr Expr)
- func (cached *Select) CachedSize(alloc bool) int64
- func (node *Select) Format(buf *TrackedBuffer)
- func (node *Select) GetColumnCount() int
- func (node *Select) GetOrderBy() OrderBy
- func (node *Select) GetParsedComments() *ParsedComments
- func (node *Select) MakeDistinct()
- func (node *Select) SetComments(comments Comments)
- func (node *Select) SetInto(into *SelectInto)
- func (node *Select) SetLimit(limit *Limit)
- func (node *Select) SetLock(lock Lock)
- func (node *Select) SetOrderBy(orderBy OrderBy)
- func (node *Select) SetWith(with *With)
- type SelectExpr
- type SelectExprs
- type SelectInto
- type SelectIntoType
- type SelectStatement
- type Set
- type SetExpr
- type SetExprs
- type SetTransaction
- type Show
- type ShowBasic
- type ShowCommandType
- type ShowCreate
- type ShowFilter
- type ShowInternal
- type ShowMigrationLogs
- type ShowOther
- type ShowTablesOpt
- type ShowThrottledApps
- type SimpleTableExpr
- type StarExpr
- type Statement
- type StatementType
- type Stream
- type SubPartition
- type SubPartitionDefinition
- type SubPartitionDefinitionOptions
- type SubPartitionDefinitions
- type Subquery
- type SubstrExpr
- type SupportOptimizerHint
- type TableAndLockType
- type TableAndLockTypes
- type TableExpr
- type TableExprs
- type TableIdent
- func (cached *TableIdent) CachedSize(alloc bool) int64
- func (node TableIdent) CompliantName() string
- func (node TableIdent) Format(buf *TrackedBuffer)
- func (node TableIdent) IsEmpty() bool
- func (node TableIdent) MarshalJSON() ([]byte, error)
- func (node TableIdent) String() string
- func (node *TableIdent) UnmarshalJSON(b []byte) error
- type TableName
- type TableNames
- type TableOption
- type TableOptions
- type TableSpec
- type TablespaceOperation
- type TimestampFuncExpr
- type Tokenizer
- type TrackedBuffer
- func (buf *TrackedBuffer) HasBindVars() bool
- func (buf *TrackedBuffer) Myprintf(format string, values ...any)
- func (buf *TrackedBuffer) SetEscapeAllIdentifiers(enable bool)
- func (buf *TrackedBuffer) SetUpperCase(enable bool)
- func (buf *TrackedBuffer) WriteArg(prefix, arg string)
- func (buf *TrackedBuffer) WriteNode(node SQLNode) *TrackedBuffer
- type TrimFuncExpr
- type TrimFuncType
- type TrimType
- type TruncateTable
- func (node *TruncateTable) AffectedTables() TableNames
- func (cached *TruncateTable) CachedSize(alloc bool) int64
- func (node *TruncateTable) Format(buf *TrackedBuffer)
- func (node *TruncateTable) GetAction() DDLAction
- func (node *TruncateTable) GetFromTables() TableNames
- func (node *TruncateTable) GetIfExists() bool
- func (node *TruncateTable) GetIfNotExists() bool
- func (node *TruncateTable) GetIsReplace() bool
- func (node *TruncateTable) GetOptLike() *OptLike
- func (node *TruncateTable) GetParsedComments() *ParsedComments
- func (node *TruncateTable) GetTable() TableName
- func (node *TruncateTable) GetTableSpec() *TableSpec
- func (node *TruncateTable) GetToTables() TableNames
- func (*TruncateTable) IsFullyParsed() bool
- func (*TruncateTable) IsTemporary() bool
- func (node *TruncateTable) SetComments(comments Comments)
- func (node *TruncateTable) SetFromTables(tables TableNames)
- func (*TruncateTable) SetFullyParsed(bool)
- func (node *TruncateTable) SetTable(qualifier string, name string)
- type TupleEqualityList
- type UnaryExpr
- type UnaryExprOperator
- type Union
- func (node *Union) AddOrder(order *Order)
- func (cached *Union) CachedSize(alloc bool) int64
- func (node *Union) Format(buf *TrackedBuffer)
- func (node *Union) GetColumnCount() int
- func (node *Union) GetOrderBy() OrderBy
- func (node *Union) GetParsedComments() *ParsedComments
- func (node *Union) MakeDistinct()
- func (node *Union) SetComments(comments Comments)
- func (node *Union) SetInto(into *SelectInto)
- func (node *Union) SetLimit(limit *Limit)
- func (node *Union) SetLock(lock Lock)
- func (node *Union) SetOrderBy(orderBy OrderBy)
- func (node *Union) SetWith(with *With)
- type UnlockTables
- type Update
- type UpdateExpr
- type UpdateExprs
- type Use
- type VStream
- type ValTuple
- type ValType
- type Validation
- type Values
- type ValuesFuncExpr
- type VindexParam
- type VindexSpec
- type Visit
- type WeightStringFuncExpr
- type When
- type Where
- type WhereType
- type With
- type XorExpr
Constants ¶
const ( StrVal = ValType(iota) IntVal DecimalVal FloatVal HexNum HexVal BitVal )
These are the possible Valtype values. HexNum represents a 0x... value. It cannot be treated as a simple value because it can be interpreted differently depending on the context.
const ( // DirectiveMultiShardAutocommit is the query comment directive to allow // single round trip autocommit with a multi-shard statement. DirectiveMultiShardAutocommit = "MULTI_SHARD_AUTOCOMMIT" // DirectiveSkipQueryPlanCache skips query plan cache when set. DirectiveSkipQueryPlanCache = "SKIP_QUERY_PLAN_CACHE" // DirectiveQueryTimeout sets a query timeout in vtgate. Only supported for SELECTS. DirectiveQueryTimeout = "QUERY_TIMEOUT_MS" // DirectiveScatterErrorsAsWarnings enables partial success scatter select queries DirectiveScatterErrorsAsWarnings = "SCATTER_ERRORS_AS_WARNINGS" // DirectiveIgnoreMaxPayloadSize skips payload size validation when set. DirectiveIgnoreMaxPayloadSize = "IGNORE_MAX_PAYLOAD_SIZE" // DirectiveIgnoreMaxMemoryRows skips memory row validation when set. DirectiveIgnoreMaxMemoryRows = "IGNORE_MAX_MEMORY_ROWS" // DirectiveAllowScatter lets scatter plans pass through even when they are turned off by `no-scatter`. DirectiveAllowScatter = "ALLOW_SCATTER" // DirectiveAllowHashJoin lets the planner use hash join if possible DirectiveAllowHashJoin = "ALLOW_HASH_JOIN" // DirectiveQueryPlanner lets the user specify per query which planner should be used DirectiveQueryPlanner = "PLANNER" )
const ( // Select.Distinct AllStr = "all " DistinctStr = "distinct " StraightJoinHint = "straight_join " SQLCalcFoundRowsStr = "sql_calc_found_rows " // Select.Lock NoLockStr = "" ForUpdateStr = " for update" // Select.Cache SQLCacheStr = "sql_cache " SQLNoCacheStr = "sql_no_cache " // Union.Type UnionStr = "union" UnionAllStr = "union all" UnionDistinctStr = "union distinct" // DDL strings. InsertStr = "insert" ReplaceStr = "replace" // Set.Scope or Show.Scope SessionStr = "session" GlobalStr = "global" VitessMetadataStr = "vitess_metadata" VariableStr = "variable" LocalStr = "local" ImplicitStr = "" // DDL strings. CreateStr = "create" AlterStr = "alter" DeallocateStr = "deallocate" DropStr = "drop" RenameStr = "rename" TruncateStr = "truncate" FlushStr = "flush" CreateVindexStr = "create vindex" DropVindexStr = "drop vindex" AddVschemaTableStr = "add vschema table" DropVschemaTableStr = "drop vschema table" AddColVindexStr = "on table add vindex" DropColVindexStr = "on table drop vindex" AddSequenceStr = "add sequence" AddAutoIncStr = "add auto_increment" // Partition and subpartition type strings HashTypeStr = "hash" KeyTypeStr = "key" RangeTypeStr = "range" ListTypeStr = "list" // Partition value range type strings LessThanTypeStr = "less than" InTypeStr = "in" // Online DDL hint OnlineStr = "online" // Vindex DDL param to specify the owner of a vindex VindexOwnerStr = "owner" // Partition strings ReorganizeStr = "reorganize partition" AddStr = "add partition" DiscardStr = "discard partition" DropPartitionStr = "drop partition" ImportStr = "import partition" TruncatePartitionStr = "truncate partition" CoalesceStr = "coalesce partition" ExchangeStr = "exchange partition" AnalyzePartitionStr = "analyze partition" CheckStr = "check partition" OptimizeStr = "optimize partition" RebuildStr = "rebuild partition" RepairStr = "repair partition" RemoveStr = "remove partitioning" UpgradeStr = "upgrade partitioning" // JoinTableExpr.Join JoinStr = "join" StraightJoinStr = "straight_join" LeftJoinStr = "left join" RightJoinStr = "right join" NaturalJoinStr = "natural join" NaturalLeftJoinStr = "natural left join" NaturalRightJoinStr = "natural right join" // Index hints. UseStr = "use " IgnoreStr = "ignore " ForceStr = "force " // Index hints For types. JoinForStr = "join" GroupByForStr = "group by" OrderByForStr = "order by" // Where.Type WhereStr = "where" HavingStr = "having" // ComparisonExpr.Operator EqualStr = "=" LessThanStr = "<" GreaterThanStr = ">" LessEqualStr = "<=" GreaterEqualStr = ">=" NotEqualStr = "!=" NullSafeEqualStr = "<=>" InStr = "in" NotInStr = "not in" LikeStr = "like" NotLikeStr = "not like" RegexpStr = "regexp" NotRegexpStr = "not regexp" // IsExpr.Operator IsNullStr = "is null" IsNotNullStr = "is not null" IsTrueStr = "is true" IsNotTrueStr = "is not true" IsFalseStr = "is false" IsNotFalseStr = "is not false" // BinaryExpr.Operator BitAndStr = "&" BitOrStr = "|" BitXorStr = "^" PlusStr = "+" MinusStr = "-" MultStr = "*" DivStr = "/" IntDivStr = "div" ModStr = "%" ShiftLeftStr = "<<" ShiftRightStr = ">>" JSONExtractOpStr = "->" JSONUnquoteExtractOpStr = "->>" // UnaryExpr.Operator UPlusStr = "+" UMinusStr = "-" TildaStr = "~" BangStr = "!" Armscii8Str = "_armscii8" ASCIIStr = "_ascii" Big5Str = "_big5" UBinaryStr = "_binary" Cp1250Str = "_cp1250" Cp1251Str = "_cp1251" Cp1256Str = "_cp1256" Cp1257Str = "_cp1257" Cp850Str = "_cp850" Cp852Str = "_cp852" Cp866Str = "_cp866" Cp932Str = "_cp932" Dec8Str = "_dec8" EucjpmsStr = "_eucjpms" EuckrStr = "_euckr" Gb18030Str = "_gb18030" Gb2312Str = "_gb2312" GbkStr = "_gbk" Geostd8Str = "_geostd8" GreekStr = "_greek" HebrewStr = "_hebrew" Hp8Str = "_hp8" Keybcs2Str = "_keybcs2" Koi8rStr = "_koi8r" Koi8uStr = "_koi8u" Latin1Str = "_latin1" Latin2Str = "_latin2" Latin5Str = "_latin5" Latin7Str = "_latin7" MacceStr = "_macce" MacromanStr = "_macroman" SjisStr = "_sjis" Swe7Str = "_swe7" Tis620Str = "_tis620" Ucs2Str = "_ucs2" UjisStr = "_ujis" Utf16Str = "_utf16" Utf16leStr = "_utf16le" Utf32Str = "_utf32" Utf8Str = "_utf8" Utf8mb4Str = "_utf8mb4" NStringStr = "N" // DatabaseOption.Type CharacterSetStr = " character set" CollateStr = " collate" EncryptionStr = " encryption" // MatchExpr.Option NoOptionStr = "" BooleanModeStr = " in boolean mode" NaturalLanguageModeStr = " in natural language mode" NaturalLanguageModeWithQueryExpansionStr = " in natural language mode with query expansion" QueryExpansionStr = " with query expansion" // INTO OUTFILE IntoOutfileStr = " into outfile " IntoOutfileS3Str = " into outfile s3 " IntoDumpfileStr = " into dumpfile " // Order.Direction AscScr = "asc" DescScr = "desc" // SetExpr.Expr, for SET TRANSACTION ... or START TRANSACTION // TransactionStr is the Name for a SET TRANSACTION statement TransactionStr = "transaction" // Transaction isolation levels ReadUncommittedStr = "read uncommitted" ReadCommittedStr = "read committed" RepeatableReadStr = "repeatable read" SerializableStr = "serializable" TxReadOnly = "read only" TxReadWrite = "read write" // Explain formats EmptyStr = "" TreeStr = "tree" JSONStr = "json" VitessStr = "vitess" TraditionalStr = "traditional" AnalyzeStr = "analyze" // Lock Types ReadStr = "read" ReadLocalStr = "read local" WriteStr = "write" LowPriorityWriteStr = "low_priority write" // ShowCommand Types CharsetStr = " charset" CollationStr = " collation" ColumnStr = " columns" CreateDbStr = " create database" CreateEStr = " create event" CreateFStr = " create function" CreateProcStr = " create procedure" CreateTblStr = " create table" CreateTrStr = " create trigger" CreateVStr = " create view" DatabaseStr = " databases" EnginesStr = " engines" FunctionCStr = " function code" FunctionStr = " function status" GtidExecGlobalStr = " global gtid_executed" IndexStr = " indexes" OpenTableStr = " open tables" PluginsStr = " plugins" PrivilegeStr = " privileges" ProcedureCStr = " procedure code" ProcedureStr = " procedure status" StatusGlobalStr = " global status" StatusSessionStr = " status" TableStr = " tables" TableStatusStr = " table status" TriggerStr = " triggers" VariableGlobalStr = " global variables" VariableSessionStr = " variables" VGtidExecGlobalStr = " global vgtid_executed" KeyspaceStr = " keyspaces" VitessMigrationsStr = " vitess_migrations" VitessReplicationStatusStr = " vitess_replication_status" VitessShardsStr = " vitess_shards" VitessTabletsStr = " vitess_tablets" VitessTargetStr = " vitess_target" VitessVariablesStr = " vitess_metadata variables" VschemaTablesStr = " vschema tables" VschemaVindexesStr = " vschema vindexes" WarningsStr = " warnings" // DropKeyType strings PrimaryKeyTypeStr = "primary key" ForeignKeyTypeStr = "foreign key" NormalKeyTypeStr = "key" CheckKeyTypeStr = "check" // TrimType strings BothTrimStr = "both" LeadingTrimStr = "leading" TrailingTrimStr = "trailing" // TrimFuncType strings NormalTrimStr = "trim" LTrimStr = "ltrim" RTrimStr = "rtrim" // JSONAttributeType strings DepthAttributeStr = "json_depth" ValidAttributeStr = "json_valid" TypeAttributeStr = "json_type" LengthAttributeStr = "json_length" // JSONValueModifierType strings JSONArrayAppendStr = "json_array_append" JSONArrayInsertStr = "json_array_insert" JSONInsertStr = "json_insert" JSONReplaceStr = "json_replace" JSONSetStr = "json_set" // JSONValueMergeType strings JSONMergeStr = "json_merge" JSONMergePatchStr = "json_merge_patch" JSONMergePreserveStr = "json_merge_preserve" // LockOptionType strings NoneTypeStr = "none" DefaultTypeStr = "default" ExclusiveTypeStr = "exclusive" // IntervalTypes strings DayStr = "day" WeekStr = "week" MonthStr = "month" YearStr = "year" DayHourStr = "day_hour" DayMicrosecondStr = "day_microsecond" DayMinuteStr = "day_minute" DaySecondStr = "day_second" HourStr = "hour" HourMicrosecondStr = "hour_microsecond" HourMinuteStr = "hour_minute" HourSecondStr = "hour_second" MicrosecondStr = "microsecond" MinuteStr = "minute" MinuteMicrosecondStr = "minute_microsecond" MinuteSecondStr = "minute_second" QuarterStr = "quarter" SecondStr = "second" SecondMicrosecondStr = "second_microsecond" YearMonthStr = "year_month" )
String constants to be used in ast.
const ACTION = 57570
const ACTIVE = 57826
const ADD = 57550
const ADMIN = 57827
const AFTER = 57619
const AGAINST = 57792
const ALGORITHM = 57423
const ALL = 57365
const ALTER = 57546
const ALWAYS = 57383
const ANALYZE = 57549
const AND = 57477
const APPROXNUM = 57685
const ARRAY = 57801
const AS = 57367
const ASC = 57369
const ASCII = 57681
const AT_AT_ID = 57430
const AT_ID = 57429
const AUTOEXTEND_SIZE = 57828
const AUTO_INCREMENT = 57684
const AVG_ROW_LENGTH = 57906
const BEGIN = 57630
const BETWEEN = 57479
const BIGINT = 57644
const BINARY = 57499
const BIT = 57638
const BIT_LITERAL = 57442
const BLOB = 57665
const BOOL = 57657
const BOOLEAN = 57793
const BOTH = 57466
const BUCKETS = 57829
const BY = 57361
const BYTE = 57802
const CALL = 57379
const CANCEL = 57622
const CASCADE = 57571
const CASCADED = 57607
const CASE = 57480
const CAST = 57763
const CHANGE = 57552
const CHANNEL = 57903
const CHAR = 57655
const CHARACTER = 57658
const CHARSET = 57471
const CHECK = 57568
const CHECKSUM = 57908
const CLEANUP = 57625
const CLONE = 57830
const COALESCE = 57585
const CODE = 57689
const COLLATE = 57498
const COLLATION = 57690
const COLUMN = 57564
const COLUMNS = 57691
const COLUMN_FORMAT = 57831
const COMMENT = 57440
const COMMENT_KEYWORD = 57441
const COMMIT = 57633
const COMMITTED = 57728
const COMPACT = 57921
const COMPLETE = 57624
const COMPONENT = 57832
const COMPRESSED = 57919
const COMPRESSION = 57443
const CONNECTION = 57907
const CONSTRAINT = 57572
const CONVERT = 57762
const COPY = 57421
const CREATE = 57545
const CROSS = 57414
const CSV = 57393
const CUME_DIST = 57803
const CURRENT_DATE = 57733
const CURRENT_TIME = 57735
const CURRENT_TIMESTAMP = 57731
const CURRENT_USER = 57738
const DATA = 57386
const DATABASE = 57732
const DATABASES = 57692
const DATE = 57580
const DATETIME = 57653
const DAY = 57742
const DAY_HOUR = 57743
const DAY_MICROSECOND = 57744
const DAY_MINUTE = 57745
const DAY_SECOND = 57746
const DEALLOCATE = 57554
const DECIMAL = 57436
const DECIMAL_TYPE = 57649
const DEFAULT = 57373
const DEFINER = 57608
const DEFINITION = 57833
const DELAY_KEY_WRITE = 57909
const DELETE = 57355
const DENSE_RANK = 57805
const DESC = 57370
const DESCRIBE = 57578
const DESCRIPTION = 57804
const DIRECTORY = 57601
const DISABLE = 57462
const DISCARD = 57459
const DISK = 57928
const DISTINCT = 57366
const DISTINCTROW = 57380
const DIV = 57495
const DO = 57378
const DOUBLE = 57647
const DROP = 57547
const DUMPFILE = 57392
const DUPLICATE = 57372
const DYNAMIC = 57918
const ELSE = 57483
const EMPTY = 57806
const EMPTY_FROM_CLAUSE = 57469
const ENABLE = 57461
const ENCLOSED = 57391
const ENCRYPTION = 57910
const END = 57484
const ENFORCED = 57834
const ENGINE = 57911
const ENGINES = 57693
const ENGINE_ATTRIBUTE = 57835
const ENUM = 57672
const ERROR = 57897
const ESCAPE = 57581
const ESCAPED = 57390
const EVENT = 57694
const EXCEPT = 57807
const EXCHANGE = 57586
const EXCLUDE = 57836
const EXCLUSIVE = 57426
const EXECUTE = 57591
const EXISTS = 57368
const EXPANSION = 57797
const EXPIRE = 57628
const EXPLAIN = 57579
const EXPORT = 57905
const EXPRESSION_PREC_SETTER = 57474
const EXTENDED = 57695
const EXTRACT = 57454
const FALSE = 57457
const FIELDS = 57696
const FIRST = 57618
const FIRST_VALUE = 57808
const FIXED = 57917
const FLOAT = 57435
const FLOAT_TYPE = 57648
const FLUSH = 57551
const FOLLOWING = 57837
const FOR = 57364
const FORCE = 57417
const FOREIGN = 57573
const FORMAT = 57889
const FROM = 57356
const FULL = 57697
const FULLTEXT = 57566
const FUNCTION = 57698
const FUNCTION_CALL_NON_KEYWORD = 57347
const GE = 57486
const GENERAL = 57898
const GENERATED = 57382
const GEOMCOLLECTION = 57838
const GEOMETRY = 57673
const GEOMETRYCOLLECTION = 57677
const GET_MASTER_PUBLIC_KEY = 57839
const GLOBAL = 57720
const GROUP = 57358
const GROUPING = 57809
const GROUPS = 57810
const GROUP_CONCAT = 57766
const GTID_EXECUTED = 57699
const HASH = 57935
const HAVING = 57359
const HEADER = 57394
const HEX = 57431
const HEXNUM = 57437
const HISTOGRAM = 57840
const HISTORY = 57841
const HOSTS = 57899
const HOUR = 57747
const HOUR_MICROSECOND = 57748
const HOUR_MINUTE = 57749
const HOUR_SECOND = 57750
const ID = 57428
const IF = 57562
const IGNORE = 57561
const IMPORT = 57460
const IN = 57492
const INACTIVE = 57842
const INDEX = 57558
const INDEXES = 57569
const INNER = 57412
const INPLACE = 57420
const INSERT = 57353
const INSERT_METHOD = 57912
const INSTANT = 57422
const INT = 57642
const INTEGER = 57643
const INTEGRAL = 57434
const INTERVAL = 57542
const INTNUM = 57645
const INTO = 57371
const INVISIBLE = 57843
const INVOKER = 57616
const IS = 57489
const ISOLATION = 57722
const JOIN = 57408
const JSON = 57669
const JSON_ARRAY = 57774
const JSON_ARRAY_APPEND = 57781
const JSON_ARRAY_INSERT = 57782
const JSON_CONTAINS = 57447
const JSON_CONTAINS_PATH = 57448
const JSON_DEPTH = 57777
const JSON_EXTRACT = 57449
const JSON_EXTRACT_OP = 57543
const JSON_INSERT = 57783
const JSON_KEYS = 57450
const JSON_LENGTH = 57779
const JSON_MERGE = 57784
const JSON_MERGE_PATCH = 57785
const JSON_MERGE_PRESERVE = 57786
const JSON_OBJECT = 57775
const JSON_OVERLAPS = 57451
const JSON_PRETTY = 57444
const JSON_QUOTE = 57776
const JSON_REMOVE = 57787
const JSON_REPLACE = 57788
const JSON_SCHEMA_VALID = 57670
const JSON_SCHEMA_VALIDATION_REPORT = 57671
const JSON_SEARCH = 57452
const JSON_SET = 57789
const JSON_STORAGE_FREE = 57446
const JSON_STORAGE_SIZE = 57445
const JSON_TABLE = 57811
const JSON_TYPE = 57778
const JSON_UNQUOTE = 57790
const JSON_UNQUOTE_EXTRACT_OP = 57544
const JSON_VALID = 57780
const JSON_VALUE = 57453
const KEY = 57473
const KEYS = 57377
const KEYSPACES = 57700
const KEY_BLOCK_SIZE = 57567
const LAG = 57812
const LANGUAGE = 57794
const LAST = 57620
const LAST_INSERT_ID = 57400
const LAST_VALUE = 57813
const LATERAL = 57814
const LE = 57485
const LEAD = 57815
const LEADING = 57467
const LEFT = 57410
const LESS = 57595
const LEVEL = 57723
const LEX_ERROR = 57348
const LIKE = 57490
const LIMIT = 57362
const LINEAR = 57930
const LINES = 57388
const LINESTRING = 57675
const LIST = 57932
const LIST_ARG = 57439
const LOAD = 57387
const LOCAL = 57893
const LOCALTIME = 57736
const LOCALTIMESTAMP = 57737
const LOCK = 57375
const LOCKED = 57844
const LOGS = 57896
const LONGBLOB = 57668
const LONGTEXT = 57664
const LOWER_THAN_CHARSET = 57470
const LOW_PRIORITY = 57894
const LTRIM = 57771
const MANIFEST = 57395
const MASTER_COMPRESSION_ALGORITHMS = 57845
const MASTER_PUBLIC_KEY_PATH = 57846
const MASTER_TLS_CIPHERSUITES = 57847
const MASTER_ZSTD_COMPRESSION_LEVEL = 57848
const MATCH = 57791
const MAXVALUE = 57592
const MAX_ROWS = 57913
const MEDIUMBLOB = 57667
const MEDIUMINT = 57641
const MEDIUMTEXT = 57663
const MEMBER = 57346
const MEMORY = 57927
const MERGE = 57613
const MICROSECOND = 57751
const MINUTE = 57752
const MINUTE_MICROSECOND = 57753
const MINUTE_SECOND = 57754
const MIN_ROWS = 57914
const MOD = 57496
const MODE = 57404
const MODIFY = 57553
const MONTH = 57755
const MULTILINESTRING = 57679
const MULTIPOINT = 57678
const MULTIPOLYGON = 57680
const NAME = 57602
const NAMES = 57719
const NATURAL = 57415
const NCHAR = 57660
const NCHAR_STRING = 57433
const NE = 57487
const NESTED = 57849
const NETWORK_NAMESPACE = 57850
const NEXT = 57401
const NO = 57574
const NONE = 57424
const NOT = 57478
const NOW = 57734
const NOWAIT = 57851
const NO_WRITE_TO_BINLOG = 57895
const NTH_VALUE = 57816
const NTILE = 57817
const NULL = 57455
const NULLS = 57852
const NULLX = 57683
const NULL_SAFE_EQUAL = 57488
const NUMERIC = 57650
const OF = 57818
const OFF = 57458
const OFFSET = 57363
const OJ = 57853
const OLD = 57854
const ON = 57418
const ONLY = 57726
const OPEN = 57701
const OPTIMIZE = 57583
const OPTIMIZER_COSTS = 57900
const OPTION = 57609
const OPTIONAL = 57855
const OPTIONALLY = 57398
const OR = 57475
const ORDER = 57360
const ORDINALITY = 57856
const ORGANIZATION = 57857
const OTHERS = 57858
const OUTER = 57413
const OUTFILE = 57384
const OVER = 57819
const OVERWRITE = 57396
const PACK_KEYS = 57915
const PARSER = 57381
const PARTIAL = 57859
const PARTITION = 57593
const PARTITIONING = 57588
const PARTITIONS = 57929
const PASSWORD = 57916
const PATH = 57860
const PERCENT_RANK = 57820
const PERSIST = 57861
const PERSIST_ONLY = 57862
const PLUGINS = 57702
const POINT = 57674
const POLYGON = 57676
const PRECEDING = 57863
const PREPARE = 57590
const PRIMARY = 57563
const PRIVILEGES = 57703
const PRIVILEGE_CHECKS_USER = 57864
const PROCEDURE = 57597
const PROCESS = 57865
const PROCESSLIST = 57704
const QUARTER = 57756
const QUERY = 57796
const RANDOM = 57866
const RANGE = 57931
const RANK = 57821
const RATIO = 57629
const READ = 57724
const REAL = 57646
const REBUILD = 57587
const RECURSIVE = 57822
const REDUNDANT = 57920
const REFERENCE = 57867
const REFERENCES = 57575
const REGEXP = 57491
const RELAY = 57904
const RELEASE = 57636
const REMOVE = 57589
const RENAME = 57548
const REORGANIZE = 57594
const REPAIR = 57582
const REPEATABLE = 57727
const REPLACE = 57761
const REQUIRE_ROW_FORMAT = 57868
const RESOURCE = 57869
const RESPECT = 57870
const RESTART = 57871
const RESTRICT = 57576
const RETAIN = 57872
const RETRY = 57623
const RETURNING = 57888
const REUSE = 57873
const REVERT = 57555
const RIGHT = 57411
const ROLE = 57874
const ROLLBACK = 57634
const ROW_FORMAT = 57922
const ROW_NUMBER = 57823
const RTRIM = 57772
const S3 = 57385
const SAVEPOINT = 57635
const SCHEMA = 57556
const SCHEMAS = 57705
const SECOND = 57757
const SECONDARY = 57875
const SECONDARY_ENGINE = 57876
const SECONDARY_ENGINE_ATTRIBUTE = 57877
const SECONDARY_LOAD = 57878
const SECONDARY_UNLOAD = 57879
const SECOND_MICROSECOND = 57758
const SECURITY = 57617
const SELECT = 57350
const SEPARATOR = 57767
const SEQUENCE = 57612
const SERIALIZABLE = 57730
const SESSION = 57721
const SET = 57374
const SHARE = 57403
const SHARED = 57425
const SHIFT_LEFT = 57493
const SHIFT_RIGHT = 57494
const SHOW = 57577
const SIGNED = 57686
const SIMPLE = 57880
const SKIP = 57881
const SLOW = 57902
const SMALLINT = 57640
const SPATIAL = 57565
const SQL = 57610
const SQL_CACHE = 57406
const SQL_CALC_FOUND_ROWS = 57407
const SQL_NO_CACHE = 57405
const SRID = 57882
const START = 57631
const STARTING = 57397
const STATS_AUTO_RECALC = 57923
const STATS_PERSISTENT = 57924
const STATS_SAMPLE_PAGES = 57925
const STATUS = 57604
const STORAGE = 57926
const STORED = 57465
const STRAIGHT_JOIN = 57409
const STREAM = 57351
const STRING = 57432
const SUBPARTITION = 57933
const SUBPARTITIONS = 57934
const SUBQUERY_AS_EXPR = 57427
const SUBSTR = 57764
const SUBSTRING = 57765
const SYSTEM = 57824
const TABLE = 57557
const TABLES = 57706
const TABLESPACE = 57463
const TEMPORARY = 57614
const TEMPTABLE = 57615
const TERMINATED = 57389
const TEXT = 57661
const THAN = 57596
const THEN = 57482
const THREAD_PRIORITY = 57883
const THROTTLE = 57626
const TIES = 57884
const TIME = 57651
const TIMESTAMP = 57652
const TIMESTAMPADD = 57768
const TIMESTAMPDIFF = 57769
const TINYBLOB = 57666
const TINYINT = 57639
const TINYTEXT = 57662
const TO = 57560
const TRADITIONAL = 57892
const TRAILING = 57468
const TRANSACTION = 57632
const TREE = 57890
const TRIGGER = 57598
const TRIGGERS = 57707
const TRIM = 57773
const TRUE = 57456
const TRUNCATE = 57584
const UNARY = 57497
const UNBOUNDED = 57885
const UNCOMMITTED = 57729
const UNDEFINED = 57611
const UNDERSCORE_ARMSCII8 = 57500
const UNDERSCORE_ASCII = 57501
const UNDERSCORE_BIG5 = 57502
const UNDERSCORE_BINARY = 57503
const UNDERSCORE_CP1250 = 57504
const UNDERSCORE_CP1251 = 57505
const UNDERSCORE_CP1256 = 57506
const UNDERSCORE_CP1257 = 57507
const UNDERSCORE_CP850 = 57508
const UNDERSCORE_CP852 = 57509
const UNDERSCORE_CP866 = 57510
const UNDERSCORE_CP932 = 57511
const UNDERSCORE_DEC8 = 57512
const UNDERSCORE_EUCJPMS = 57513
const UNDERSCORE_EUCKR = 57514
const UNDERSCORE_GB18030 = 57515
const UNDERSCORE_GB2312 = 57516
const UNDERSCORE_GBK = 57517
const UNDERSCORE_GEOSTD8 = 57518
const UNDERSCORE_GREEK = 57519
const UNDERSCORE_HEBREW = 57520
const UNDERSCORE_HP8 = 57521
const UNDERSCORE_KEYBCS2 = 57522
const UNDERSCORE_KOI8R = 57523
const UNDERSCORE_KOI8U = 57524
const UNDERSCORE_LATIN1 = 57525
const UNDERSCORE_LATIN2 = 57526
const UNDERSCORE_LATIN5 = 57527
const UNDERSCORE_LATIN7 = 57528
const UNDERSCORE_MACCE = 57529
const UNDERSCORE_MACROMAN = 57530
const UNDERSCORE_SJIS = 57531
const UNDERSCORE_SWE7 = 57532
const UNDERSCORE_TIS620 = 57533
const UNDERSCORE_UCS2 = 57534
const UNDERSCORE_UJIS = 57535
const UNDERSCORE_UTF16 = 57536
const UNDERSCORE_UTF16LE = 57537
const UNDERSCORE_UTF32 = 57538
const UNDERSCORE_UTF8 = 57539
const UNDERSCORE_UTF8MB3 = 57541
const UNDERSCORE_UTF8MB4 = 57540
const UNICODE = 57682
const UNION = 57349
const UNIQUE = 57472
const UNLOCK = 57376
const UNSIGNED = 57687
const UNTHROTTLE = 57627
const UNUSED = 57800
const UPDATE = 57354
const UPGRADE = 57603
const USE = 57416
const USER = 57708
const USER_RESOURCES = 57901
const USING = 57419
const UTC_DATE = 57739
const UTC_TIME = 57740
const UTC_TIMESTAMP = 57741
const VALIDATION = 57799
const VALUE = 57402
const VALUES = 57399
const VALUE_ARG = 57438
const VARBINARY = 57659
const VARCHAR = 57656
const VARIABLES = 57605
const VCPU = 57886
const VGTID_EXECUTED = 57709
const VIEW = 57559
const VINDEX = 57599
const VINDEXES = 57600
const VIRTUAL = 57464
const VISIBLE = 57887
const VITESS = 57891
const VITESS_KEYSPACES = 57710
const VITESS_METADATA = 57711
const VITESS_MIGRATION = 57621
const VITESS_MIGRATIONS = 57712
const VITESS_REPLICATION_STATUS = 57713
const VITESS_SHARDS = 57714
const VITESS_TABLETS = 57715
const VITESS_TARGET = 57716
const VITESS_THROTTLED_APPS = 57718
const VSCHEMA = 57717
const VSTREAM = 57352
const WARNINGS = 57606
const WEEK = 57760
const WEIGHT_STRING = 57770
const WHEN = 57481
const WHERE = 57357
const WINDOW = 57825
const WITH = 57795
const WITHOUT = 57798
const WORK = 57637
const WRITE = 57725
const XOR = 57476
const YEAR = 57654
const YEAR_MONTH = 57759
const ZEROFILL = 57688
Variables ¶
var ( // TruncateUILen truncate queries in debug UIs to the given length. 0 means unlimited. TruncateUILen = flag.Int("sql-max-length-ui", 512, "truncate queries in debug UIs to the given length (default 512)") // TruncateErrLen truncate queries in error logs to the given length. 0 means unlimited. TruncateErrLen = flag.Int("sql-max-length-errors", 0, "truncate queries in error logs to the given length (default unlimited)") )
var Aggregates = map[string]bool{ "avg": true, "bit_and": true, "bit_or": true, "bit_xor": true, "count": true, "group_concat": true, "max": true, "min": true, "std": true, "stddev_pop": true, "stddev_samp": true, "stddev": true, "sum": true, "var_pop": true, "var_samp": true, "variance": true, }
Aggregates is a map of all aggregate functions.
var ErrEmpty = coerrors.NewErrorf(coerrors.Code_INVALID_ARGUMENT, coerrors.EmptyQuery, "query was empty")
ErrEmpty is a sentinel error returned when parsing empty statements.
var MySQLServerVersion = flag.String("mysql_server_version", "", "MySQL server version to advertise.")
MySQLServerVersion is what Vitess will present as it's version during the connection handshake, and as the value to the @@version system variable. If nothing is provided, Vitess will report itself as a specific MySQL version with the vitess version appended to it
var MySQLVersion = "50709" // default version if nothing else is stated
MySQLVersion is the version of MySQL that the parser would emulate
Functions ¶
func AllowScatterDirective ¶
AllowScatterDirective returns true if the allow scatter override is set to true
func CanNormalize ¶
CanNormalize takes Statement and returns if the statement can be normalized.
func CanonicalString ¶
CanonicalString returns a canonical string representation of an SQLNode where all identifiers are always escaped and all SQL syntax is in uppercase. This matches the canonical output from MySQL.
func CloneRefOfBool ¶
CloneRefOfBool creates a deep clone of the input.
func CloneRefOfInt ¶
CloneRefOfInt creates a deep clone of the input.
func CloneSliceOfString ¶
CloneSliceOfString creates a deep clone of the input.
func ContainsAggregation ¶
ContainsAggregation returns true if the expression contains aggregation
func EqualsAlterOption ¶
func EqualsAlterOption(inA, inB AlterOption) bool
EqualsAlterOption does deep equals between the two objects.
func EqualsCallable ¶
EqualsCallable does deep equals between the two objects.
func EqualsCharacteristic ¶
func EqualsCharacteristic(inA, inB Characteristic) bool
EqualsCharacteristic does deep equals between the two objects.
func EqualsColIdent ¶
EqualsColIdent does deep equals between the two objects.
func EqualsColTuple ¶
EqualsColTuple does deep equals between the two objects.
func EqualsColumnCharset ¶
func EqualsColumnCharset(a, b ColumnCharset) bool
EqualsColumnCharset does deep equals between the two objects.
func EqualsColumnType ¶
func EqualsColumnType(a, b ColumnType) bool
EqualsColumnType does deep equals between the two objects.
func EqualsColumns ¶
EqualsColumns does deep equals between the two objects.
func EqualsComments ¶
EqualsComments does deep equals between the two objects.
func EqualsConstraintInfo ¶
func EqualsConstraintInfo(inA, inB ConstraintInfo) bool
EqualsConstraintInfo does deep equals between the two objects.
func EqualsDBDDLStatement ¶
func EqualsDBDDLStatement(inA, inB DBDDLStatement) bool
EqualsDBDDLStatement does deep equals between the two objects.
func EqualsDDLStatement ¶
func EqualsDDLStatement(inA, inB DDLStatement) bool
EqualsDDLStatement does deep equals between the two objects.
func EqualsDatabaseOption ¶
func EqualsDatabaseOption(a, b DatabaseOption) bool
EqualsDatabaseOption does deep equals between the two objects.
func EqualsExplain ¶
EqualsExplain does deep equals between the two objects.
func EqualsExpr ¶
EqualsExpr does deep equals between the two objects.
func EqualsExprs ¶
EqualsExprs does deep equals between the two objects.
func EqualsGroupBy ¶
EqualsGroupBy does deep equals between the two objects.
func EqualsIndexHints ¶
func EqualsIndexHints(a, b IndexHints) bool
EqualsIndexHints does deep equals between the two objects.
func EqualsInsertRows ¶
func EqualsInsertRows(inA, inB InsertRows) bool
EqualsInsertRows does deep equals between the two objects.
func EqualsJSONObjectParam ¶
func EqualsJSONObjectParam(a, b JSONObjectParam) bool
EqualsJSONObjectParam does deep equals between the two objects.
func EqualsJSONPathParam ¶
func EqualsJSONPathParam(inA, inB JSONPathParam) bool
EqualsJSONPathParam does deep equals between the two objects.
func EqualsOnDup ¶
EqualsOnDup does deep equals between the two objects.
func EqualsOrderBy ¶
EqualsOrderBy does deep equals between the two objects.
func EqualsPartitions ¶
func EqualsPartitions(a, b Partitions) bool
EqualsPartitions does deep equals between the two objects.
func EqualsRefOfAddColumns ¶
func EqualsRefOfAddColumns(a, b *AddColumns) bool
EqualsRefOfAddColumns does deep equals between the two objects.
func EqualsRefOfAddConstraintDefinition ¶
func EqualsRefOfAddConstraintDefinition(a, b *AddConstraintDefinition) bool
EqualsRefOfAddConstraintDefinition does deep equals between the two objects.
func EqualsRefOfAddIndexDefinition ¶
func EqualsRefOfAddIndexDefinition(a, b *AddIndexDefinition) bool
EqualsRefOfAddIndexDefinition does deep equals between the two objects.
func EqualsRefOfAliasedExpr ¶
func EqualsRefOfAliasedExpr(a, b *AliasedExpr) bool
EqualsRefOfAliasedExpr does deep equals between the two objects.
func EqualsRefOfAliasedTableExpr ¶
func EqualsRefOfAliasedTableExpr(a, b *AliasedTableExpr) bool
EqualsRefOfAliasedTableExpr does deep equals between the two objects.
func EqualsRefOfAlterCharset ¶
func EqualsRefOfAlterCharset(a, b *AlterCharset) bool
EqualsRefOfAlterCharset does deep equals between the two objects.
func EqualsRefOfAlterCheck ¶
func EqualsRefOfAlterCheck(a, b *AlterCheck) bool
EqualsRefOfAlterCheck does deep equals between the two objects.
func EqualsRefOfAlterColumn ¶
func EqualsRefOfAlterColumn(a, b *AlterColumn) bool
EqualsRefOfAlterColumn does deep equals between the two objects.
func EqualsRefOfAlterDatabase ¶
func EqualsRefOfAlterDatabase(a, b *AlterDatabase) bool
EqualsRefOfAlterDatabase does deep equals between the two objects.
func EqualsRefOfAlterIndex ¶
func EqualsRefOfAlterIndex(a, b *AlterIndex) bool
EqualsRefOfAlterIndex does deep equals between the two objects.
func EqualsRefOfAlterMigration ¶
func EqualsRefOfAlterMigration(a, b *AlterMigration) bool
EqualsRefOfAlterMigration does deep equals between the two objects.
func EqualsRefOfAlterTable ¶
func EqualsRefOfAlterTable(a, b *AlterTable) bool
EqualsRefOfAlterTable does deep equals between the two objects.
func EqualsRefOfAlterView ¶
EqualsRefOfAlterView does deep equals between the two objects.
func EqualsRefOfAlterVschema ¶
func EqualsRefOfAlterVschema(a, b *AlterVschema) bool
EqualsRefOfAlterVschema does deep equals between the two objects.
func EqualsRefOfAndExpr ¶
EqualsRefOfAndExpr does deep equals between the two objects.
func EqualsRefOfAutoIncSpec ¶
func EqualsRefOfAutoIncSpec(a, b *AutoIncSpec) bool
EqualsRefOfAutoIncSpec does deep equals between the two objects.
func EqualsRefOfBegin ¶
EqualsRefOfBegin does deep equals between the two objects.
func EqualsRefOfBetweenExpr ¶
func EqualsRefOfBetweenExpr(a, b *BetweenExpr) bool
EqualsRefOfBetweenExpr does deep equals between the two objects.
func EqualsRefOfBinaryExpr ¶
func EqualsRefOfBinaryExpr(a, b *BinaryExpr) bool
EqualsRefOfBinaryExpr does deep equals between the two objects.
func EqualsRefOfBool ¶
EqualsRefOfBool does deep equals between the two objects.
func EqualsRefOfCallProc ¶
EqualsRefOfCallProc does deep equals between the two objects.
func EqualsRefOfCaseExpr ¶
EqualsRefOfCaseExpr does deep equals between the two objects.
func EqualsRefOfChangeColumn ¶
func EqualsRefOfChangeColumn(a, b *ChangeColumn) bool
EqualsRefOfChangeColumn does deep equals between the two objects.
func EqualsRefOfCheckConstraintDefinition ¶
func EqualsRefOfCheckConstraintDefinition(a, b *CheckConstraintDefinition) bool
EqualsRefOfCheckConstraintDefinition does deep equals between the two objects.
func EqualsRefOfColIdent ¶
EqualsRefOfColIdent does deep equals between the two objects.
func EqualsRefOfColName ¶
EqualsRefOfColName does deep equals between the two objects.
func EqualsRefOfCollateExpr ¶
func EqualsRefOfCollateExpr(a, b *CollateExpr) bool
EqualsRefOfCollateExpr does deep equals between the two objects.
func EqualsRefOfColumnCharset ¶
func EqualsRefOfColumnCharset(a, b *ColumnCharset) bool
EqualsRefOfColumnCharset does deep equals between the two objects.
func EqualsRefOfColumnDefinition ¶
func EqualsRefOfColumnDefinition(a, b *ColumnDefinition) bool
EqualsRefOfColumnDefinition does deep equals between the two objects.
func EqualsRefOfColumnType ¶
func EqualsRefOfColumnType(a, b *ColumnType) bool
EqualsRefOfColumnType does deep equals between the two objects.
func EqualsRefOfColumnTypeOptions ¶
func EqualsRefOfColumnTypeOptions(a, b *ColumnTypeOptions) bool
EqualsRefOfColumnTypeOptions does deep equals between the two objects.
func EqualsRefOfCommit ¶
EqualsRefOfCommit does deep equals between the two objects.
func EqualsRefOfCommonTableExpr ¶
func EqualsRefOfCommonTableExpr(a, b *CommonTableExpr) bool
EqualsRefOfCommonTableExpr does deep equals between the two objects.
func EqualsRefOfComparisonExpr ¶
func EqualsRefOfComparisonExpr(a, b *ComparisonExpr) bool
EqualsRefOfComparisonExpr does deep equals between the two objects.
func EqualsRefOfConstraintDefinition ¶
func EqualsRefOfConstraintDefinition(a, b *ConstraintDefinition) bool
EqualsRefOfConstraintDefinition does deep equals between the two objects.
func EqualsRefOfConvertExpr ¶
func EqualsRefOfConvertExpr(a, b *ConvertExpr) bool
EqualsRefOfConvertExpr does deep equals between the two objects.
func EqualsRefOfConvertType ¶
func EqualsRefOfConvertType(a, b *ConvertType) bool
EqualsRefOfConvertType does deep equals between the two objects.
func EqualsRefOfConvertUsingExpr ¶
func EqualsRefOfConvertUsingExpr(a, b *ConvertUsingExpr) bool
EqualsRefOfConvertUsingExpr does deep equals between the two objects.
func EqualsRefOfCreateDatabase ¶
func EqualsRefOfCreateDatabase(a, b *CreateDatabase) bool
EqualsRefOfCreateDatabase does deep equals between the two objects.
func EqualsRefOfCreateTable ¶
func EqualsRefOfCreateTable(a, b *CreateTable) bool
EqualsRefOfCreateTable does deep equals between the two objects.
func EqualsRefOfCreateView ¶
func EqualsRefOfCreateView(a, b *CreateView) bool
EqualsRefOfCreateView does deep equals between the two objects.
func EqualsRefOfCurTimeFuncExpr ¶
func EqualsRefOfCurTimeFuncExpr(a, b *CurTimeFuncExpr) bool
EqualsRefOfCurTimeFuncExpr does deep equals between the two objects.
func EqualsRefOfDatabaseOption ¶
func EqualsRefOfDatabaseOption(a, b *DatabaseOption) bool
EqualsRefOfDatabaseOption does deep equals between the two objects.
func EqualsRefOfDeallocateStmt ¶
func EqualsRefOfDeallocateStmt(a, b *DeallocateStmt) bool
EqualsRefOfDeallocateStmt does deep equals between the two objects.
func EqualsRefOfDefault ¶
EqualsRefOfDefault does deep equals between the two objects.
func EqualsRefOfDefiner ¶
EqualsRefOfDefiner does deep equals between the two objects.
func EqualsRefOfDelete ¶
EqualsRefOfDelete does deep equals between the two objects.
func EqualsRefOfDerivedTable ¶
func EqualsRefOfDerivedTable(a, b *DerivedTable) bool
EqualsRefOfDerivedTable does deep equals between the two objects.
func EqualsRefOfDropColumn ¶
func EqualsRefOfDropColumn(a, b *DropColumn) bool
EqualsRefOfDropColumn does deep equals between the two objects.
func EqualsRefOfDropDatabase ¶
func EqualsRefOfDropDatabase(a, b *DropDatabase) bool
EqualsRefOfDropDatabase does deep equals between the two objects.
func EqualsRefOfDropKey ¶
EqualsRefOfDropKey does deep equals between the two objects.
func EqualsRefOfDropTable ¶
EqualsRefOfDropTable does deep equals between the two objects.
func EqualsRefOfDropView ¶
EqualsRefOfDropView does deep equals between the two objects.
func EqualsRefOfExecuteStmt ¶
func EqualsRefOfExecuteStmt(a, b *ExecuteStmt) bool
EqualsRefOfExecuteStmt does deep equals between the two objects.
func EqualsRefOfExistsExpr ¶
func EqualsRefOfExistsExpr(a, b *ExistsExpr) bool
EqualsRefOfExistsExpr does deep equals between the two objects.
func EqualsRefOfExplainStmt ¶
func EqualsRefOfExplainStmt(a, b *ExplainStmt) bool
EqualsRefOfExplainStmt does deep equals between the two objects.
func EqualsRefOfExplainTab ¶
func EqualsRefOfExplainTab(a, b *ExplainTab) bool
EqualsRefOfExplainTab does deep equals between the two objects.
func EqualsRefOfExtractFuncExpr ¶
func EqualsRefOfExtractFuncExpr(a, b *ExtractFuncExpr) bool
EqualsRefOfExtractFuncExpr does deep equals between the two objects.
func EqualsRefOfExtractedSubquery ¶
func EqualsRefOfExtractedSubquery(a, b *ExtractedSubquery) bool
EqualsRefOfExtractedSubquery does deep equals between the two objects.
func EqualsRefOfFlush ¶
EqualsRefOfFlush does deep equals between the two objects.
func EqualsRefOfForce ¶
EqualsRefOfForce does deep equals between the two objects.
func EqualsRefOfForeignKeyDefinition ¶
func EqualsRefOfForeignKeyDefinition(a, b *ForeignKeyDefinition) bool
EqualsRefOfForeignKeyDefinition does deep equals between the two objects.
func EqualsRefOfFuncExpr ¶
EqualsRefOfFuncExpr does deep equals between the two objects.
func EqualsRefOfGroupConcatExpr ¶
func EqualsRefOfGroupConcatExpr(a, b *GroupConcatExpr) bool
EqualsRefOfGroupConcatExpr does deep equals between the two objects.
func EqualsRefOfIndexColumn ¶
func EqualsRefOfIndexColumn(a, b *IndexColumn) bool
EqualsRefOfIndexColumn does deep equals between the two objects.
func EqualsRefOfIndexDefinition ¶
func EqualsRefOfIndexDefinition(a, b *IndexDefinition) bool
EqualsRefOfIndexDefinition does deep equals between the two objects.
func EqualsRefOfIndexHint ¶
EqualsRefOfIndexHint does deep equals between the two objects.
func EqualsRefOfIndexInfo ¶
EqualsRefOfIndexInfo does deep equals between the two objects.
func EqualsRefOfIndexOption ¶
func EqualsRefOfIndexOption(a, b *IndexOption) bool
EqualsRefOfIndexOption does deep equals between the two objects.
func EqualsRefOfInsert ¶
EqualsRefOfInsert does deep equals between the two objects.
func EqualsRefOfInt ¶
EqualsRefOfInt does deep equals between the two objects.
func EqualsRefOfIntervalExpr ¶
func EqualsRefOfIntervalExpr(a, b *IntervalExpr) bool
EqualsRefOfIntervalExpr does deep equals between the two objects.
func EqualsRefOfIntroducerExpr ¶
func EqualsRefOfIntroducerExpr(a, b *IntroducerExpr) bool
EqualsRefOfIntroducerExpr does deep equals between the two objects.
func EqualsRefOfIsExpr ¶
EqualsRefOfIsExpr does deep equals between the two objects.
func EqualsRefOfJSONArrayExpr ¶
func EqualsRefOfJSONArrayExpr(a, b *JSONArrayExpr) bool
EqualsRefOfJSONArrayExpr does deep equals between the two objects.
func EqualsRefOfJSONAttributesExpr ¶
func EqualsRefOfJSONAttributesExpr(a, b *JSONAttributesExpr) bool
EqualsRefOfJSONAttributesExpr does deep equals between the two objects.
func EqualsRefOfJSONContainsExpr ¶
func EqualsRefOfJSONContainsExpr(a, b *JSONContainsExpr) bool
EqualsRefOfJSONContainsExpr does deep equals between the two objects.
func EqualsRefOfJSONContainsPathExpr ¶
func EqualsRefOfJSONContainsPathExpr(a, b *JSONContainsPathExpr) bool
EqualsRefOfJSONContainsPathExpr does deep equals between the two objects.
func EqualsRefOfJSONExtractExpr ¶
func EqualsRefOfJSONExtractExpr(a, b *JSONExtractExpr) bool
EqualsRefOfJSONExtractExpr does deep equals between the two objects.
func EqualsRefOfJSONKeysExpr ¶
func EqualsRefOfJSONKeysExpr(a, b *JSONKeysExpr) bool
EqualsRefOfJSONKeysExpr does deep equals between the two objects.
func EqualsRefOfJSONObjectExpr ¶
func EqualsRefOfJSONObjectExpr(a, b *JSONObjectExpr) bool
EqualsRefOfJSONObjectExpr does deep equals between the two objects.
func EqualsRefOfJSONObjectParam ¶
func EqualsRefOfJSONObjectParam(a, b *JSONObjectParam) bool
EqualsRefOfJSONObjectParam does deep equals between the two objects.
func EqualsRefOfJSONOverlapsExpr ¶
func EqualsRefOfJSONOverlapsExpr(a, b *JSONOverlapsExpr) bool
EqualsRefOfJSONOverlapsExpr does deep equals between the two objects.
func EqualsRefOfJSONPrettyExpr ¶
func EqualsRefOfJSONPrettyExpr(a, b *JSONPrettyExpr) bool
EqualsRefOfJSONPrettyExpr does deep equals between the two objects.
func EqualsRefOfJSONQuoteExpr ¶
func EqualsRefOfJSONQuoteExpr(a, b *JSONQuoteExpr) bool
EqualsRefOfJSONQuoteExpr does deep equals between the two objects.
func EqualsRefOfJSONRemoveExpr ¶
func EqualsRefOfJSONRemoveExpr(a, b *JSONRemoveExpr) bool
EqualsRefOfJSONRemoveExpr does deep equals between the two objects.
func EqualsRefOfJSONSchemaValidFuncExpr ¶
func EqualsRefOfJSONSchemaValidFuncExpr(a, b *JSONSchemaValidFuncExpr) bool
EqualsRefOfJSONSchemaValidFuncExpr does deep equals between the two objects.
func EqualsRefOfJSONSchemaValidationReportFuncExpr ¶
func EqualsRefOfJSONSchemaValidationReportFuncExpr(a, b *JSONSchemaValidationReportFuncExpr) bool
EqualsRefOfJSONSchemaValidationReportFuncExpr does deep equals between the two objects.
func EqualsRefOfJSONSearchExpr ¶
func EqualsRefOfJSONSearchExpr(a, b *JSONSearchExpr) bool
EqualsRefOfJSONSearchExpr does deep equals between the two objects.
func EqualsRefOfJSONStorageFreeExpr ¶
func EqualsRefOfJSONStorageFreeExpr(a, b *JSONStorageFreeExpr) bool
EqualsRefOfJSONStorageFreeExpr does deep equals between the two objects.
func EqualsRefOfJSONStorageSizeExpr ¶
func EqualsRefOfJSONStorageSizeExpr(a, b *JSONStorageSizeExpr) bool
EqualsRefOfJSONStorageSizeExpr does deep equals between the two objects.
func EqualsRefOfJSONTableExpr ¶
func EqualsRefOfJSONTableExpr(a, b *JSONTableExpr) bool
EqualsRefOfJSONTableExpr does deep equals between the two objects.
func EqualsRefOfJSONUnquoteExpr ¶
func EqualsRefOfJSONUnquoteExpr(a, b *JSONUnquoteExpr) bool
EqualsRefOfJSONUnquoteExpr does deep equals between the two objects.
func EqualsRefOfJSONValueExpr ¶
func EqualsRefOfJSONValueExpr(a, b *JSONValueExpr) bool
EqualsRefOfJSONValueExpr does deep equals between the two objects.
func EqualsRefOfJSONValueMergeExpr ¶
func EqualsRefOfJSONValueMergeExpr(a, b *JSONValueMergeExpr) bool
EqualsRefOfJSONValueMergeExpr does deep equals between the two objects.
func EqualsRefOfJSONValueModifierExpr ¶
func EqualsRefOfJSONValueModifierExpr(a, b *JSONValueModifierExpr) bool
EqualsRefOfJSONValueModifierExpr does deep equals between the two objects.
func EqualsRefOfJoinCondition ¶
func EqualsRefOfJoinCondition(a, b *JoinCondition) bool
EqualsRefOfJoinCondition does deep equals between the two objects.
func EqualsRefOfJoinTableExpr ¶
func EqualsRefOfJoinTableExpr(a, b *JoinTableExpr) bool
EqualsRefOfJoinTableExpr does deep equals between the two objects.
func EqualsRefOfJtColumnDefinition ¶
func EqualsRefOfJtColumnDefinition(a, b *JtColumnDefinition) bool
EqualsRefOfJtColumnDefinition does deep equals between the two objects.
func EqualsRefOfJtNestedPathColDef ¶
func EqualsRefOfJtNestedPathColDef(a, b *JtNestedPathColDef) bool
EqualsRefOfJtNestedPathColDef does deep equals between the two objects.
func EqualsRefOfJtOnResponse ¶
func EqualsRefOfJtOnResponse(a, b *JtOnResponse) bool
EqualsRefOfJtOnResponse does deep equals between the two objects.
func EqualsRefOfJtOrdinalColDef ¶
func EqualsRefOfJtOrdinalColDef(a, b *JtOrdinalColDef) bool
EqualsRefOfJtOrdinalColDef does deep equals between the two objects.
func EqualsRefOfJtPathColDef ¶
func EqualsRefOfJtPathColDef(a, b *JtPathColDef) bool
EqualsRefOfJtPathColDef does deep equals between the two objects.
func EqualsRefOfKeyState ¶
EqualsRefOfKeyState does deep equals between the two objects.
func EqualsRefOfLimit ¶
EqualsRefOfLimit does deep equals between the two objects.
func EqualsRefOfLiteral ¶
EqualsRefOfLiteral does deep equals between the two objects.
func EqualsRefOfLoad ¶
EqualsRefOfLoad does deep equals between the two objects.
func EqualsRefOfLockOption ¶
func EqualsRefOfLockOption(a, b *LockOption) bool
EqualsRefOfLockOption does deep equals between the two objects.
func EqualsRefOfLockTables ¶
func EqualsRefOfLockTables(a, b *LockTables) bool
EqualsRefOfLockTables does deep equals between the two objects.
func EqualsRefOfMatchExpr ¶
EqualsRefOfMatchExpr does deep equals between the two objects.
func EqualsRefOfMemberOfExpr ¶
func EqualsRefOfMemberOfExpr(a, b *MemberOfExpr) bool
EqualsRefOfMemberOfExpr does deep equals between the two objects.
func EqualsRefOfModifyColumn ¶
func EqualsRefOfModifyColumn(a, b *ModifyColumn) bool
EqualsRefOfModifyColumn does deep equals between the two objects.
func EqualsRefOfNextval ¶
EqualsRefOfNextval does deep equals between the two objects.
func EqualsRefOfNotExpr ¶
EqualsRefOfNotExpr does deep equals between the two objects.
func EqualsRefOfNullVal ¶
EqualsRefOfNullVal does deep equals between the two objects.
func EqualsRefOfOptLike ¶
EqualsRefOfOptLike does deep equals between the two objects.
func EqualsRefOfOrExpr ¶
EqualsRefOfOrExpr does deep equals between the two objects.
func EqualsRefOfOrder ¶
EqualsRefOfOrder does deep equals between the two objects.
func EqualsRefOfOrderByOption ¶
func EqualsRefOfOrderByOption(a, b *OrderByOption) bool
EqualsRefOfOrderByOption does deep equals between the two objects.
func EqualsRefOfOtherAdmin ¶
func EqualsRefOfOtherAdmin(a, b *OtherAdmin) bool
EqualsRefOfOtherAdmin does deep equals between the two objects.
func EqualsRefOfOtherRead ¶
EqualsRefOfOtherRead does deep equals between the two objects.
func EqualsRefOfParenTableExpr ¶
func EqualsRefOfParenTableExpr(a, b *ParenTableExpr) bool
EqualsRefOfParenTableExpr does deep equals between the two objects.
func EqualsRefOfParsedComments ¶
func EqualsRefOfParsedComments(a, b *ParsedComments) bool
EqualsRefOfParsedComments does deep equals between the two objects.
func EqualsRefOfPartitionDefinition ¶
func EqualsRefOfPartitionDefinition(a, b *PartitionDefinition) bool
EqualsRefOfPartitionDefinition does deep equals between the two objects.
func EqualsRefOfPartitionDefinitionOptions ¶
func EqualsRefOfPartitionDefinitionOptions(a, b *PartitionDefinitionOptions) bool
EqualsRefOfPartitionDefinitionOptions does deep equals between the two objects.
func EqualsRefOfPartitionEngine ¶
func EqualsRefOfPartitionEngine(a, b *PartitionEngine) bool
EqualsRefOfPartitionEngine does deep equals between the two objects.
func EqualsRefOfPartitionOption ¶
func EqualsRefOfPartitionOption(a, b *PartitionOption) bool
EqualsRefOfPartitionOption does deep equals between the two objects.
func EqualsRefOfPartitionSpec ¶
func EqualsRefOfPartitionSpec(a, b *PartitionSpec) bool
EqualsRefOfPartitionSpec does deep equals between the two objects.
func EqualsRefOfPartitionValueRange ¶
func EqualsRefOfPartitionValueRange(a, b *PartitionValueRange) bool
EqualsRefOfPartitionValueRange does deep equals between the two objects.
func EqualsRefOfPrepareStmt ¶
func EqualsRefOfPrepareStmt(a, b *PrepareStmt) bool
EqualsRefOfPrepareStmt does deep equals between the two objects.
func EqualsRefOfReferenceDefinition ¶
func EqualsRefOfReferenceDefinition(a, b *ReferenceDefinition) bool
EqualsRefOfReferenceDefinition does deep equals between the two objects.
func EqualsRefOfRelease ¶
EqualsRefOfRelease does deep equals between the two objects.
func EqualsRefOfRenameIndex ¶
func EqualsRefOfRenameIndex(a, b *RenameIndex) bool
EqualsRefOfRenameIndex does deep equals between the two objects.
func EqualsRefOfRenameTable ¶
func EqualsRefOfRenameTable(a, b *RenameTable) bool
EqualsRefOfRenameTable does deep equals between the two objects.
func EqualsRefOfRenameTableName ¶
func EqualsRefOfRenameTableName(a, b *RenameTableName) bool
EqualsRefOfRenameTableName does deep equals between the two objects.
func EqualsRefOfRenameTablePair ¶
func EqualsRefOfRenameTablePair(a, b *RenameTablePair) bool
EqualsRefOfRenameTablePair does deep equals between the two objects.
func EqualsRefOfRevertMigration ¶
func EqualsRefOfRevertMigration(a, b *RevertMigration) bool
EqualsRefOfRevertMigration does deep equals between the two objects.
func EqualsRefOfRollback ¶
EqualsRefOfRollback does deep equals between the two objects.
func EqualsRefOfRootNode ¶
EqualsRefOfRootNode does deep equals between the two objects.
func EqualsRefOfSRollback ¶
EqualsRefOfSRollback does deep equals between the two objects.
func EqualsRefOfSavepoint ¶
EqualsRefOfSavepoint does deep equals between the two objects.
func EqualsRefOfSelect ¶
EqualsRefOfSelect does deep equals between the two objects.
func EqualsRefOfSelectInto ¶
func EqualsRefOfSelectInto(a, b *SelectInto) bool
EqualsRefOfSelectInto does deep equals between the two objects.
func EqualsRefOfSet ¶
EqualsRefOfSet does deep equals between the two objects.
func EqualsRefOfSetExpr ¶
EqualsRefOfSetExpr does deep equals between the two objects.
func EqualsRefOfSetTransaction ¶
func EqualsRefOfSetTransaction(a, b *SetTransaction) bool
EqualsRefOfSetTransaction does deep equals between the two objects.
func EqualsRefOfShow ¶
EqualsRefOfShow does deep equals between the two objects.
func EqualsRefOfShowBasic ¶
EqualsRefOfShowBasic does deep equals between the two objects.
func EqualsRefOfShowCreate ¶
func EqualsRefOfShowCreate(a, b *ShowCreate) bool
EqualsRefOfShowCreate does deep equals between the two objects.
func EqualsRefOfShowFilter ¶
func EqualsRefOfShowFilter(a, b *ShowFilter) bool
EqualsRefOfShowFilter does deep equals between the two objects.
func EqualsRefOfShowMigrationLogs ¶
func EqualsRefOfShowMigrationLogs(a, b *ShowMigrationLogs) bool
EqualsRefOfShowMigrationLogs does deep equals between the two objects.
func EqualsRefOfShowOther ¶
EqualsRefOfShowOther does deep equals between the two objects.
func EqualsRefOfShowThrottledApps ¶
func EqualsRefOfShowThrottledApps(a, b *ShowThrottledApps) bool
EqualsRefOfShowThrottledApps does deep equals between the two objects.
func EqualsRefOfStarExpr ¶
EqualsRefOfStarExpr does deep equals between the two objects.
func EqualsRefOfStream ¶
EqualsRefOfStream does deep equals between the two objects.
func EqualsRefOfSubPartition ¶
func EqualsRefOfSubPartition(a, b *SubPartition) bool
EqualsRefOfSubPartition does deep equals between the two objects.
func EqualsRefOfSubPartitionDefinition ¶
func EqualsRefOfSubPartitionDefinition(a, b *SubPartitionDefinition) bool
EqualsRefOfSubPartitionDefinition does deep equals between the two objects.
func EqualsRefOfSubPartitionDefinitionOptions ¶
func EqualsRefOfSubPartitionDefinitionOptions(a, b *SubPartitionDefinitionOptions) bool
EqualsRefOfSubPartitionDefinitionOptions does deep equals between the two objects.
func EqualsRefOfSubquery ¶
EqualsRefOfSubquery does deep equals between the two objects.
func EqualsRefOfSubstrExpr ¶
func EqualsRefOfSubstrExpr(a, b *SubstrExpr) bool
EqualsRefOfSubstrExpr does deep equals between the two objects.
func EqualsRefOfTableAndLockType ¶
func EqualsRefOfTableAndLockType(a, b *TableAndLockType) bool
EqualsRefOfTableAndLockType does deep equals between the two objects.
func EqualsRefOfTableIdent ¶
func EqualsRefOfTableIdent(a, b *TableIdent) bool
EqualsRefOfTableIdent does deep equals between the two objects.
func EqualsRefOfTableName ¶
EqualsRefOfTableName does deep equals between the two objects.
func EqualsRefOfTableOption ¶
func EqualsRefOfTableOption(a, b *TableOption) bool
EqualsRefOfTableOption does deep equals between the two objects.
func EqualsRefOfTableSpec ¶
EqualsRefOfTableSpec does deep equals between the two objects.
func EqualsRefOfTablespaceOperation ¶
func EqualsRefOfTablespaceOperation(a, b *TablespaceOperation) bool
EqualsRefOfTablespaceOperation does deep equals between the two objects.
func EqualsRefOfTimestampFuncExpr ¶
func EqualsRefOfTimestampFuncExpr(a, b *TimestampFuncExpr) bool
EqualsRefOfTimestampFuncExpr does deep equals between the two objects.
func EqualsRefOfTrimFuncExpr ¶
func EqualsRefOfTrimFuncExpr(a, b *TrimFuncExpr) bool
EqualsRefOfTrimFuncExpr does deep equals between the two objects.
func EqualsRefOfTruncateTable ¶
func EqualsRefOfTruncateTable(a, b *TruncateTable) bool
EqualsRefOfTruncateTable does deep equals between the two objects.
func EqualsRefOfUnaryExpr ¶
EqualsRefOfUnaryExpr does deep equals between the two objects.
func EqualsRefOfUnion ¶
EqualsRefOfUnion does deep equals between the two objects.
func EqualsRefOfUnlockTables ¶
func EqualsRefOfUnlockTables(a, b *UnlockTables) bool
EqualsRefOfUnlockTables does deep equals between the two objects.
func EqualsRefOfUpdate ¶
EqualsRefOfUpdate does deep equals between the two objects.
func EqualsRefOfUpdateExpr ¶
func EqualsRefOfUpdateExpr(a, b *UpdateExpr) bool
EqualsRefOfUpdateExpr does deep equals between the two objects.
func EqualsRefOfUse ¶
EqualsRefOfUse does deep equals between the two objects.
func EqualsRefOfVStream ¶
EqualsRefOfVStream does deep equals between the two objects.
func EqualsRefOfValidation ¶
func EqualsRefOfValidation(a, b *Validation) bool
EqualsRefOfValidation does deep equals between the two objects.
func EqualsRefOfValuesFuncExpr ¶
func EqualsRefOfValuesFuncExpr(a, b *ValuesFuncExpr) bool
EqualsRefOfValuesFuncExpr does deep equals between the two objects.
func EqualsRefOfVindexParam ¶
func EqualsRefOfVindexParam(a, b *VindexParam) bool
EqualsRefOfVindexParam does deep equals between the two objects.
func EqualsRefOfVindexSpec ¶
func EqualsRefOfVindexSpec(a, b *VindexSpec) bool
EqualsRefOfVindexSpec does deep equals between the two objects.
func EqualsRefOfWeightStringFuncExpr ¶
func EqualsRefOfWeightStringFuncExpr(a, b *WeightStringFuncExpr) bool
EqualsRefOfWeightStringFuncExpr does deep equals between the two objects.
func EqualsRefOfWhen ¶
EqualsRefOfWhen does deep equals between the two objects.
func EqualsRefOfWhere ¶
EqualsRefOfWhere does deep equals between the two objects.
func EqualsRefOfWith ¶
EqualsRefOfWith does deep equals between the two objects.
func EqualsRefOfXorExpr ¶
EqualsRefOfXorExpr does deep equals between the two objects.
func EqualsRootNode ¶
EqualsRootNode does deep equals between the two objects.
func EqualsSQLNode ¶
EqualsSQLNode does deep equals between the two objects.
func EqualsSelectExpr ¶
func EqualsSelectExpr(inA, inB SelectExpr) bool
EqualsSelectExpr does deep equals between the two objects.
func EqualsSelectExprs ¶
func EqualsSelectExprs(a, b SelectExprs) bool
EqualsSelectExprs does deep equals between the two objects.
func EqualsSelectStatement ¶
func EqualsSelectStatement(inA, inB SelectStatement) bool
EqualsSelectStatement does deep equals between the two objects.
func EqualsSetExprs ¶
EqualsSetExprs does deep equals between the two objects.
func EqualsShowInternal ¶
func EqualsShowInternal(inA, inB ShowInternal) bool
EqualsShowInternal does deep equals between the two objects.
func EqualsSimpleTableExpr ¶
func EqualsSimpleTableExpr(inA, inB SimpleTableExpr) bool
EqualsSimpleTableExpr does deep equals between the two objects.
func EqualsSliceOfAlterOption ¶
func EqualsSliceOfAlterOption(a, b []AlterOption) bool
EqualsSliceOfAlterOption does deep equals between the two objects.
func EqualsSliceOfCharacteristic ¶
func EqualsSliceOfCharacteristic(a, b []Characteristic) bool
EqualsSliceOfCharacteristic does deep equals between the two objects.
func EqualsSliceOfColIdent ¶
EqualsSliceOfColIdent does deep equals between the two objects.
func EqualsSliceOfDatabaseOption ¶
func EqualsSliceOfDatabaseOption(a, b []DatabaseOption) bool
EqualsSliceOfDatabaseOption does deep equals between the two objects.
func EqualsSliceOfJSONPathParam ¶
func EqualsSliceOfJSONPathParam(a, b []JSONPathParam) bool
EqualsSliceOfJSONPathParam does deep equals between the two objects.
func EqualsSliceOfRefOfColumnDefinition ¶
func EqualsSliceOfRefOfColumnDefinition(a, b []*ColumnDefinition) bool
EqualsSliceOfRefOfColumnDefinition does deep equals between the two objects.
func EqualsSliceOfRefOfCommonTableExpr ¶
func EqualsSliceOfRefOfCommonTableExpr(a, b []*CommonTableExpr) bool
EqualsSliceOfRefOfCommonTableExpr does deep equals between the two objects.
func EqualsSliceOfRefOfConstraintDefinition ¶
func EqualsSliceOfRefOfConstraintDefinition(a, b []*ConstraintDefinition) bool
EqualsSliceOfRefOfConstraintDefinition does deep equals between the two objects.
func EqualsSliceOfRefOfIndexColumn ¶
func EqualsSliceOfRefOfIndexColumn(a, b []*IndexColumn) bool
EqualsSliceOfRefOfIndexColumn does deep equals between the two objects.
func EqualsSliceOfRefOfIndexDefinition ¶
func EqualsSliceOfRefOfIndexDefinition(a, b []*IndexDefinition) bool
EqualsSliceOfRefOfIndexDefinition does deep equals between the two objects.
func EqualsSliceOfRefOfIndexOption ¶
func EqualsSliceOfRefOfIndexOption(a, b []*IndexOption) bool
EqualsSliceOfRefOfIndexOption does deep equals between the two objects.
func EqualsSliceOfRefOfJSONObjectParam ¶
func EqualsSliceOfRefOfJSONObjectParam(a, b []*JSONObjectParam) bool
EqualsSliceOfRefOfJSONObjectParam does deep equals between the two objects.
func EqualsSliceOfRefOfJtColumnDefinition ¶
func EqualsSliceOfRefOfJtColumnDefinition(a, b []*JtColumnDefinition) bool
EqualsSliceOfRefOfJtColumnDefinition does deep equals between the two objects.
func EqualsSliceOfRefOfPartitionDefinition ¶
func EqualsSliceOfRefOfPartitionDefinition(a, b []*PartitionDefinition) bool
EqualsSliceOfRefOfPartitionDefinition does deep equals between the two objects.
func EqualsSliceOfRefOfRenameTablePair ¶
func EqualsSliceOfRefOfRenameTablePair(a, b []*RenameTablePair) bool
EqualsSliceOfRefOfRenameTablePair does deep equals between the two objects.
func EqualsSliceOfRefOfWhen ¶
EqualsSliceOfRefOfWhen does deep equals between the two objects.
func EqualsSliceOfString ¶
EqualsSliceOfString does deep equals between the two objects.
func EqualsSliceOfTableExpr ¶
EqualsSliceOfTableExpr does deep equals between the two objects.
func EqualsSliceOfVindexParam ¶
func EqualsSliceOfVindexParam(a, b []VindexParam) bool
EqualsSliceOfVindexParam does deep equals between the two objects.
func EqualsStatement ¶
EqualsStatement does deep equals between the two objects.
func EqualsSubPartitionDefinitions ¶
func EqualsSubPartitionDefinitions(a, b SubPartitionDefinitions) bool
EqualsSubPartitionDefinitions does deep equals between the two objects.
func EqualsTableAndLockTypes ¶
func EqualsTableAndLockTypes(a, b TableAndLockTypes) bool
EqualsTableAndLockTypes does deep equals between the two objects.
func EqualsTableExpr ¶
EqualsTableExpr does deep equals between the two objects.
func EqualsTableExprs ¶
func EqualsTableExprs(a, b TableExprs) bool
EqualsTableExprs does deep equals between the two objects.
func EqualsTableIdent ¶
func EqualsTableIdent(a, b TableIdent) bool
EqualsTableIdent does deep equals between the two objects.
func EqualsTableName ¶
EqualsTableName does deep equals between the two objects.
func EqualsTableNames ¶
func EqualsTableNames(a, b TableNames) bool
EqualsTableNames does deep equals between the two objects.
func EqualsTableOptions ¶
func EqualsTableOptions(a, b TableOptions) bool
EqualsTableOptions does deep equals between the two objects.
func EqualsUpdateExprs ¶
func EqualsUpdateExprs(a, b UpdateExprs) bool
EqualsUpdateExprs does deep equals between the two objects.
func EqualsValTuple ¶
EqualsValTuple does deep equals between the two objects.
func EqualsValues ¶
EqualsValues does deep equals between the two objects.
func EqualsVindexParam ¶
func EqualsVindexParam(a, b VindexParam) bool
EqualsVindexParam does deep equals between the two objects.
func ExtractMysqlComment ¶
ExtractMysqlComment extracts the version and SQL from a comment-only query such as /*!50708 sql here */
func IgnoreMaxMaxMemoryRowsDirective ¶
IgnoreMaxMaxMemoryRowsDirective returns true if the max memory rows override directive is set to true.
func IgnoreMaxPayloadSizeDirective ¶
IgnoreMaxPayloadSizeDirective returns true if the max payload size override directive is set to true.
func IsAggregation ¶
IsAggregation returns true if the node is an aggregation expression
func IsDMLStatement ¶
IsDMLStatement returns true if the query is an INSERT, UPDATE or DELETE statement.
func IsLockingFunc ¶
IsLockingFunc returns true for all functions that are used to work with mysql advisory locks
func IsMySQL80AndAbove ¶
func IsMySQL80AndAbove() bool
func IsSimpleTuple ¶
IsSimpleTuple returns true if the Expr is a ValTuple that contains simple values or if it's a list arg.
func IsValue ¶
IsValue returns true if the Expr is a string, integral or value arg. NULL is not considered to be a value.
func KeywordString ¶
KeywordString returns the string corresponding to the given keyword
func LikeToRegexp ¶
LikeToRegexp converts a like sql expression to regular expression
func MultiShardAutocommitDirective ¶
MultiShardAutocommitDirective returns true if multishard autocommit directive is set to true in query.
func MustRewriteAST ¶
MustRewriteAST takes Statement and returns true if RewriteAST must run on it for correct execution irrespective of user flags.
func Parse2 ¶
Parse2 parses the SQL in full and returns a Statement, which is the AST representation of the query, and a set of BindVars, which are all the bind variables that were found in the original SQL query. If a DDL statement is partially parsed but still contains a syntax error, the error is ignored and the DDL is returned anyway.
func ParseTable ¶
ParseTable parses the input as a qualified table name. It handles all valid literal escaping.
func ParseTokenizer ¶
ParseTokenizer is a raw interface to parse from the given tokenizer. This does not used pooled parsers, and should not be used in general.
func SkipQueryPlanCacheDirective ¶
SkipQueryPlanCacheDirective returns true if skip query plan cache directive is set to true in query.
func SplitStatement ¶
SplitStatement returns the first sql statement up to either a ; or EOF and the remainder from the given buffer
func SplitStatementToPieces ¶
SplitStatementToPieces split raw sql statement that may have multi sql pieces to sql pieces returns the sql pieces blob contains; or error if sql cannot be parsed
func StripLeadingComments ¶
StripLeadingComments trims the SQL string and removes any leading comments
func ToString ¶
ToString prints the list of table expressions as a string To be used as an alternate for String for []TableExpr
func TruncateForLog ¶
TruncateForLog is used when displaying queries as part of error logs to avoid overwhelming logging systems with potentially long queries and bind value data.
func TruncateForUI ¶
TruncateForUI is used when displaying queries on various Vitess status pages to keep the pages small enough to load and render properly
func VisitAccessMode ¶
func VisitAccessMode(in AccessMode, f Visit) error
func VisitAlgorithmValue ¶
func VisitAlgorithmValue(in AlgorithmValue, f Visit) error
func VisitAlterOption ¶
func VisitAlterOption(in AlterOption, f Visit) error
func VisitArgument ¶
func VisitBoolVal ¶
func VisitCallable ¶
func VisitCharacteristic ¶
func VisitCharacteristic(in Characteristic, f Visit) error
func VisitColIdent ¶
func VisitColTuple ¶
func VisitColumns ¶
func VisitConstraintInfo ¶
func VisitConstraintInfo(in ConstraintInfo, f Visit) error
func VisitDBDDLStatement ¶
func VisitDBDDLStatement(in DBDDLStatement, f Visit) error
func VisitDDLStatement ¶
func VisitDDLStatement(in DDLStatement, f Visit) error
func VisitExplain ¶
func VisitExprs ¶
func VisitGroupBy ¶
func VisitIndexHints ¶
func VisitIndexHints(in IndexHints, f Visit) error
func VisitInsertRows ¶
func VisitInsertRows(in InsertRows, f Visit) error
func VisitIsolationLevel ¶
func VisitIsolationLevel(in IsolationLevel, f Visit) error
func VisitJSONObjectParam ¶
func VisitJSONObjectParam(in JSONObjectParam, f Visit) error
func VisitJSONPathParam ¶
func VisitJSONPathParam(in JSONPathParam, f Visit) error
func VisitListArg ¶
func VisitMatchAction ¶
func VisitMatchAction(in MatchAction, f Visit) error
func VisitOffset ¶
func VisitOnDup ¶
func VisitOrderBy ¶
func VisitPartitions ¶
func VisitPartitions(in Partitions, f Visit) error
func VisitRefOfAddColumns ¶
func VisitRefOfAddColumns(in *AddColumns, f Visit) error
func VisitRefOfAddConstraintDefinition ¶
func VisitRefOfAddConstraintDefinition(in *AddConstraintDefinition, f Visit) error
func VisitRefOfAddIndexDefinition ¶
func VisitRefOfAddIndexDefinition(in *AddIndexDefinition, f Visit) error
func VisitRefOfAliasedExpr ¶
func VisitRefOfAliasedExpr(in *AliasedExpr, f Visit) error
func VisitRefOfAliasedTableExpr ¶
func VisitRefOfAliasedTableExpr(in *AliasedTableExpr, f Visit) error
func VisitRefOfAlterCharset ¶
func VisitRefOfAlterCharset(in *AlterCharset, f Visit) error
func VisitRefOfAlterCheck ¶
func VisitRefOfAlterCheck(in *AlterCheck, f Visit) error
func VisitRefOfAlterColumn ¶
func VisitRefOfAlterColumn(in *AlterColumn, f Visit) error
func VisitRefOfAlterDatabase ¶
func VisitRefOfAlterDatabase(in *AlterDatabase, f Visit) error
func VisitRefOfAlterIndex ¶
func VisitRefOfAlterIndex(in *AlterIndex, f Visit) error
func VisitRefOfAlterMigration ¶
func VisitRefOfAlterMigration(in *AlterMigration, f Visit) error
func VisitRefOfAlterTable ¶
func VisitRefOfAlterTable(in *AlterTable, f Visit) error
func VisitRefOfAlterView ¶
func VisitRefOfAlterVschema ¶
func VisitRefOfAlterVschema(in *AlterVschema, f Visit) error
func VisitRefOfAndExpr ¶
func VisitRefOfAutoIncSpec ¶
func VisitRefOfAutoIncSpec(in *AutoIncSpec, f Visit) error
func VisitRefOfBegin ¶
func VisitRefOfBetweenExpr ¶
func VisitRefOfBetweenExpr(in *BetweenExpr, f Visit) error
func VisitRefOfBinaryExpr ¶
func VisitRefOfBinaryExpr(in *BinaryExpr, f Visit) error
func VisitRefOfCallProc ¶
func VisitRefOfCaseExpr ¶
func VisitRefOfChangeColumn ¶
func VisitRefOfChangeColumn(in *ChangeColumn, f Visit) error
func VisitRefOfCheckConstraintDefinition ¶
func VisitRefOfCheckConstraintDefinition(in *CheckConstraintDefinition, f Visit) error
func VisitRefOfColIdent ¶
func VisitRefOfColName ¶
func VisitRefOfCollateExpr ¶
func VisitRefOfCollateExpr(in *CollateExpr, f Visit) error
func VisitRefOfColumnDefinition ¶
func VisitRefOfColumnDefinition(in *ColumnDefinition, f Visit) error
func VisitRefOfColumnType ¶
func VisitRefOfColumnType(in *ColumnType, f Visit) error
func VisitRefOfCommit ¶
func VisitRefOfCommonTableExpr ¶
func VisitRefOfCommonTableExpr(in *CommonTableExpr, f Visit) error
func VisitRefOfComparisonExpr ¶
func VisitRefOfComparisonExpr(in *ComparisonExpr, f Visit) error
func VisitRefOfConstraintDefinition ¶
func VisitRefOfConstraintDefinition(in *ConstraintDefinition, f Visit) error
func VisitRefOfConvertExpr ¶
func VisitRefOfConvertExpr(in *ConvertExpr, f Visit) error
func VisitRefOfConvertType ¶
func VisitRefOfConvertType(in *ConvertType, f Visit) error
func VisitRefOfConvertUsingExpr ¶
func VisitRefOfConvertUsingExpr(in *ConvertUsingExpr, f Visit) error
func VisitRefOfCreateDatabase ¶
func VisitRefOfCreateDatabase(in *CreateDatabase, f Visit) error
func VisitRefOfCreateTable ¶
func VisitRefOfCreateTable(in *CreateTable, f Visit) error
func VisitRefOfCreateView ¶
func VisitRefOfCreateView(in *CreateView, f Visit) error
func VisitRefOfCurTimeFuncExpr ¶
func VisitRefOfCurTimeFuncExpr(in *CurTimeFuncExpr, f Visit) error
func VisitRefOfDeallocateStmt ¶
func VisitRefOfDeallocateStmt(in *DeallocateStmt, f Visit) error
func VisitRefOfDefault ¶
func VisitRefOfDefiner ¶
func VisitRefOfDelete ¶
func VisitRefOfDerivedTable ¶
func VisitRefOfDerivedTable(in *DerivedTable, f Visit) error
func VisitRefOfDropColumn ¶
func VisitRefOfDropColumn(in *DropColumn, f Visit) error
func VisitRefOfDropDatabase ¶
func VisitRefOfDropDatabase(in *DropDatabase, f Visit) error
func VisitRefOfDropKey ¶
func VisitRefOfDropTable ¶
func VisitRefOfDropView ¶
func VisitRefOfExecuteStmt ¶
func VisitRefOfExecuteStmt(in *ExecuteStmt, f Visit) error
func VisitRefOfExistsExpr ¶
func VisitRefOfExistsExpr(in *ExistsExpr, f Visit) error
func VisitRefOfExplainStmt ¶
func VisitRefOfExplainStmt(in *ExplainStmt, f Visit) error
func VisitRefOfExplainTab ¶
func VisitRefOfExplainTab(in *ExplainTab, f Visit) error
func VisitRefOfExtractFuncExpr ¶
func VisitRefOfExtractFuncExpr(in *ExtractFuncExpr, f Visit) error
func VisitRefOfExtractedSubquery ¶
func VisitRefOfExtractedSubquery(in *ExtractedSubquery, f Visit) error
func VisitRefOfFlush ¶
func VisitRefOfForce ¶
func VisitRefOfForeignKeyDefinition ¶
func VisitRefOfForeignKeyDefinition(in *ForeignKeyDefinition, f Visit) error
func VisitRefOfFuncExpr ¶
func VisitRefOfGroupConcatExpr ¶
func VisitRefOfGroupConcatExpr(in *GroupConcatExpr, f Visit) error
func VisitRefOfIndexDefinition ¶
func VisitRefOfIndexDefinition(in *IndexDefinition, f Visit) error
func VisitRefOfIndexHint ¶
func VisitRefOfIndexInfo ¶
func VisitRefOfInsert ¶
func VisitRefOfIntervalExpr ¶
func VisitRefOfIntervalExpr(in *IntervalExpr, f Visit) error
func VisitRefOfIntroducerExpr ¶
func VisitRefOfIntroducerExpr(in *IntroducerExpr, f Visit) error
func VisitRefOfIsExpr ¶
func VisitRefOfJSONArrayExpr ¶
func VisitRefOfJSONArrayExpr(in *JSONArrayExpr, f Visit) error
func VisitRefOfJSONAttributesExpr ¶
func VisitRefOfJSONAttributesExpr(in *JSONAttributesExpr, f Visit) error
func VisitRefOfJSONContainsExpr ¶
func VisitRefOfJSONContainsExpr(in *JSONContainsExpr, f Visit) error
func VisitRefOfJSONContainsPathExpr ¶
func VisitRefOfJSONContainsPathExpr(in *JSONContainsPathExpr, f Visit) error
func VisitRefOfJSONExtractExpr ¶
func VisitRefOfJSONExtractExpr(in *JSONExtractExpr, f Visit) error
func VisitRefOfJSONKeysExpr ¶
func VisitRefOfJSONKeysExpr(in *JSONKeysExpr, f Visit) error
func VisitRefOfJSONObjectExpr ¶
func VisitRefOfJSONObjectExpr(in *JSONObjectExpr, f Visit) error
func VisitRefOfJSONObjectParam ¶
func VisitRefOfJSONObjectParam(in *JSONObjectParam, f Visit) error
func VisitRefOfJSONOverlapsExpr ¶
func VisitRefOfJSONOverlapsExpr(in *JSONOverlapsExpr, f Visit) error
func VisitRefOfJSONPrettyExpr ¶
func VisitRefOfJSONPrettyExpr(in *JSONPrettyExpr, f Visit) error
func VisitRefOfJSONQuoteExpr ¶
func VisitRefOfJSONQuoteExpr(in *JSONQuoteExpr, f Visit) error
func VisitRefOfJSONRemoveExpr ¶
func VisitRefOfJSONRemoveExpr(in *JSONRemoveExpr, f Visit) error
func VisitRefOfJSONSchemaValidFuncExpr ¶
func VisitRefOfJSONSchemaValidFuncExpr(in *JSONSchemaValidFuncExpr, f Visit) error
func VisitRefOfJSONSchemaValidationReportFuncExpr ¶
func VisitRefOfJSONSchemaValidationReportFuncExpr(in *JSONSchemaValidationReportFuncExpr, f Visit) error
func VisitRefOfJSONSearchExpr ¶
func VisitRefOfJSONSearchExpr(in *JSONSearchExpr, f Visit) error
func VisitRefOfJSONStorageFreeExpr ¶
func VisitRefOfJSONStorageFreeExpr(in *JSONStorageFreeExpr, f Visit) error
func VisitRefOfJSONStorageSizeExpr ¶
func VisitRefOfJSONStorageSizeExpr(in *JSONStorageSizeExpr, f Visit) error
func VisitRefOfJSONTableExpr ¶
func VisitRefOfJSONTableExpr(in *JSONTableExpr, f Visit) error
func VisitRefOfJSONUnquoteExpr ¶
func VisitRefOfJSONUnquoteExpr(in *JSONUnquoteExpr, f Visit) error
func VisitRefOfJSONValueExpr ¶
func VisitRefOfJSONValueExpr(in *JSONValueExpr, f Visit) error
func VisitRefOfJSONValueMergeExpr ¶
func VisitRefOfJSONValueMergeExpr(in *JSONValueMergeExpr, f Visit) error
func VisitRefOfJSONValueModifierExpr ¶
func VisitRefOfJSONValueModifierExpr(in *JSONValueModifierExpr, f Visit) error
func VisitRefOfJoinCondition ¶
func VisitRefOfJoinCondition(in *JoinCondition, f Visit) error
func VisitRefOfJoinTableExpr ¶
func VisitRefOfJoinTableExpr(in *JoinTableExpr, f Visit) error
func VisitRefOfJtColumnDefinition ¶
func VisitRefOfJtColumnDefinition(in *JtColumnDefinition, f Visit) error
func VisitRefOfJtOnResponse ¶
func VisitRefOfJtOnResponse(in *JtOnResponse, f Visit) error
func VisitRefOfKeyState ¶
func VisitRefOfLimit ¶
func VisitRefOfLiteral ¶
func VisitRefOfLoad ¶
func VisitRefOfLockOption ¶
func VisitRefOfLockOption(in *LockOption, f Visit) error
func VisitRefOfLockTables ¶
func VisitRefOfLockTables(in *LockTables, f Visit) error
func VisitRefOfMatchExpr ¶
func VisitRefOfMemberOfExpr ¶
func VisitRefOfMemberOfExpr(in *MemberOfExpr, f Visit) error
func VisitRefOfModifyColumn ¶
func VisitRefOfModifyColumn(in *ModifyColumn, f Visit) error
func VisitRefOfNextval ¶
func VisitRefOfNotExpr ¶
func VisitRefOfNullVal ¶
func VisitRefOfOptLike ¶
func VisitRefOfOrExpr ¶
func VisitRefOfOrder ¶
func VisitRefOfOrderByOption ¶
func VisitRefOfOrderByOption(in *OrderByOption, f Visit) error
func VisitRefOfOtherAdmin ¶
func VisitRefOfOtherAdmin(in *OtherAdmin, f Visit) error
func VisitRefOfOtherRead ¶
func VisitRefOfParenTableExpr ¶
func VisitRefOfParenTableExpr(in *ParenTableExpr, f Visit) error
func VisitRefOfParsedComments ¶
func VisitRefOfParsedComments(in *ParsedComments, f Visit) error
func VisitRefOfPartitionDefinition ¶
func VisitRefOfPartitionDefinition(in *PartitionDefinition, f Visit) error
func VisitRefOfPartitionDefinitionOptions ¶
func VisitRefOfPartitionDefinitionOptions(in *PartitionDefinitionOptions, f Visit) error
func VisitRefOfPartitionEngine ¶
func VisitRefOfPartitionEngine(in *PartitionEngine, f Visit) error
func VisitRefOfPartitionOption ¶
func VisitRefOfPartitionOption(in *PartitionOption, f Visit) error
func VisitRefOfPartitionSpec ¶
func VisitRefOfPartitionSpec(in *PartitionSpec, f Visit) error
func VisitRefOfPartitionValueRange ¶
func VisitRefOfPartitionValueRange(in *PartitionValueRange, f Visit) error
func VisitRefOfPrepareStmt ¶
func VisitRefOfPrepareStmt(in *PrepareStmt, f Visit) error
func VisitRefOfReferenceDefinition ¶
func VisitRefOfReferenceDefinition(in *ReferenceDefinition, f Visit) error
func VisitRefOfRelease ¶
func VisitRefOfRenameIndex ¶
func VisitRefOfRenameIndex(in *RenameIndex, f Visit) error
func VisitRefOfRenameTable ¶
func VisitRefOfRenameTable(in *RenameTable, f Visit) error
func VisitRefOfRenameTableName ¶
func VisitRefOfRenameTableName(in *RenameTableName, f Visit) error
func VisitRefOfRevertMigration ¶
func VisitRefOfRevertMigration(in *RevertMigration, f Visit) error
func VisitRefOfRollback ¶
func VisitRefOfRootNode ¶
func VisitRefOfSRollback ¶
func VisitRefOfSavepoint ¶
func VisitRefOfSelect ¶
func VisitRefOfSelectInto ¶
func VisitRefOfSelectInto(in *SelectInto, f Visit) error
func VisitRefOfSet ¶
func VisitRefOfSetExpr ¶
func VisitRefOfSetTransaction ¶
func VisitRefOfSetTransaction(in *SetTransaction, f Visit) error
func VisitRefOfShow ¶
func VisitRefOfShowBasic ¶
func VisitRefOfShowCreate ¶
func VisitRefOfShowCreate(in *ShowCreate, f Visit) error
func VisitRefOfShowFilter ¶
func VisitRefOfShowFilter(in *ShowFilter, f Visit) error
func VisitRefOfShowMigrationLogs ¶
func VisitRefOfShowMigrationLogs(in *ShowMigrationLogs, f Visit) error
func VisitRefOfShowOther ¶
func VisitRefOfShowThrottledApps ¶
func VisitRefOfShowThrottledApps(in *ShowThrottledApps, f Visit) error
func VisitRefOfStarExpr ¶
func VisitRefOfStream ¶
func VisitRefOfSubPartition ¶
func VisitRefOfSubPartition(in *SubPartition, f Visit) error
func VisitRefOfSubPartitionDefinition ¶
func VisitRefOfSubPartitionDefinition(in *SubPartitionDefinition, f Visit) error
func VisitRefOfSubPartitionDefinitionOptions ¶
func VisitRefOfSubPartitionDefinitionOptions(in *SubPartitionDefinitionOptions, f Visit) error
func VisitRefOfSubquery ¶
func VisitRefOfSubstrExpr ¶
func VisitRefOfSubstrExpr(in *SubstrExpr, f Visit) error
func VisitRefOfTableIdent ¶
func VisitRefOfTableIdent(in *TableIdent, f Visit) error
func VisitRefOfTableName ¶
func VisitRefOfTableSpec ¶
func VisitRefOfTablespaceOperation ¶
func VisitRefOfTablespaceOperation(in *TablespaceOperation, f Visit) error
func VisitRefOfTimestampFuncExpr ¶
func VisitRefOfTimestampFuncExpr(in *TimestampFuncExpr, f Visit) error
func VisitRefOfTrimFuncExpr ¶
func VisitRefOfTrimFuncExpr(in *TrimFuncExpr, f Visit) error
func VisitRefOfTruncateTable ¶
func VisitRefOfTruncateTable(in *TruncateTable, f Visit) error
func VisitRefOfUnaryExpr ¶
func VisitRefOfUnion ¶
func VisitRefOfUnlockTables ¶
func VisitRefOfUnlockTables(in *UnlockTables, f Visit) error
func VisitRefOfUpdate ¶
func VisitRefOfUpdateExpr ¶
func VisitRefOfUpdateExpr(in *UpdateExpr, f Visit) error
func VisitRefOfUse ¶
func VisitRefOfVStream ¶
func VisitRefOfValidation ¶
func VisitRefOfValidation(in *Validation, f Visit) error
func VisitRefOfValuesFuncExpr ¶
func VisitRefOfValuesFuncExpr(in *ValuesFuncExpr, f Visit) error
func VisitRefOfVindexParam ¶
func VisitRefOfVindexParam(in *VindexParam, f Visit) error
func VisitRefOfVindexSpec ¶
func VisitRefOfVindexSpec(in *VindexSpec, f Visit) error
func VisitRefOfWeightStringFuncExpr ¶
func VisitRefOfWeightStringFuncExpr(in *WeightStringFuncExpr, f Visit) error
func VisitRefOfWhen ¶
func VisitRefOfWhere ¶
func VisitRefOfWith ¶
func VisitRefOfXorExpr ¶
func VisitReferenceAction ¶
func VisitReferenceAction(in ReferenceAction, f Visit) error
func VisitRootNode ¶
func VisitSQLNode ¶
func VisitSelectExpr ¶
func VisitSelectExpr(in SelectExpr, f Visit) error
func VisitSelectExprs ¶
func VisitSelectExprs(in SelectExprs, f Visit) error
func VisitSelectStatement ¶
func VisitSelectStatement(in SelectStatement, f Visit) error
func VisitSetExprs ¶
func VisitShowInternal ¶
func VisitShowInternal(in ShowInternal, f Visit) error
func VisitSimpleTableExpr ¶
func VisitSimpleTableExpr(in SimpleTableExpr, f Visit) error
func VisitStatement ¶
func VisitSubPartitionDefinitions ¶
func VisitSubPartitionDefinitions(in SubPartitionDefinitions, f Visit) error
func VisitTableExpr ¶
func VisitTableExprs ¶
func VisitTableExprs(in TableExprs, f Visit) error
func VisitTableIdent ¶
func VisitTableIdent(in TableIdent, f Visit) error
func VisitTableName ¶
func VisitTableNames ¶
func VisitTableNames(in TableNames, f Visit) error
func VisitTableOptions ¶
func VisitTableOptions(in TableOptions, f Visit) error
func VisitUpdateExprs ¶
func VisitUpdateExprs(in UpdateExprs, f Visit) error
func VisitValTuple ¶
func VisitValues ¶
func VisitVindexParam ¶
func VisitVindexParam(in VindexParam, f Visit) error
Types ¶
type AccessMode ¶
type AccessMode int8
AccessMode is enum for the mode - ReadOnly or ReadWrite
const ( ReadOnly AccessMode = iota ReadWrite )
Constants for Enum type - AccessMode
func (AccessMode) Format ¶
func (node AccessMode) Format(buf *TrackedBuffer)
Format formats the node.
type AddColumns ¶
type AddColumns struct { Columns []*ColumnDefinition First bool After *ColName }
AddColumns represents a ADD COLUMN alter option
func CloneRefOfAddColumns ¶
func CloneRefOfAddColumns(n *AddColumns) *AddColumns
CloneRefOfAddColumns creates a deep clone of the input.
func (*AddColumns) CachedSize ¶
func (cached *AddColumns) CachedSize(alloc bool) int64
func (*AddColumns) Format ¶
func (node *AddColumns) Format(buf *TrackedBuffer)
Format formats the node.
type AddConstraintDefinition ¶
type AddConstraintDefinition struct {
ConstraintDefinition *ConstraintDefinition
}
AddConstraintDefinition represents a ADD CONSTRAINT alter option
func CloneRefOfAddConstraintDefinition ¶
func CloneRefOfAddConstraintDefinition(n *AddConstraintDefinition) *AddConstraintDefinition
CloneRefOfAddConstraintDefinition creates a deep clone of the input.
func (*AddConstraintDefinition) CachedSize ¶
func (cached *AddConstraintDefinition) CachedSize(alloc bool) int64
func (*AddConstraintDefinition) Format ¶
func (node *AddConstraintDefinition) Format(buf *TrackedBuffer)
Format formats the node.
type AddIndexDefinition ¶
type AddIndexDefinition struct {
IndexDefinition *IndexDefinition
}
AddIndexDefinition represents a ADD INDEX alter option
func CloneRefOfAddIndexDefinition ¶
func CloneRefOfAddIndexDefinition(n *AddIndexDefinition) *AddIndexDefinition
CloneRefOfAddIndexDefinition creates a deep clone of the input.
func (*AddIndexDefinition) CachedSize ¶
func (cached *AddIndexDefinition) CachedSize(alloc bool) int64
func (*AddIndexDefinition) Format ¶
func (node *AddIndexDefinition) Format(buf *TrackedBuffer)
Format formats the node.
type AlgorithmValue ¶
type AlgorithmValue string
AlgorithmValue is the algorithm specified in the alter table command
func (AlgorithmValue) Format ¶
func (node AlgorithmValue) Format(buf *TrackedBuffer)
Format formats the node.
type AliasedExpr ¶
AliasedExpr defines an aliased SELECT expression.
func CloneRefOfAliasedExpr ¶
func CloneRefOfAliasedExpr(n *AliasedExpr) *AliasedExpr
CloneRefOfAliasedExpr creates a deep clone of the input.
func (*AliasedExpr) CachedSize ¶
func (cached *AliasedExpr) CachedSize(alloc bool) int64
func (*AliasedExpr) ColumnName ¶
func (ae *AliasedExpr) ColumnName() string
ColumnName returns the alias if one was provided, otherwise prints the AST
func (*AliasedExpr) Format ¶
func (node *AliasedExpr) Format(buf *TrackedBuffer)
Format formats the node.
type AliasedTableExpr ¶
type AliasedTableExpr struct { Expr SimpleTableExpr Partitions Partitions As TableIdent Hints IndexHints Columns Columns }
AliasedTableExpr represents a table expression coupled with an optional alias or index hint. If As is empty, no alias was used.
func CloneRefOfAliasedTableExpr ¶
func CloneRefOfAliasedTableExpr(n *AliasedTableExpr) *AliasedTableExpr
CloneRefOfAliasedTableExpr creates a deep clone of the input.
func (*AliasedTableExpr) CachedSize ¶
func (cached *AliasedTableExpr) CachedSize(alloc bool) int64
func (*AliasedTableExpr) Format ¶
func (node *AliasedTableExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*AliasedTableExpr) RemoveHints ¶
func (node *AliasedTableExpr) RemoveHints() *AliasedTableExpr
RemoveHints returns a new AliasedTableExpr with the hints removed.
func (*AliasedTableExpr) TableName ¶
func (node *AliasedTableExpr) TableName() (TableName, error)
TableName returns a TableName pointing to this table expr
type AlterCharset ¶
AlterCharset is used to set the default or change the character set and collation in alter table command
func CloneRefOfAlterCharset ¶
func CloneRefOfAlterCharset(n *AlterCharset) *AlterCharset
CloneRefOfAlterCharset creates a deep clone of the input.
func (*AlterCharset) CachedSize ¶
func (cached *AlterCharset) CachedSize(alloc bool) int64
func (*AlterCharset) Format ¶
func (node *AlterCharset) Format(buf *TrackedBuffer)
Format formats the node
type AlterCheck ¶
AlterCheck represents the `ALTER CHECK` part in an `ALTER TABLE ALTER CHECK` command.
func CloneRefOfAlterCheck ¶
func CloneRefOfAlterCheck(n *AlterCheck) *AlterCheck
CloneRefOfAlterCheck creates a deep clone of the input.
func (*AlterCheck) CachedSize ¶
func (cached *AlterCheck) CachedSize(alloc bool) int64
func (*AlterCheck) Format ¶
func (node *AlterCheck) Format(buf *TrackedBuffer)
type AlterColumn ¶
AlterColumn is used to add or drop defaults & visibility to columns in alter table command
func CloneRefOfAlterColumn ¶
func CloneRefOfAlterColumn(n *AlterColumn) *AlterColumn
CloneRefOfAlterColumn creates a deep clone of the input.
func (*AlterColumn) CachedSize ¶
func (cached *AlterColumn) CachedSize(alloc bool) int64
func (*AlterColumn) Format ¶
func (node *AlterColumn) Format(buf *TrackedBuffer)
Format formats the node
type AlterDatabase ¶
type AlterDatabase struct { DBName TableIdent UpdateDataDirectory bool AlterOptions []DatabaseOption FullyParsed bool }
AlterDatabase represents a ALTER database statement.
func CloneRefOfAlterDatabase ¶
func CloneRefOfAlterDatabase(n *AlterDatabase) *AlterDatabase
CloneRefOfAlterDatabase creates a deep clone of the input.
func (*AlterDatabase) CachedSize ¶
func (cached *AlterDatabase) CachedSize(alloc bool) int64
func (*AlterDatabase) Format ¶
func (node *AlterDatabase) Format(buf *TrackedBuffer)
Format formats the node.
func (*AlterDatabase) GetDatabaseName ¶
func (node *AlterDatabase) GetDatabaseName() string
GetDatabaseName implements the DBDDLStatement interface
func (*AlterDatabase) IsFullyParsed ¶
func (node *AlterDatabase) IsFullyParsed() bool
IsFullyParsed implements the DBDDLStatement interface
func (*AlterDatabase) SetFullyParsed ¶
func (node *AlterDatabase) SetFullyParsed(fullyParsed bool)
SetFullyParsed implements the DBDDLStatement interface
type AlterIndex ¶
AlterIndex represents the `ALTER INDEX` part in an `ALTER TABLE ALTER INDEX` command.
func CloneRefOfAlterIndex ¶
func CloneRefOfAlterIndex(n *AlterIndex) *AlterIndex
CloneRefOfAlterIndex creates a deep clone of the input.
func (*AlterIndex) CachedSize ¶
func (cached *AlterIndex) CachedSize(alloc bool) int64
func (*AlterIndex) Format ¶
func (node *AlterIndex) Format(buf *TrackedBuffer)
Format formats the node
type AlterMigration ¶
type AlterMigration struct { Type AlterMigrationType UUID string Expire string Ratio *Literal }
AlterMigration represents a ALTER VITESS_MIGRATION statement
func CloneRefOfAlterMigration ¶
func CloneRefOfAlterMigration(n *AlterMigration) *AlterMigration
CloneRefOfAlterMigration creates a deep clone of the input.
func (*AlterMigration) CachedSize ¶
func (cached *AlterMigration) CachedSize(alloc bool) int64
func (*AlterMigration) Format ¶
func (node *AlterMigration) Format(buf *TrackedBuffer)
Format formats the node.
type AlterMigrationType ¶
type AlterMigrationType int8
AlterMigrationType represents the type of operation in an ALTER VITESS_MIGRATION statement
const ( RetryMigrationType AlterMigrationType = iota CompleteMigrationType CancelMigrationType CancelAllMigrationType CleanupMigrationType ThrottleMigrationType ThrottleAllMigrationType UnthrottleMigrationType UnthrottleAllMigrationType )
AlterMigrationType constants
type AlterOption ¶
type AlterOption interface { SQLNode // contains filtered or unexported methods }
AlterOption is an interface that represents the various options in ALTER TABLE statements
func CloneAlterOption ¶
func CloneAlterOption(in AlterOption) AlterOption
CloneAlterOption creates a deep clone of the input.
func CloneSliceOfAlterOption ¶
func CloneSliceOfAlterOption(n []AlterOption) []AlterOption
CloneSliceOfAlterOption creates a deep clone of the input.
type AlterTable ¶
type AlterTable struct { Table TableName AlterOptions []AlterOption PartitionSpec *PartitionSpec PartitionOption *PartitionOption Comments *ParsedComments FullyParsed bool }
AlterTable represents a ALTER TABLE statement.
func CloneRefOfAlterTable ¶
func CloneRefOfAlterTable(n *AlterTable) *AlterTable
CloneRefOfAlterTable creates a deep clone of the input.
func (*AlterTable) AffectedTables ¶
func (node *AlterTable) AffectedTables() TableNames
AffectedTables returns the list table names affected by the DDLStatement.
func (*AlterTable) CachedSize ¶
func (cached *AlterTable) CachedSize(alloc bool) int64
func (*AlterTable) Format ¶
func (node *AlterTable) Format(buf *TrackedBuffer)
Format formats the AlterTable node.
func (*AlterTable) GetAction ¶
func (node *AlterTable) GetAction() DDLAction
GetAction implements the DDLStatement interface
func (*AlterTable) GetFromTables ¶
func (node *AlterTable) GetFromTables() TableNames
GetFromTables implements the DDLStatement interface
func (*AlterTable) GetIfExists ¶
func (node *AlterTable) GetIfExists() bool
GetIfExists implements the DDLStatement interface
func (*AlterTable) GetIfNotExists ¶
func (node *AlterTable) GetIfNotExists() bool
GetIfNotExists implements the DDLStatement interface
func (*AlterTable) GetIsReplace ¶
func (node *AlterTable) GetIsReplace() bool
GetIsReplace implements the DDLStatement interface
func (*AlterTable) GetOptLike ¶
func (node *AlterTable) GetOptLike() *OptLike
GetOptLike implements the DDLStatement interface
func (*AlterTable) GetParsedComments ¶
func (node *AlterTable) GetParsedComments() *ParsedComments
GetParsedComments implements DDLStatement.
func (*AlterTable) GetTable ¶
func (node *AlterTable) GetTable() TableName
GetTable implements the DDLStatement interface
func (*AlterTable) GetTableSpec ¶
func (node *AlterTable) GetTableSpec() *TableSpec
GetTableSpec implements the DDLStatement interface
func (*AlterTable) GetToTables ¶
func (node *AlterTable) GetToTables() TableNames
GetToTables implements the DDLStatement interface
func (*AlterTable) IsFullyParsed ¶
func (node *AlterTable) IsFullyParsed() bool
IsFullyParsed implements the DDLStatement interface
func (*AlterTable) IsTemporary ¶
func (node *AlterTable) IsTemporary() bool
IsTemporary implements the DDLStatement interface
func (*AlterTable) SetComments ¶
func (node *AlterTable) SetComments(comments Comments)
SetComments implements DDLStatement.
func (*AlterTable) SetFromTables ¶
func (node *AlterTable) SetFromTables(tables TableNames)
SetFromTables implements DDLStatement.
func (*AlterTable) SetFullyParsed ¶
func (node *AlterTable) SetFullyParsed(fullyParsed bool)
SetFullyParsed implements the DDLStatement interface
func (*AlterTable) SetTable ¶
func (node *AlterTable) SetTable(qualifier string, name string)
SetTable implements DDLStatement.
type AlterView ¶
type AlterView struct { ViewName TableName Algorithm string Definer *Definer Security string Columns Columns Select SelectStatement CheckOption string Comments *ParsedComments }
AlterView represents a ALTER VIEW query
func CloneRefOfAlterView ¶
CloneRefOfAlterView creates a deep clone of the input.
func (*AlterView) AffectedTables ¶
func (node *AlterView) AffectedTables() TableNames
AffectedTables implements DDLStatement.
func (*AlterView) CachedSize ¶
func (*AlterView) Format ¶
func (node *AlterView) Format(buf *TrackedBuffer)
Format formats the node.
func (*AlterView) GetFromTables ¶
func (node *AlterView) GetFromTables() TableNames
GetFromTables implements the DDLStatement interface
func (*AlterView) GetIfExists ¶
GetIfExists implements the DDLStatement interface
func (*AlterView) GetIfNotExists ¶
GetIfNotExists implements the DDLStatement interface
func (*AlterView) GetIsReplace ¶
GetIsReplace implements the DDLStatement interface
func (*AlterView) GetOptLike ¶
GetOptLike implements the DDLStatement interface
func (*AlterView) GetParsedComments ¶
func (node *AlterView) GetParsedComments() *ParsedComments
GetParsedComments implements DDLStatement.
func (*AlterView) GetTableSpec ¶
GetTableSpec implements the DDLStatement interface
func (*AlterView) GetToTables ¶
func (node *AlterView) GetToTables() TableNames
GetToTables implements the DDLStatement interface
func (*AlterView) IsFullyParsed ¶
IsFullyParsed implements the DDLStatement interface
func (*AlterView) IsTemporary ¶
IsTemporary implements the DDLStatement interface
func (*AlterView) SetComments ¶
SetComments implements DDLStatement.
func (*AlterView) SetFromTables ¶
func (node *AlterView) SetFromTables(tables TableNames)
SetFromTables implements DDLStatement.
func (*AlterView) SetFullyParsed ¶
SetFullyParsed implements the DDLStatement interface
type AlterVschema ¶
type AlterVschema struct { Action DDLAction Table TableName // VindexSpec is set for CreateVindexDDLAction, DropVindexDDLAction, AddColVindexDDLAction, DropColVindexDDLAction. VindexSpec *VindexSpec // VindexCols is set for AddColVindexDDLAction. VindexCols []ColIdent // AutoIncSpec is set for AddAutoIncDDLAction. AutoIncSpec *AutoIncSpec }
AlterVschema represents a ALTER VSCHEMA statement.
func CloneRefOfAlterVschema ¶
func CloneRefOfAlterVschema(n *AlterVschema) *AlterVschema
CloneRefOfAlterVschema creates a deep clone of the input.
func (*AlterVschema) CachedSize ¶
func (cached *AlterVschema) CachedSize(alloc bool) int64
func (*AlterVschema) Format ¶
func (node *AlterVschema) Format(buf *TrackedBuffer)
Format formats the node.
type AndExpr ¶
type AndExpr struct {
Left, Right Expr
}
AndExpr represents an AND expression.
func CloneRefOfAndExpr ¶
CloneRefOfAndExpr creates a deep clone of the input.
func (*AndExpr) CachedSize ¶
type ApplyFunc ¶
An ApplyFunc is invoked by Rewrite for each node n, even if n is nil, before and/or after the node's children, using a Cursor describing the current node and providing operations on it.
The return value of ApplyFunc controls the syntax tree traversal. See Rewrite for details.
type AutoIncSpec ¶
AutoIncSpec defines and autoincrement value for a ADD AUTO_INCREMENT statement
func CloneRefOfAutoIncSpec ¶
func CloneRefOfAutoIncSpec(n *AutoIncSpec) *AutoIncSpec
CloneRefOfAutoIncSpec creates a deep clone of the input.
func (*AutoIncSpec) CachedSize ¶
func (cached *AutoIncSpec) CachedSize(alloc bool) int64
func (*AutoIncSpec) Format ¶
func (node *AutoIncSpec) Format(buf *TrackedBuffer)
Format formats the node.
type Begin ¶
type Begin struct{}
Begin represents a Begin statement.
func CloneRefOfBegin ¶
CloneRefOfBegin creates a deep clone of the input.
type BetweenExpr ¶
BetweenExpr represents a BETWEEN or a NOT BETWEEN expression.
func CloneRefOfBetweenExpr ¶
func CloneRefOfBetweenExpr(n *BetweenExpr) *BetweenExpr
CloneRefOfBetweenExpr creates a deep clone of the input.
func (*BetweenExpr) CachedSize ¶
func (cached *BetweenExpr) CachedSize(alloc bool) int64
func (*BetweenExpr) Format ¶
func (node *BetweenExpr) Format(buf *TrackedBuffer)
Format formats the node.
type BinaryExpr ¶
type BinaryExpr struct { Operator BinaryExprOperator Left, Right Expr }
BinaryExpr represents a binary value expression.
func CloneRefOfBinaryExpr ¶
func CloneRefOfBinaryExpr(n *BinaryExpr) *BinaryExpr
CloneRefOfBinaryExpr creates a deep clone of the input.
func (*BinaryExpr) CachedSize ¶
func (cached *BinaryExpr) CachedSize(alloc bool) int64
func (*BinaryExpr) Format ¶
func (node *BinaryExpr) Format(buf *TrackedBuffer)
Format formats the node.
type BinaryExprOperator ¶
type BinaryExprOperator int8
BinaryExprOperator is an enum for BinaryExpr.Operator
const ( BitAndOp BinaryExprOperator = iota BitOrOp BitXorOp PlusOp MinusOp MultOp DivOp IntDivOp ModOp ShiftLeftOp ShiftRightOp JSONExtractOp JSONUnquoteExtractOp )
Constant for Enum Type - BinaryExprOperator
func (BinaryExprOperator) ToString ¶
func (op BinaryExprOperator) ToString() string
ToString returns the operator as a string
type BindVars ¶
type BindVars map[string]struct{}
BindVars is a set of reserved bind variables from a SQL statement
type CallProc ¶
CallProc represents a CALL statement
func CloneRefOfCallProc ¶
CloneRefOfCallProc creates a deep clone of the input.
func (*CallProc) CachedSize ¶
type Callable ¶
type Callable interface { Expr // contains filtered or unexported methods }
*********** Expressions
func CloneCallable ¶
CloneCallable creates a deep clone of the input.
type CaseExpr ¶
CaseExpr represents a CASE expression.
func CloneRefOfCaseExpr ¶
CloneRefOfCaseExpr creates a deep clone of the input.
func (*CaseExpr) CachedSize ¶
type ChangeColumn ¶
type ChangeColumn struct { OldColumn *ColName NewColDefinition *ColumnDefinition First bool After *ColName }
ChangeColumn is used to change the column definition, can also rename the column in alter table command
func CloneRefOfChangeColumn ¶
func CloneRefOfChangeColumn(n *ChangeColumn) *ChangeColumn
CloneRefOfChangeColumn creates a deep clone of the input.
func (*ChangeColumn) CachedSize ¶
func (cached *ChangeColumn) CachedSize(alloc bool) int64
func (*ChangeColumn) Format ¶
func (node *ChangeColumn) Format(buf *TrackedBuffer)
Format formats the node
type Characteristic ¶
type Characteristic interface { SQLNode // contains filtered or unexported methods }
Characteristic is a transaction related change
func CloneCharacteristic ¶
func CloneCharacteristic(in Characteristic) Characteristic
CloneCharacteristic creates a deep clone of the input.
func CloneSliceOfCharacteristic ¶
func CloneSliceOfCharacteristic(n []Characteristic) []Characteristic
CloneSliceOfCharacteristic creates a deep clone of the input.
type CheckConstraintDefinition ¶
CheckConstraintDefinition describes a check constraint in a CREATE TABLE statement
func CloneRefOfCheckConstraintDefinition ¶
func CloneRefOfCheckConstraintDefinition(n *CheckConstraintDefinition) *CheckConstraintDefinition
CloneRefOfCheckConstraintDefinition creates a deep clone of the input.
func (*CheckConstraintDefinition) CachedSize ¶
func (cached *CheckConstraintDefinition) CachedSize(alloc bool) int64
func (*CheckConstraintDefinition) Format ¶
func (c *CheckConstraintDefinition) Format(buf *TrackedBuffer)
Format formats the node.
type ColIdent ¶
type ColIdent struct {
// contains filtered or unexported fields
}
ColIdent is a case insensitive SQL identifier. It will be escaped with backquotes if necessary.
func CloneColIdent ¶
CloneColIdent creates a deep clone of the input.
func CloneRefOfColIdent ¶
CloneRefOfColIdent creates a deep clone of the input.
func CloneSliceOfColIdent ¶
CloneSliceOfColIdent creates a deep clone of the input.
func NewColIdentWithAt ¶
NewColIdentWithAt makes a new ColIdent.
func (*ColIdent) CachedSize ¶
func (ColIdent) CompliantName ¶
CompliantName returns a compliant id name that can be used for a bind var.
func (ColIdent) EqualString ¶
EqualString performs a case-insensitive compare with str.
func (ColIdent) Lowered ¶
Lowered returns a lower-cased column name. This function should generally be used only for optimizing comparisons.
func (ColIdent) MarshalJSON ¶
MarshalJSON marshals into JSON.
func (ColIdent) String ¶
String returns the unescaped column name. It must not be used for SQL generation. Use sqlparser.String instead. The Stringer conformance is for usage in templates.
func (*ColIdent) UnmarshalJSON ¶
UnmarshalJSON unmarshals from JSON.
type ColName ¶
type ColName struct { // Metadata is not populated by the parser. // It's a placeholder for analyzers to store // additional data, typically info about which // table or column this node references. Metadata any Name ColIdent Qualifier TableName }
ColName represents a column name.
func CloneRefOfColName ¶
CloneRefOfColName creates a deep clone of the input.
func NewColNameWithQualifier ¶
NewColNameWithQualifier makes a new ColName pointing to a specific table
func (*ColName) CachedSize ¶
func (*ColName) CompliantName ¶
CompliantName is used to get the name of the bind variable to use for this column name
type ColTuple ¶
type ColTuple interface { Expr // contains filtered or unexported methods }
ColTuple represents a list of column values. It can be ValTuple, Subquery, ListArg.
func CloneColTuple ¶
CloneColTuple creates a deep clone of the input.
type CollateExpr ¶
CollateExpr represents dynamic collate operator.
func CloneRefOfCollateExpr ¶
func CloneRefOfCollateExpr(n *CollateExpr) *CollateExpr
CloneRefOfCollateExpr creates a deep clone of the input.
func (*CollateExpr) CachedSize ¶
func (cached *CollateExpr) CachedSize(alloc bool) int64
func (*CollateExpr) Format ¶
func (node *CollateExpr) Format(buf *TrackedBuffer)
Format formats the node.
type ColumnCharset ¶
ColumnCharset exists because in the type definition it's possible to add the binary marker for a character set, so we need to track when this happens. We can't at the point of where we parse things backfill this with an existing collation. Firstly because we don't have access to that during parsing, but more importantly because it would generate syntax that is invalid.
Not in all cases where a binary marker is allowed, a collation is allowed. See https://dev.mysql.com/doc/refman/8.0/en/cast-functions.html specifically under Character Set Conversions.
func CloneColumnCharset ¶
func CloneColumnCharset(n ColumnCharset) ColumnCharset
CloneColumnCharset creates a deep clone of the input.
func CloneRefOfColumnCharset ¶
func CloneRefOfColumnCharset(n *ColumnCharset) *ColumnCharset
CloneRefOfColumnCharset creates a deep clone of the input.
func (*ColumnCharset) CachedSize ¶
func (cached *ColumnCharset) CachedSize(alloc bool) int64
type ColumnDefinition ¶
type ColumnDefinition struct { Name ColIdent // TODO: Should this not be a reference? Type ColumnType }
ColumnDefinition describes a column in a CREATE TABLE statement
func CloneRefOfColumnDefinition ¶
func CloneRefOfColumnDefinition(n *ColumnDefinition) *ColumnDefinition
CloneRefOfColumnDefinition creates a deep clone of the input.
func CloneSliceOfRefOfColumnDefinition ¶
func CloneSliceOfRefOfColumnDefinition(n []*ColumnDefinition) []*ColumnDefinition
CloneSliceOfRefOfColumnDefinition creates a deep clone of the input.
func (*ColumnDefinition) CachedSize ¶
func (cached *ColumnDefinition) CachedSize(alloc bool) int64
func (*ColumnDefinition) Format ¶
func (col *ColumnDefinition) Format(buf *TrackedBuffer)
Format formats the node.
type ColumnFormat ¶
type ColumnFormat int
ColumnFormat is an enum that defines the type of storage.
const ( UnspecifiedFormat ColumnFormat = iota FixedFormat DynamicFormat DefaultFormat )
ColumnFormat constants
func (ColumnFormat) ToString ¶
func (columnFormat ColumnFormat) ToString() string
ToString returns the string associated with JoinType
type ColumnKeyOption ¶
type ColumnKeyOption int
ColumnKeyOption indicates whether or not the given column is defined as an index element and contains the type of the option
type ColumnStorage ¶
type ColumnStorage int
ColumnStorage is an enum that defines the type of storage.
const ( VirtualStorage ColumnStorage = iota StoredStorage )
ColumnStorage constants
type ColumnType ¶
type ColumnType struct { // The base type string Type string // Generic field options. Options *ColumnTypeOptions // Numeric field options Length *Literal Unsigned bool Zerofill bool Scale *Literal // Text field options Charset ColumnCharset // Enum values EnumValues []string }
ColumnType represents a sql type in a CREATE TABLE statement All optional fields are nil if not specified
func CloneColumnType ¶
func CloneColumnType(n ColumnType) ColumnType
CloneColumnType creates a deep clone of the input.
func CloneRefOfColumnType ¶
func CloneRefOfColumnType(n *ColumnType) *ColumnType
CloneRefOfColumnType creates a deep clone of the input.
func (*ColumnType) CachedSize ¶
func (cached *ColumnType) CachedSize(alloc bool) int64
func (*ColumnType) DescribeType ¶
func (ct *ColumnType) DescribeType() string
DescribeType returns the abbreviated type information as required for describe table
func (*ColumnType) Format ¶
func (ct *ColumnType) Format(buf *TrackedBuffer)
Format returns a canonical string representation of the type and all relevant options
func (*ColumnType) SQLType ¶
func (ct *ColumnType) SQLType() sqltypes.Type
SQLType returns the sqltypes type code for the given column
type ColumnTypeOptions ¶
type ColumnTypeOptions struct { /* We need Null to be *bool to distinguish 3 cases - 1. When Not Null is specified (Null = false) 2. When Null is specified (Null = true) 3. When nothing is specified (Null = nil) The complexity arises from the fact that we do not know whether the column will be nullable or not if nothing is specified. Therefore we do not know whether the column is nullable or not in case 3. */ Null *bool Autoincrement bool Default Expr OnUpdate Expr As Expr Comment *Literal Storage ColumnStorage Collate string // Reference stores a foreign key constraint for the given column Reference *ReferenceDefinition // Key specification KeyOpt ColumnKeyOption // Stores the tri state of having either VISIBLE, INVISIBLE or nothing specified // on the column. In case of nothing, this is nil, when VISIBLE is set it's false // and only when INVISIBLE is set does the pointer value return true. Invisible *bool // Storage format for this specific column. This is NDB specific, but the parser // still allows for it and ignores it for other storage engines. So we also should // parse it but it's then not used anywhere. Format ColumnFormat // EngineAttribute is a new attribute not used for anything yet, but accepted // since 8.0.23 in the MySQL parser. EngineAttribute *Literal // SecondaryEngineAttribute is a new attribute not used for anything yet, but accepted // since 8.0.23 in the MySQL parser. SecondaryEngineAttribute *Literal // SRID is an attribute that indiciates the spatial reference system. // // https://dev.mysql.com/doc/refman/8.0/en/spatial-type-overview.html SRID *Literal }
ColumnTypeOptions are generic field options for a column type
func CloneRefOfColumnTypeOptions ¶
func CloneRefOfColumnTypeOptions(n *ColumnTypeOptions) *ColumnTypeOptions
CloneRefOfColumnTypeOptions creates a deep clone of the input.
func (*ColumnTypeOptions) CachedSize ¶
func (cached *ColumnTypeOptions) CachedSize(alloc bool) int64
type Columns ¶
type Columns []ColIdent
Columns represents an insert column list.
func CloneColumns ¶
CloneColumns creates a deep clone of the input.
func (Columns) FindColumn ¶
FindColumn finds a column in the column list, returning the index if it exists or -1 otherwise
type CommentDirectives ¶
CommentDirectives is the parsed representation for execution directives conveyed in query comments
func (CommentDirectives) GetString ¶
func (d CommentDirectives) GetString(key string, defaultVal string) string
GetString gets a directive value as string, with default value if not found
func (CommentDirectives) IsSet ¶
func (d CommentDirectives) IsSet(key string) bool
IsSet checks the directive map for the named directive and returns true if the directive is set and has a true/false or 0/1 value
type Commented ¶
type Commented interface { SetComments(comments Comments) GetParsedComments() *ParsedComments }
Statements
type Comments ¶
type Comments []string
Comments represents a list of comments.
func CloneComments ¶
CloneComments creates a deep clone of the input.
func CommentsForStatement ¶
func (Comments) Parsed ¶
func (c Comments) Parsed() *ParsedComments
type Commit ¶
type Commit struct{}
Commit represents a Commit statement.
func CloneRefOfCommit ¶
CloneRefOfCommit creates a deep clone of the input.
type CommonTableExpr ¶
type CommonTableExpr struct { TableID TableIdent Columns Columns Subquery *Subquery }
CommonTableExpr is the structure for supporting common table expressions
func CloneRefOfCommonTableExpr ¶
func CloneRefOfCommonTableExpr(n *CommonTableExpr) *CommonTableExpr
CloneRefOfCommonTableExpr creates a deep clone of the input.
func CloneSliceOfRefOfCommonTableExpr ¶
func CloneSliceOfRefOfCommonTableExpr(n []*CommonTableExpr) []*CommonTableExpr
CloneSliceOfRefOfCommonTableExpr creates a deep clone of the input.
func (*CommonTableExpr) CachedSize ¶
func (cached *CommonTableExpr) CachedSize(alloc bool) int64
func (*CommonTableExpr) Format ¶
func (node *CommonTableExpr) Format(buf *TrackedBuffer)
Format formats the node.
type ComparisonExpr ¶
type ComparisonExpr struct { Operator ComparisonExprOperator Left, Right Expr Escape Expr }
ComparisonExpr represents a two-value comparison expression.
func CloneRefOfComparisonExpr ¶
func CloneRefOfComparisonExpr(n *ComparisonExpr) *ComparisonExpr
CloneRefOfComparisonExpr creates a deep clone of the input.
func (*ComparisonExpr) CachedSize ¶
func (cached *ComparisonExpr) CachedSize(alloc bool) int64
func (*ComparisonExpr) Format ¶
func (node *ComparisonExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*ComparisonExpr) IsImpossible ¶
func (node *ComparisonExpr) IsImpossible() bool
IsImpossible returns true if the comparison in the expression can never evaluate to true. Note that this is not currently exhaustive to ALL impossible comparisons.
type ComparisonExprOperator ¶
type ComparisonExprOperator int8
ComparisonExprOperator is an enum for ComparisonExpr.Operator
const ( EqualOp ComparisonExprOperator = iota LessThanOp GreaterThanOp LessEqualOp GreaterEqualOp NotEqualOp NullSafeEqualOp InOp NotInOp LikeOp NotLikeOp RegexpOp NotRegexpOp )
Constants for Enum Type - ComparisonExprOperator
func (ComparisonExprOperator) ToString ¶
func (op ComparisonExprOperator) ToString() string
ToString returns the operator as a string
type ConstraintDefinition ¶
type ConstraintDefinition struct { Name ColIdent Details ConstraintInfo }
ConstraintDefinition describes a constraint in a CREATE TABLE statement
func CloneRefOfConstraintDefinition ¶
func CloneRefOfConstraintDefinition(n *ConstraintDefinition) *ConstraintDefinition
CloneRefOfConstraintDefinition creates a deep clone of the input.
func CloneSliceOfRefOfConstraintDefinition ¶
func CloneSliceOfRefOfConstraintDefinition(n []*ConstraintDefinition) []*ConstraintDefinition
CloneSliceOfRefOfConstraintDefinition creates a deep clone of the input.
func (*ConstraintDefinition) CachedSize ¶
func (cached *ConstraintDefinition) CachedSize(alloc bool) int64
func (*ConstraintDefinition) Format ¶
func (c *ConstraintDefinition) Format(buf *TrackedBuffer)
Format formats the node.
type ConstraintInfo ¶
type ConstraintInfo interface { SQLNode // contains filtered or unexported methods }
ConstraintInfo details a constraint in a CREATE TABLE statement
func CloneConstraintInfo ¶
func CloneConstraintInfo(in ConstraintInfo) ConstraintInfo
CloneConstraintInfo creates a deep clone of the input.
type ConvertExpr ¶
type ConvertExpr struct { Expr Expr Type *ConvertType }
ConvertExpr represents a call to CONVERT(expr, type) or it's equivalent CAST(expr AS type). Both are rewritten to the former.
func CloneRefOfConvertExpr ¶
func CloneRefOfConvertExpr(n *ConvertExpr) *ConvertExpr
CloneRefOfConvertExpr creates a deep clone of the input.
func (*ConvertExpr) CachedSize ¶
func (cached *ConvertExpr) CachedSize(alloc bool) int64
func (*ConvertExpr) Format ¶
func (node *ConvertExpr) Format(buf *TrackedBuffer)
Format formats the node.
type ConvertType ¶
type ConvertType struct { Type string Length *Literal Scale *Literal Charset ColumnCharset }
ConvertType represents the type in call to CONVERT(expr, type)
func CloneRefOfConvertType ¶
func CloneRefOfConvertType(n *ConvertType) *ConvertType
CloneRefOfConvertType creates a deep clone of the input.
func (*ConvertType) CachedSize ¶
func (cached *ConvertType) CachedSize(alloc bool) int64
func (*ConvertType) Format ¶
func (node *ConvertType) Format(buf *TrackedBuffer)
Format formats the node.
type ConvertUsingExpr ¶
ConvertUsingExpr represents a call to CONVERT(expr USING charset).
func CloneRefOfConvertUsingExpr ¶
func CloneRefOfConvertUsingExpr(n *ConvertUsingExpr) *ConvertUsingExpr
CloneRefOfConvertUsingExpr creates a deep clone of the input.
func (*ConvertUsingExpr) CachedSize ¶
func (cached *ConvertUsingExpr) CachedSize(alloc bool) int64
func (*ConvertUsingExpr) Format ¶
func (node *ConvertUsingExpr) Format(buf *TrackedBuffer)
Format formats the node.
type CreateDatabase ¶
type CreateDatabase struct { Comments *ParsedComments DBName TableIdent IfNotExists bool CreateOptions []DatabaseOption FullyParsed bool }
CreateDatabase represents a CREATE database statement.
func CloneRefOfCreateDatabase ¶
func CloneRefOfCreateDatabase(n *CreateDatabase) *CreateDatabase
CloneRefOfCreateDatabase creates a deep clone of the input.
func (*CreateDatabase) CachedSize ¶
func (cached *CreateDatabase) CachedSize(alloc bool) int64
func (*CreateDatabase) Format ¶
func (node *CreateDatabase) Format(buf *TrackedBuffer)
Format formats the node.
func (*CreateDatabase) GetDatabaseName ¶
func (node *CreateDatabase) GetDatabaseName() string
GetDatabaseName implements the DBDDLStatement interface
func (*CreateDatabase) IsFullyParsed ¶
func (node *CreateDatabase) IsFullyParsed() bool
IsFullyParsed implements the DBDDLStatement interface
func (*CreateDatabase) SetFullyParsed ¶
func (node *CreateDatabase) SetFullyParsed(fullyParsed bool)
SetFullyParsed implements the DBDDLStatement interface
type CreateTable ¶
type CreateTable struct { Temp bool Table TableName IfNotExists bool TableSpec *TableSpec OptLike *OptLike Comments *ParsedComments FullyParsed bool }
CreateTable represents a CREATE TABLE statement.
func CloneRefOfCreateTable ¶
func CloneRefOfCreateTable(n *CreateTable) *CreateTable
CloneRefOfCreateTable creates a deep clone of the input.
func (*CreateTable) AffectedTables ¶
func (node *CreateTable) AffectedTables() TableNames
AffectedTables implements DDLStatement.
func (*CreateTable) CachedSize ¶
func (cached *CreateTable) CachedSize(alloc bool) int64
func (*CreateTable) Format ¶
func (node *CreateTable) Format(buf *TrackedBuffer)
Format formats the node.
func (*CreateTable) GetAction ¶
func (node *CreateTable) GetAction() DDLAction
GetAction implements the DDLStatement interface
func (*CreateTable) GetFromTables ¶
func (node *CreateTable) GetFromTables() TableNames
GetFromTables implements the DDLStatement interface
func (*CreateTable) GetIfExists ¶
func (node *CreateTable) GetIfExists() bool
GetIfExists implements the DDLStatement interface
func (*CreateTable) GetIfNotExists ¶
func (node *CreateTable) GetIfNotExists() bool
GetIfNotExists implements the DDLStatement interface
func (*CreateTable) GetIsReplace ¶
func (node *CreateTable) GetIsReplace() bool
GetIsReplace implements the DDLStatement interface
func (*CreateTable) GetOptLike ¶
func (node *CreateTable) GetOptLike() *OptLike
GetOptLike implements the DDLStatement interface
func (*CreateTable) GetParsedComments ¶
func (node *CreateTable) GetParsedComments() *ParsedComments
GetParsedComments implements DDLStatement.
func (*CreateTable) GetTable ¶
func (node *CreateTable) GetTable() TableName
GetTable implements the DDLStatement interface
func (*CreateTable) GetTableSpec ¶
func (node *CreateTable) GetTableSpec() *TableSpec
GetTableSpec implements the DDLStatement interface
func (*CreateTable) GetToTables ¶
func (node *CreateTable) GetToTables() TableNames
GetToTables implements the DDLStatement interface
func (*CreateTable) IsFullyParsed ¶
func (node *CreateTable) IsFullyParsed() bool
IsFullyParsed implements the DDLStatement interface
func (*CreateTable) IsTemporary ¶
func (node *CreateTable) IsTemporary() bool
IsTemporary implements the DDLStatement interface
func (*CreateTable) SetComments ¶
func (node *CreateTable) SetComments(comments Comments)
SetComments implements DDLStatement.
func (*CreateTable) SetFromTables ¶
func (node *CreateTable) SetFromTables(tables TableNames)
SetFromTables implements DDLStatement.
func (*CreateTable) SetFullyParsed ¶
func (node *CreateTable) SetFullyParsed(fullyParsed bool)
SetFullyParsed implements the DDLStatement interface
func (*CreateTable) SetTable ¶
func (node *CreateTable) SetTable(qualifier string, name string)
SetTable implements DDLStatement.
type CreateView ¶
type CreateView struct { ViewName TableName Algorithm string Definer *Definer Security string Columns Columns Select SelectStatement CheckOption string IsReplace bool Comments *ParsedComments }
CreateView represents a CREATE VIEW query
func CloneRefOfCreateView ¶
func CloneRefOfCreateView(n *CreateView) *CreateView
CloneRefOfCreateView creates a deep clone of the input.
func (*CreateView) AffectedTables ¶
func (node *CreateView) AffectedTables() TableNames
AffectedTables implements DDLStatement.
func (*CreateView) CachedSize ¶
func (cached *CreateView) CachedSize(alloc bool) int64
func (*CreateView) Format ¶
func (node *CreateView) Format(buf *TrackedBuffer)
Format formats the node.
func (*CreateView) GetAction ¶
func (node *CreateView) GetAction() DDLAction
GetAction implements the DDLStatement interface
func (*CreateView) GetFromTables ¶
func (node *CreateView) GetFromTables() TableNames
GetFromTables implements the DDLStatement interface
func (*CreateView) GetIfExists ¶
func (node *CreateView) GetIfExists() bool
GetIfExists implements the DDLStatement interface
func (*CreateView) GetIfNotExists ¶
func (node *CreateView) GetIfNotExists() bool
GetIfNotExists implements the DDLStatement interface
func (*CreateView) GetIsReplace ¶
func (node *CreateView) GetIsReplace() bool
GetIsReplace implements the DDLStatement interface
func (*CreateView) GetOptLike ¶
func (node *CreateView) GetOptLike() *OptLike
GetOptLike implements the DDLStatement interface
func (*CreateView) GetParsedComments ¶
func (node *CreateView) GetParsedComments() *ParsedComments
GetParsedComments implements DDLStatement.
func (*CreateView) GetTable ¶
func (node *CreateView) GetTable() TableName
GetTable implements the DDLStatement interface
func (*CreateView) GetTableSpec ¶
func (node *CreateView) GetTableSpec() *TableSpec
GetTableSpec implements the DDLStatement interface
func (*CreateView) GetToTables ¶
func (node *CreateView) GetToTables() TableNames
GetToTables implements the DDLStatement interface
func (*CreateView) IsFullyParsed ¶
func (node *CreateView) IsFullyParsed() bool
IsFullyParsed implements the DDLStatement interface
func (*CreateView) IsTemporary ¶
func (node *CreateView) IsTemporary() bool
IsTemporary implements the DDLStatement interface
func (*CreateView) SetComments ¶
func (node *CreateView) SetComments(comments Comments)
SetComments implements DDLStatement.
func (*CreateView) SetFromTables ¶
func (node *CreateView) SetFromTables(tables TableNames)
SetFromTables implements DDLStatement.
func (*CreateView) SetFullyParsed ¶
func (node *CreateView) SetFullyParsed(fullyParsed bool)
SetFullyParsed implements the DDLStatement interface
func (*CreateView) SetTable ¶
func (node *CreateView) SetTable(qualifier string, name string)
SetTable implements DDLStatement.
type CurTimeFuncExpr ¶
type CurTimeFuncExpr struct { Name ColIdent Fsp Expr // fractional seconds precision, integer from 0 to 6 or an Argument }
CurTimeFuncExpr represents the function and arguments for CURRENT DATE/TIME functions supported functions are documented in the grammar
func CloneRefOfCurTimeFuncExpr ¶
func CloneRefOfCurTimeFuncExpr(n *CurTimeFuncExpr) *CurTimeFuncExpr
CloneRefOfCurTimeFuncExpr creates a deep clone of the input.
func (*CurTimeFuncExpr) CachedSize ¶
func (cached *CurTimeFuncExpr) CachedSize(alloc bool) int64
func (*CurTimeFuncExpr) Format ¶
func (node *CurTimeFuncExpr) Format(buf *TrackedBuffer)
Format formats the node.
type Cursor ¶
type Cursor struct {
// contains filtered or unexported fields
}
A Cursor describes a node encountered during Apply. Information about the node and its parent is available from the Node and Parent methods.
func (*Cursor) Replace ¶
Replace replaces the current node in the parent field with this new object. The use needs to make sure to not replace the object with something of the wrong type, or the visitor will panic.
func (*Cursor) ReplaceAndRevisit ¶
ReplaceAndRevisit replaces the current node in the parent field with this new object. When used, this will abort the visitation of the current node - no post or children visited, and the new node visited.
type DBDDLStatement ¶
type DBDDLStatement interface { IsFullyParsed() bool GetDatabaseName() string SetFullyParsed(bool) Statement // contains filtered or unexported methods }
DBDDLStatement represents any DBDDL Statement
func CloneDBDDLStatement ¶
func CloneDBDDLStatement(in DBDDLStatement) DBDDLStatement
CloneDBDDLStatement creates a deep clone of the input.
type DDLAction ¶
type DDLAction int8
DDLAction is an enum for DDL.Action
const ( CreateDDLAction DDLAction = iota AlterDDLAction DropDDLAction RenameDDLAction TruncateDDLAction CreateVindexDDLAction DropVindexDDLAction AddVschemaTableDDLAction DropVschemaTableDDLAction AddColVindexDDLAction DropColVindexDDLAction AddSequenceDDLAction AddAutoIncDDLAction RevertDDLAction )
Constants for Enum Type - DDL.Action
type DDLStatement ¶
type DDLStatement interface { IsFullyParsed() bool IsTemporary() bool GetTable() TableName GetAction() DDLAction GetOptLike() *OptLike GetIfExists() bool GetIfNotExists() bool GetIsReplace() bool GetTableSpec() *TableSpec GetFromTables() TableNames GetToTables() TableNames AffectedTables() TableNames SetTable(qualifier string, name string) SetFromTables(tables TableNames) SetFullyParsed(fullyParsed bool) Commented Statement // contains filtered or unexported methods }
DDLStatement represents any DDL Statement
func CloneDDLStatement ¶
func CloneDDLStatement(in DDLStatement) DDLStatement
CloneDDLStatement creates a deep clone of the input.
type DatabaseOption ¶
type DatabaseOption struct { Type DatabaseOptionType IsDefault bool Value string }
DatabaseOption is a struct that stores Collation or Character Set value
func CloneDatabaseOption ¶
func CloneDatabaseOption(n DatabaseOption) DatabaseOption
CloneDatabaseOption creates a deep clone of the input.
func CloneRefOfDatabaseOption ¶
func CloneRefOfDatabaseOption(n *DatabaseOption) *DatabaseOption
CloneRefOfDatabaseOption creates a deep clone of the input.
func CloneSliceOfDatabaseOption ¶
func CloneSliceOfDatabaseOption(n []DatabaseOption) []DatabaseOption
CloneSliceOfDatabaseOption creates a deep clone of the input.
func (*DatabaseOption) CachedSize ¶
func (cached *DatabaseOption) CachedSize(alloc bool) int64
type DatabaseOptionType ¶
type DatabaseOptionType int8
DatabaseOptionType is an enum for create database options
const ( CollateType DatabaseOptionType = iota CharacterSetType EncryptionType )
Constant for Enum Type - DatabaseOptionType
func (DatabaseOptionType) ToString ¶
func (node DatabaseOptionType) ToString() string
ToString returns the type as a string
type DeallocateStmt ¶
type DeallocateStmt struct { Type DeallocateStmtType Comments *ParsedComments Name ColIdent }
DeallocateStmt represents a Deallocate Statement More info available on https://dev.mysql.com/doc/refman/8.0/en/deallocate-prepare.html
func CloneRefOfDeallocateStmt ¶
func CloneRefOfDeallocateStmt(n *DeallocateStmt) *DeallocateStmt
CloneRefOfDeallocateStmt creates a deep clone of the input.
func (*DeallocateStmt) CachedSize ¶
func (cached *DeallocateStmt) CachedSize(alloc bool) int64
func (*DeallocateStmt) Format ¶
func (node *DeallocateStmt) Format(buf *TrackedBuffer)
Format formats the node.
type DeallocateStmtType ¶
type DeallocateStmtType int8
DeallocateStmtType is an enum to get types of deallocate
const ( DeallocateType DeallocateStmtType = iota DropType )
Constant for Enum Type - DeallocateStmtType
func (DeallocateStmtType) ToString ¶
func (ty DeallocateStmtType) ToString() string
ToString returns the type as a string
type Default ¶
type Default struct {
ColName string
}
Default represents a DEFAULT expression.
func CloneRefOfDefault ¶
CloneRefOfDefault creates a deep clone of the input.
func (*Default) CachedSize ¶
type Definer ¶
Definer stores the user for AlterView and CreateView definers
func CloneRefOfDefiner ¶
CloneRefOfDefiner creates a deep clone of the input.
func (*Definer) CachedSize ¶
func (*Definer) Format ¶
func (definer *Definer) Format(buf *TrackedBuffer)
type Delete ¶
type Delete struct { With *With Ignore Ignore Comments *ParsedComments Targets TableNames TableExprs TableExprs Partitions Partitions Where *Where OrderBy OrderBy Limit *Limit }
Delete represents a DELETE statement. If you add fields here, consider adding them to calls to validateUnshardedRoute.
func CloneRefOfDelete ¶
CloneRefOfDelete creates a deep clone of the input.
func (*Delete) CachedSize ¶
func (*Delete) GetParsedComments ¶
func (node *Delete) GetParsedComments() *ParsedComments
GetParsedComments implements SupportOptimizerHint.
func (*Delete) SetComments ¶
SetComments for Delete
type DerivedTable ¶
type DerivedTable struct { Lateral bool Select SelectStatement }
DerivedTable represents a subquery used as a table expression.
func CloneRefOfDerivedTable ¶
func CloneRefOfDerivedTable(n *DerivedTable) *DerivedTable
CloneRefOfDerivedTable creates a deep clone of the input.
func (*DerivedTable) CachedSize ¶
func (cached *DerivedTable) CachedSize(alloc bool) int64
func (*DerivedTable) Format ¶
func (node *DerivedTable) Format(buf *TrackedBuffer)
Format formats the node.
type DropColumn ¶
type DropColumn struct {
Name *ColName
}
DropColumn is used to drop a column in an alter table statement
func CloneRefOfDropColumn ¶
func CloneRefOfDropColumn(n *DropColumn) *DropColumn
CloneRefOfDropColumn creates a deep clone of the input.
func (*DropColumn) CachedSize ¶
func (cached *DropColumn) CachedSize(alloc bool) int64
func (*DropColumn) Format ¶
func (node *DropColumn) Format(buf *TrackedBuffer)
Format formats the node
type DropDatabase ¶
type DropDatabase struct { Comments *ParsedComments DBName TableIdent IfExists bool }
DropDatabase represents a DROP database statement.
func CloneRefOfDropDatabase ¶
func CloneRefOfDropDatabase(n *DropDatabase) *DropDatabase
CloneRefOfDropDatabase creates a deep clone of the input.
func (*DropDatabase) CachedSize ¶
func (cached *DropDatabase) CachedSize(alloc bool) int64
func (*DropDatabase) Format ¶
func (node *DropDatabase) Format(buf *TrackedBuffer)
Format formats the node.
func (*DropDatabase) GetDatabaseName ¶
func (node *DropDatabase) GetDatabaseName() string
GetDatabaseName implements the DBDDLStatement interface
func (*DropDatabase) IsFullyParsed ¶
func (node *DropDatabase) IsFullyParsed() bool
IsFullyParsed implements the DBDDLStatement interface
func (*DropDatabase) SetFullyParsed ¶
func (node *DropDatabase) SetFullyParsed(fullyParsed bool)
SetFullyParsed implements the DBDDLStatement interface
type DropKey ¶
type DropKey struct { Type DropKeyType Name ColIdent }
DropKey is used to drop a key in an alter table statement
func CloneRefOfDropKey ¶
CloneRefOfDropKey creates a deep clone of the input.
func (*DropKey) CachedSize ¶
type DropKeyType ¶
type DropKeyType int8
DropKeyType is an enum that represents the type of key being dropped in an alter table statement
const ( PrimaryKeyType DropKeyType = iota ForeignKeyType NormalKeyType CheckKeyType )
DropKeyType constants
func (DropKeyType) ToString ¶
func (key DropKeyType) ToString() string
ToString returns the DropKeyType as a string
type DropTable ¶
type DropTable struct { Temp bool FromTables TableNames // The following fields are set if a DDL was fully analyzed. IfExists bool Comments *ParsedComments }
DropTable represents a DROP TABLE statement.
func CloneRefOfDropTable ¶
CloneRefOfDropTable creates a deep clone of the input.
func (*DropTable) AffectedTables ¶
func (node *DropTable) AffectedTables() TableNames
AffectedTables returns the list table names affected by the DDLStatement.
func (*DropTable) CachedSize ¶
func (*DropTable) Format ¶
func (node *DropTable) Format(buf *TrackedBuffer)
Format formats the node.
func (*DropTable) GetFromTables ¶
func (node *DropTable) GetFromTables() TableNames
GetFromTables implements the DDLStatement interface
func (*DropTable) GetIfExists ¶
GetIfExists implements the DDLStatement interface
func (*DropTable) GetIfNotExists ¶
GetIfNotExists implements the DDLStatement interface
func (*DropTable) GetIsReplace ¶
GetIsReplace implements the DDLStatement interface
func (*DropTable) GetOptLike ¶
GetOptLike implements the DDLStatement interface
func (*DropTable) GetParsedComments ¶
func (node *DropTable) GetParsedComments() *ParsedComments
GetParsedComments implements DDLStatement.
func (*DropTable) GetTableSpec ¶
GetTableSpec implements the DDLStatement interface
func (*DropTable) GetToTables ¶
func (node *DropTable) GetToTables() TableNames
GetToTables implements the DDLStatement interface
func (*DropTable) IsFullyParsed ¶
IsFullyParsed implements the DDLStatement interface
func (*DropTable) IsTemporary ¶
IsTemporary implements the DDLStatement interface
func (*DropTable) SetComments ¶
SetComments implements DDLStatement.
func (*DropTable) SetFromTables ¶
func (node *DropTable) SetFromTables(tables TableNames)
SetFromTables implements DDLStatement.
func (*DropTable) SetFullyParsed ¶
SetFullyParsed implements the DDLStatement interface
type DropView ¶
type DropView struct { FromTables TableNames IfExists bool Comments *ParsedComments }
DropView represents a DROP VIEW statement.
func CloneRefOfDropView ¶
CloneRefOfDropView creates a deep clone of the input.
func (*DropView) AffectedTables ¶
func (node *DropView) AffectedTables() TableNames
AffectedTables returns the list table names affected by the DDLStatement.
func (*DropView) CachedSize ¶
func (*DropView) GetFromTables ¶
func (node *DropView) GetFromTables() TableNames
GetFromTables implements the DDLStatement interface
func (*DropView) GetIfExists ¶
GetIfExists implements the DDLStatement interface
func (*DropView) GetIfNotExists ¶
GetIfNotExists implements the DDLStatement interface
func (*DropView) GetIsReplace ¶
GetIsReplace implements the DDLStatement interface
func (*DropView) GetOptLike ¶
GetOptLike implements the DDLStatement interface
func (*DropView) GetParsedComments ¶
func (node *DropView) GetParsedComments() *ParsedComments
GetParsedComments implements DDLStatement.
func (*DropView) GetTableSpec ¶
GetTableSpec implements the DDLStatement interface
func (*DropView) GetToTables ¶
func (node *DropView) GetToTables() TableNames
GetToTables implements the DDLStatement interface
func (*DropView) IsFullyParsed ¶
IsFullyParsed implements the DDLStatement interface
func (*DropView) IsTemporary ¶
IsTemporary implements the DDLStatement interface
func (*DropView) SetComments ¶
SetComments implements DDLStatement.
func (*DropView) SetFromTables ¶
func (node *DropView) SetFromTables(tables TableNames)
SetFromTables implements DDLStatement.
func (*DropView) SetFullyParsed ¶
SetFullyParsed implements the DDLStatement interface
type ExecuteStmt ¶
type ExecuteStmt struct { Name ColIdent Comments *ParsedComments Arguments Columns }
ExecuteStmt represents an Execute Statement More info available on https://dev.mysql.com/doc/refman/8.0/en/execute.html
func CloneRefOfExecuteStmt ¶
func CloneRefOfExecuteStmt(n *ExecuteStmt) *ExecuteStmt
CloneRefOfExecuteStmt creates a deep clone of the input.
func (*ExecuteStmt) CachedSize ¶
func (cached *ExecuteStmt) CachedSize(alloc bool) int64
func (*ExecuteStmt) Format ¶
func (node *ExecuteStmt) Format(buf *TrackedBuffer)
Format formats the node.
type ExistsExpr ¶
type ExistsExpr struct {
Subquery *Subquery
}
ExistsExpr represents an EXISTS expression.
func CloneRefOfExistsExpr ¶
func CloneRefOfExistsExpr(n *ExistsExpr) *ExistsExpr
CloneRefOfExistsExpr creates a deep clone of the input.
func (*ExistsExpr) CachedSize ¶
func (cached *ExistsExpr) CachedSize(alloc bool) int64
func (*ExistsExpr) Format ¶
func (node *ExistsExpr) Format(buf *TrackedBuffer)
Format formats the node.
type Explain ¶
type Explain interface { Statement // contains filtered or unexported methods }
Explain is an interface that represents the Explain statements
func CloneExplain ¶
CloneExplain creates a deep clone of the input.
type ExplainStmt ¶
type ExplainStmt struct { Type ExplainType Statement Statement }
ExplainStmt represents an Explain statement
func CloneRefOfExplainStmt ¶
func CloneRefOfExplainStmt(n *ExplainStmt) *ExplainStmt
CloneRefOfExplainStmt creates a deep clone of the input.
func (*ExplainStmt) CachedSize ¶
func (cached *ExplainStmt) CachedSize(alloc bool) int64
func (*ExplainStmt) Format ¶
func (node *ExplainStmt) Format(buf *TrackedBuffer)
Format formats the node.
type ExplainTab ¶
ExplainTab represents the Explain table
func CloneRefOfExplainTab ¶
func CloneRefOfExplainTab(n *ExplainTab) *ExplainTab
CloneRefOfExplainTab creates a deep clone of the input.
func (*ExplainTab) CachedSize ¶
func (cached *ExplainTab) CachedSize(alloc bool) int64
func (*ExplainTab) Format ¶
func (node *ExplainTab) Format(buf *TrackedBuffer)
Format formats the node.
type ExplainType ¶
type ExplainType int8
ExplainType is an enum for ExplainStmt.Type
const ( EmptyType ExplainType = iota TreeType JSONType VitessType TraditionalType AnalyzeType )
Constant for Enum Type - ExplainType
func (ExplainType) ToString ¶
func (ty ExplainType) ToString() string
ToString returns the type as a string
type Expr ¶
type Expr interface { SQLNode // contains filtered or unexported methods }
Expr represents an expression.
func AndExpressions ¶
AndExpressions ands together two or more expressions, minimising the expr when possible
func RemoveKeyspaceFromColName ¶
RemoveKeyspaceFromColName removes the Qualifier.Qualifier on all ColNames in the expression tree
func ReplaceExpr ¶
ReplaceExpr finds the from expression from root and replaces it with to. If from matches root, then to is returned.
func SplitAndExpression ¶
SplitAndExpression breaks up the Expr into AND-separated conditions and appends them to filters. Outer parenthesis are removed. Precedence should be taken into account if expressions are recombined.
type Exprs ¶
type Exprs []Expr
Exprs represents a list of value expressions. It's not a valid expression because it's not parenthesized.
type ExtractFuncExpr ¶
type ExtractFuncExpr struct { IntervalTypes IntervalTypes Expr Expr }
ExtractFuncExpr represents the function and arguments for EXTRACT(YEAR FROM '2019-07-02') type functions.
func CloneRefOfExtractFuncExpr ¶
func CloneRefOfExtractFuncExpr(n *ExtractFuncExpr) *ExtractFuncExpr
CloneRefOfExtractFuncExpr creates a deep clone of the input.
func (*ExtractFuncExpr) CachedSize ¶
func (cached *ExtractFuncExpr) CachedSize(alloc bool) int64
func (*ExtractFuncExpr) Format ¶
func (node *ExtractFuncExpr) Format(buf *TrackedBuffer)
Format formats the node.
type ExtractedSubquery ¶
type ExtractedSubquery struct { Original Expr // original expression that was replaced by this ExtractedSubquery OpCode int // this should really be engine.PulloutOpCode, but we cannot depend on engine :( Subquery *Subquery OtherSide Expr // represents the side of the comparison, this field will be nil if Original is not a comparison NeedsRewrite bool // tells whether we need to rewrite this subquery to Original or not // contains filtered or unexported fields }
ExtractedSubquery is a subquery that has been extracted from the original AST This is a struct that the parser will never produce - it's written and read by the gen4 planner CAUTION: you should only change argName and hasValuesArg through the setter methods
func CloneRefOfExtractedSubquery ¶
func CloneRefOfExtractedSubquery(n *ExtractedSubquery) *ExtractedSubquery
CloneRefOfExtractedSubquery creates a deep clone of the input.
func (*ExtractedSubquery) CachedSize ¶
func (cached *ExtractedSubquery) CachedSize(alloc bool) int64
func (*ExtractedSubquery) Format ¶
func (node *ExtractedSubquery) Format(buf *TrackedBuffer)
Format formats the node. If an extracted subquery is still in the AST when we print it, it will be formatted as if the subquery has been extracted, and instead show up like argument comparisons
func (*ExtractedSubquery) GetArgName ¶
func (es *ExtractedSubquery) GetArgName() string
GetArgName returns argument name.
func (*ExtractedSubquery) GetHasValuesArg ¶
func (es *ExtractedSubquery) GetHasValuesArg() string
GetHasValuesArg returns has values argument.
func (*ExtractedSubquery) SetArgName ¶
func (es *ExtractedSubquery) SetArgName(n string)
SetArgName sets argument name.
func (*ExtractedSubquery) SetHasValuesArg ¶
func (es *ExtractedSubquery) SetHasValuesArg(n string)
SetHasValuesArg sets has_values argument.
type Flush ¶
type Flush struct { IsLocal bool FlushOptions []string TableNames TableNames WithLock bool ForExport bool }
Flush represents a FLUSH statement.
func CloneRefOfFlush ¶
CloneRefOfFlush creates a deep clone of the input.
func (*Flush) CachedSize ¶
type Force ¶
type Force struct{}
Force is used to specify force alter option in an alter table statement
func CloneRefOfForce ¶
CloneRefOfForce creates a deep clone of the input.
type ForeignKeyDefinition ¶
type ForeignKeyDefinition struct { Source Columns IndexName ColIdent ReferenceDefinition *ReferenceDefinition }
ForeignKeyDefinition describes a foreign key in a CREATE TABLE statement
func CloneRefOfForeignKeyDefinition ¶
func CloneRefOfForeignKeyDefinition(n *ForeignKeyDefinition) *ForeignKeyDefinition
CloneRefOfForeignKeyDefinition creates a deep clone of the input.
func (*ForeignKeyDefinition) CachedSize ¶
func (cached *ForeignKeyDefinition) CachedSize(alloc bool) int64
func (*ForeignKeyDefinition) Format ¶
func (f *ForeignKeyDefinition) Format(buf *TrackedBuffer)
Format formats the node.
type FuncExpr ¶
type FuncExpr struct { Qualifier TableIdent Name ColIdent Distinct bool Exprs SelectExprs }
FuncExpr represents a function call.
func CloneRefOfFuncExpr ¶
CloneRefOfFuncExpr creates a deep clone of the input.
func (*FuncExpr) CachedSize ¶
func (*FuncExpr) IsAggregate ¶
IsAggregate returns true if the function is an aggregate.
type GroupBy ¶
type GroupBy []Expr
GroupBy represents a GROUP BY clause.
func CloneGroupBy ¶
CloneGroupBy creates a deep clone of the input.
type GroupConcatExpr ¶
type GroupConcatExpr struct { Distinct bool Exprs SelectExprs OrderBy OrderBy Separator string Limit *Limit }
GroupConcatExpr represents a call to GROUP_CONCAT
func CloneRefOfGroupConcatExpr ¶
func CloneRefOfGroupConcatExpr(n *GroupConcatExpr) *GroupConcatExpr
CloneRefOfGroupConcatExpr creates a deep clone of the input.
func (*GroupConcatExpr) CachedSize ¶
func (cached *GroupConcatExpr) CachedSize(alloc bool) int64
func (*GroupConcatExpr) Format ¶
func (node *GroupConcatExpr) Format(buf *TrackedBuffer)
Format formats the node
type IndexColumn ¶
type IndexColumn struct { // Only one of Column or Expression can be specified // Length is an optional field which is only applicable when Column is used Column ColIdent Length *Literal Expression Expr Direction OrderDirection }
IndexColumn describes a column or expression in an index definition with optional length (for column)
func CloneRefOfIndexColumn ¶
func CloneRefOfIndexColumn(n *IndexColumn) *IndexColumn
CloneRefOfIndexColumn creates a deep clone of the input.
func CloneSliceOfRefOfIndexColumn ¶
func CloneSliceOfRefOfIndexColumn(n []*IndexColumn) []*IndexColumn
CloneSliceOfRefOfIndexColumn creates a deep clone of the input.
func (*IndexColumn) CachedSize ¶
func (cached *IndexColumn) CachedSize(alloc bool) int64
type IndexDefinition ¶
type IndexDefinition struct { Info *IndexInfo Columns []*IndexColumn Options []*IndexOption }
IndexDefinition describes an index in a CREATE TABLE statement
func CloneRefOfIndexDefinition ¶
func CloneRefOfIndexDefinition(n *IndexDefinition) *IndexDefinition
CloneRefOfIndexDefinition creates a deep clone of the input.
func CloneSliceOfRefOfIndexDefinition ¶
func CloneSliceOfRefOfIndexDefinition(n []*IndexDefinition) []*IndexDefinition
CloneSliceOfRefOfIndexDefinition creates a deep clone of the input.
func (*IndexDefinition) CachedSize ¶
func (cached *IndexDefinition) CachedSize(alloc bool) int64
func (*IndexDefinition) Format ¶
func (idx *IndexDefinition) Format(buf *TrackedBuffer)
Format formats the node.
type IndexHint ¶
type IndexHint struct { Type IndexHintType ForType IndexHintForType Indexes []ColIdent }
IndexHint represents an index hint. More information available on https://dev.mysql.com/doc/refman/8.0/en/index-hints.html
func CloneRefOfIndexHint ¶
CloneRefOfIndexHint creates a deep clone of the input.
func (*IndexHint) CachedSize ¶
func (*IndexHint) Format ¶
func (node *IndexHint) Format(buf *TrackedBuffer)
Format formats the node.
type IndexHintForType ¶
type IndexHintForType int8
IndexHintForType is an enum for FOR specified in an IndexHint
const ( NoForType IndexHintForType = iota JoinForType GroupByForType OrderByForType )
Constant for Enum Type - IndexHintForType
func (IndexHintForType) ToString ¶
func (ty IndexHintForType) ToString() string
ToString returns the type as a string
type IndexHintType ¶
type IndexHintType int8
IndexHintType is an enum for IndexHint.Type
const ( UseOp IndexHintType = iota IgnoreOp ForceOp )
Constant for Enum Type - IndexHintType
func (IndexHintType) ToString ¶
func (ty IndexHintType) ToString() string
ToString returns the type as a string
type IndexHints ¶
type IndexHints []*IndexHint
IndexHints represents a list of index hints.
func CloneIndexHints ¶
func CloneIndexHints(n IndexHints) IndexHints
CloneIndexHints creates a deep clone of the input.
func (IndexHints) Format ¶
func (node IndexHints) Format(buf *TrackedBuffer)
Format formats the node.
type IndexInfo ¶
type IndexInfo struct { Type string Name ColIdent ConstraintName ColIdent Primary bool Spatial bool Fulltext bool Unique bool }
IndexInfo describes the name and type of an index in a CREATE TABLE statement
func CloneRefOfIndexInfo ¶
CloneRefOfIndexInfo creates a deep clone of the input.
func (*IndexInfo) CachedSize ¶
type IndexOption ¶
IndexOption is used for trailing options for indexes: COMMENT, KEY_BLOCK_SIZE, USING, WITH PARSER
func CloneRefOfIndexOption ¶
func CloneRefOfIndexOption(n *IndexOption) *IndexOption
CloneRefOfIndexOption creates a deep clone of the input.
func CloneSliceOfRefOfIndexOption ¶
func CloneSliceOfRefOfIndexOption(n []*IndexOption) []*IndexOption
CloneSliceOfRefOfIndexOption creates a deep clone of the input.
func (*IndexOption) CachedSize ¶
func (cached *IndexOption) CachedSize(alloc bool) int64
type Insert ¶
type Insert struct { Action InsertAction Comments *ParsedComments Ignore Ignore Table TableName Partitions Partitions Columns Columns Rows InsertRows OnDup OnDup }
Insert represents an INSERT or REPLACE statement. Per the MySQL docs, http://dev.mysql.com/doc/refman/5.7/en/replace.html Replace is the counterpart to `INSERT IGNORE`, and works exactly like a normal INSERT except if the row exists. In that case it first deletes the row and re-inserts with new values. For that reason we keep it as an Insert struct. Replaces are currently disallowed in sharded schemas because of the implications the deletion part may have on vindexes. If you add fields here, consider adding them to calls to validateUnshardedRoute.
func CloneRefOfInsert ¶
CloneRefOfInsert creates a deep clone of the input.
func (*Insert) CachedSize ¶
func (*Insert) GetParsedComments ¶
func (node *Insert) GetParsedComments() *ParsedComments
GetParsedComments implements Insert.
func (*Insert) SetComments ¶
SetComments for Insert
type InsertAction ¶
type InsertAction int8
InsertAction is the action for insert.
const ( InsertAct InsertAction = iota ReplaceAct )
Constants for Enum Type - Insert.Action
type InsertRows ¶
type InsertRows interface { SQLNode // contains filtered or unexported methods }
InsertRows represents the rows for an INSERT statement.
func CloneInsertRows ¶
func CloneInsertRows(in InsertRows) InsertRows
CloneInsertRows creates a deep clone of the input.
type InsertValues ¶
InsertValues is a custom SQL encoder for the values of an insert statement.
func (InsertValues) EncodeSQL ¶
func (iv InsertValues) EncodeSQL(buf *strings.Builder)
EncodeSQL performs the SQL encoding for InsertValues.
type IntervalExpr ¶
IntervalExpr represents a date-time INTERVAL expression.
func CloneRefOfIntervalExpr ¶
func CloneRefOfIntervalExpr(n *IntervalExpr) *IntervalExpr
CloneRefOfIntervalExpr creates a deep clone of the input.
func (*IntervalExpr) CachedSize ¶
func (cached *IntervalExpr) CachedSize(alloc bool) int64
func (*IntervalExpr) Format ¶
func (node *IntervalExpr) Format(buf *TrackedBuffer)
Format formats the node.
type IntervalTypes ¶
type IntervalTypes int8
IntervalTypes is an enum to get types of intervals
const ( IntervalYear IntervalTypes = iota IntervalQuarter IntervalMonth IntervalWeek IntervalDay IntervalHour IntervalMinute IntervalSecond IntervalMicrosecond IntervalYearMonth IntervalDayHour IntervalDayMinute IntervalDaySecond IntervalHourMinute IntervalHourSecond IntervalMinuteSecond IntervalDayMicrosecond IntervalHourMicrosecond IntervalMinuteMicrosecond IntervalSecondMicrosecond )
IntervalTypes constants
func (IntervalTypes) ToString ¶
func (ty IntervalTypes) ToString() string
ToString returns the type as a string
type IntroducerExpr ¶
IntroducerExpr represents a unary value expression.
func CloneRefOfIntroducerExpr ¶
func CloneRefOfIntroducerExpr(n *IntroducerExpr) *IntroducerExpr
CloneRefOfIntroducerExpr creates a deep clone of the input.
func (*IntroducerExpr) CachedSize ¶
func (cached *IntroducerExpr) CachedSize(alloc bool) int64
func (*IntroducerExpr) Format ¶
func (node *IntroducerExpr) Format(buf *TrackedBuffer)
Format formats the node.
type IsExpr ¶
type IsExpr struct { Left Expr Right IsExprOperator }
IsExpr represents an IS ... or an IS NOT ... expression.
func CloneRefOfIsExpr ¶
CloneRefOfIsExpr creates a deep clone of the input.
func (*IsExpr) CachedSize ¶
type IsExprOperator ¶
type IsExprOperator int8
IsExprOperator is an enum for IsExpr.Operator
const ( IsNullOp IsExprOperator = iota IsNotNullOp IsTrueOp IsNotTrueOp IsFalseOp IsNotFalseOp )
Constant for Enum Type - IsExprOperator
func (IsExprOperator) ToString ¶
func (op IsExprOperator) ToString() string
ToString returns the operator as a string
type IsolationLevel ¶
type IsolationLevel int8
IsolationLevel is an enum for isolation levels
const ( ReadUncommitted IsolationLevel = iota ReadCommitted RepeatableRead Serializable )
Constants for Enum type - IsolationLevel
func (IsolationLevel) Format ¶
func (node IsolationLevel) Format(buf *TrackedBuffer)
Format formats the node.
type JSONArrayExpr ¶
type JSONArrayExpr struct {
Params Exprs
}
JSONArrayExpr represents JSON_ARRAY() More information on https://dev.mysql.com/doc/refman/8.0/en/json-creation-functions.html#function_json-array
func CloneRefOfJSONArrayExpr ¶
func CloneRefOfJSONArrayExpr(n *JSONArrayExpr) *JSONArrayExpr
CloneRefOfJSONArrayExpr creates a deep clone of the input.
func (*JSONArrayExpr) CachedSize ¶
func (cached *JSONArrayExpr) CachedSize(alloc bool) int64
func (*JSONArrayExpr) Format ¶
func (node *JSONArrayExpr) Format(buf *TrackedBuffer)
Format formats the node.
type JSONAttributeType ¶
type JSONAttributeType int8
JSONAttributeType is an enum to get types of TrimFunc. TrimFunc stand for one of the following: JSON_DEPTH JSON_TYPE JSON_VALID ENUM
const ( DepthAttributeType JSONAttributeType = iota ValidAttributeType TypeAttributeType LengthAttributeType )
Constants for Enum Type - JSONAttributeType
func (JSONAttributeType) ToString ¶
func (ty JSONAttributeType) ToString() string
ToString returns the type as a string
type JSONAttributesExpr ¶
type JSONAttributesExpr struct { Type JSONAttributeType JSONDoc Expr Path JSONPathParam }
JSONAttributesExpr represents the argument and function for functions returning JSON value attributes More information available on https://dev.mysql.com/doc/refman/8.0/en/json-attribute-functions.html
func CloneRefOfJSONAttributesExpr ¶
func CloneRefOfJSONAttributesExpr(n *JSONAttributesExpr) *JSONAttributesExpr
CloneRefOfJSONAttributesExpr creates a deep clone of the input.
func (*JSONAttributesExpr) CachedSize ¶
func (cached *JSONAttributesExpr) CachedSize(alloc bool) int64
func (*JSONAttributesExpr) Format ¶
func (node *JSONAttributesExpr) Format(buf *TrackedBuffer)
Format formats the node
type JSONContainsExpr ¶
type JSONContainsExpr struct { Target Expr Candidate Expr PathList []JSONPathParam }
JSONContainsExpr represents the function and arguments for JSON_CONTAINS() For more information, see https://dev.mysql.com/doc/refman/8.0/en/json-search-functions.html#function_json-contains
func CloneRefOfJSONContainsExpr ¶
func CloneRefOfJSONContainsExpr(n *JSONContainsExpr) *JSONContainsExpr
CloneRefOfJSONContainsExpr creates a deep clone of the input.
func (*JSONContainsExpr) CachedSize ¶
func (cached *JSONContainsExpr) CachedSize(alloc bool) int64
func (*JSONContainsExpr) Format ¶
func (node *JSONContainsExpr) Format(buf *TrackedBuffer)
Format formats the node
type JSONContainsPathExpr ¶
type JSONContainsPathExpr struct { JSONDoc Expr OneOrAll Expr PathList []JSONPathParam }
JSONContainsPathExpr represents the function and arguments for JSON_CONTAINS_PATH() For more information, see https://dev.mysql.com/doc/refman/8.0/en/json-search-functions.html#function_json-contains-path
func CloneRefOfJSONContainsPathExpr ¶
func CloneRefOfJSONContainsPathExpr(n *JSONContainsPathExpr) *JSONContainsPathExpr
CloneRefOfJSONContainsPathExpr creates a deep clone of the input.
func (*JSONContainsPathExpr) CachedSize ¶
func (cached *JSONContainsPathExpr) CachedSize(alloc bool) int64
func (*JSONContainsPathExpr) Format ¶
func (node *JSONContainsPathExpr) Format(buf *TrackedBuffer)
Format formats the node
type JSONContainsPathType ¶
type JSONContainsPathType int8
JSONContainsPathType is an enum to get types of Trim
type JSONExtractExpr ¶
type JSONExtractExpr struct { JSONDoc Expr PathList []JSONPathParam }
JSONExtractExpr represents the function and arguments for JSON_EXTRACT() For more information, see https://dev.mysql.com/doc/refman/8.0/en/json-search-functions.html#function_json-extract
func CloneRefOfJSONExtractExpr ¶
func CloneRefOfJSONExtractExpr(n *JSONExtractExpr) *JSONExtractExpr
CloneRefOfJSONExtractExpr creates a deep clone of the input.
func (*JSONExtractExpr) CachedSize ¶
func (cached *JSONExtractExpr) CachedSize(alloc bool) int64
func (*JSONExtractExpr) Format ¶
func (node *JSONExtractExpr) Format(buf *TrackedBuffer)
Format formats the node
type JSONKeysExpr ¶
type JSONKeysExpr struct { JSONDoc Expr PathList []JSONPathParam }
JSONKeysExpr represents the function and arguments for JSON_KEYS() For more information, see https://dev.mysql.com/doc/refman/8.0/en/json-search-functions.html#function_json-keys
func CloneRefOfJSONKeysExpr ¶
func CloneRefOfJSONKeysExpr(n *JSONKeysExpr) *JSONKeysExpr
CloneRefOfJSONKeysExpr creates a deep clone of the input.
func (*JSONKeysExpr) CachedSize ¶
func (cached *JSONKeysExpr) CachedSize(alloc bool) int64
func (*JSONKeysExpr) Format ¶
func (node *JSONKeysExpr) Format(buf *TrackedBuffer)
Format formats the node
type JSONObjectExpr ¶
type JSONObjectExpr struct {
Params []*JSONObjectParam
}
JSONObjectExpr represents JSON_OBJECT() More information on https://dev.mysql.com/doc/refman/8.0/en/json-creation-functions.html#function_json-object
func CloneRefOfJSONObjectExpr ¶
func CloneRefOfJSONObjectExpr(n *JSONObjectExpr) *JSONObjectExpr
CloneRefOfJSONObjectExpr creates a deep clone of the input.
func (*JSONObjectExpr) CachedSize ¶
func (cached *JSONObjectExpr) CachedSize(alloc bool) int64
func (*JSONObjectExpr) Format ¶
func (node *JSONObjectExpr) Format(buf *TrackedBuffer)
Format formats the node.
type JSONObjectParam ¶
JSONObjectParam defines a key/value parameter for a JSON_OBJECT expression
func CloneJSONObjectParam ¶
func CloneJSONObjectParam(n JSONObjectParam) JSONObjectParam
CloneJSONObjectParam creates a deep clone of the input.
func CloneRefOfJSONObjectParam ¶
func CloneRefOfJSONObjectParam(n *JSONObjectParam) *JSONObjectParam
CloneRefOfJSONObjectParam creates a deep clone of the input.
func CloneSliceOfRefOfJSONObjectParam ¶
func CloneSliceOfRefOfJSONObjectParam(n []*JSONObjectParam) []*JSONObjectParam
CloneSliceOfRefOfJSONObjectParam creates a deep clone of the input.
func (*JSONObjectParam) CachedSize ¶
func (cached *JSONObjectParam) CachedSize(alloc bool) int64
func (JSONObjectParam) Format ¶
func (node JSONObjectParam) Format(buf *TrackedBuffer)
Format formats the node.
type JSONOverlapsExpr ¶
JSONOverlapsExpr represents the function and arguments for JSON_OVERLAPS() For more information, see https://dev.mysql.com/doc/refman/8.0/en/json-search-functions.html#function_json-overlaps
func CloneRefOfJSONOverlapsExpr ¶
func CloneRefOfJSONOverlapsExpr(n *JSONOverlapsExpr) *JSONOverlapsExpr
CloneRefOfJSONOverlapsExpr creates a deep clone of the input.
func (*JSONOverlapsExpr) CachedSize ¶
func (cached *JSONOverlapsExpr) CachedSize(alloc bool) int64
func (*JSONOverlapsExpr) Format ¶
func (node *JSONOverlapsExpr) Format(buf *TrackedBuffer)
Format formats the node
type JSONPathParam ¶
type JSONPathParam Expr
JSONPathParam is used to store the path used as arguments in different JSON functions
func CloneJSONPathParam ¶
func CloneJSONPathParam(in JSONPathParam) JSONPathParam
CloneJSONPathParam creates a deep clone of the input.
func CloneSliceOfJSONPathParam ¶
func CloneSliceOfJSONPathParam(n []JSONPathParam) []JSONPathParam
CloneSliceOfJSONPathParam creates a deep clone of the input.
type JSONPrettyExpr ¶
type JSONPrettyExpr struct {
JSONVal Expr
}
JSONPrettyExpr represents the function and argument for JSON_PRETTY() https://dev.mysql.com/doc/refman/8.0/en/json-utility-functions.html#function_json-pretty
func CloneRefOfJSONPrettyExpr ¶
func CloneRefOfJSONPrettyExpr(n *JSONPrettyExpr) *JSONPrettyExpr
CloneRefOfJSONPrettyExpr creates a deep clone of the input.
func (*JSONPrettyExpr) CachedSize ¶
func (cached *JSONPrettyExpr) CachedSize(alloc bool) int64
func (*JSONPrettyExpr) Format ¶
func (node *JSONPrettyExpr) Format(buf *TrackedBuffer)
Format formats the node
type JSONQuoteExpr ¶
type JSONQuoteExpr struct {
StringArg Expr
}
JSONQuoteExpr represents JSON_QUOTE() More information https://dev.mysql.com/doc/refman/8.0/en/json-creation-functions.html#function_json-quote
func CloneRefOfJSONQuoteExpr ¶
func CloneRefOfJSONQuoteExpr(n *JSONQuoteExpr) *JSONQuoteExpr
CloneRefOfJSONQuoteExpr creates a deep clone of the input.
func (*JSONQuoteExpr) CachedSize ¶
func (cached *JSONQuoteExpr) CachedSize(alloc bool) int64
func (*JSONQuoteExpr) Format ¶
func (node *JSONQuoteExpr) Format(buf *TrackedBuffer)
Format formats the node.
type JSONRemoveExpr ¶
JSONRemoveExpr represents the JSON_REMOVE() For more information, visit https://dev.mysql.com/doc/refman/8.0/en/json-modification-functions.html#function_json-remove
func CloneRefOfJSONRemoveExpr ¶
func CloneRefOfJSONRemoveExpr(n *JSONRemoveExpr) *JSONRemoveExpr
CloneRefOfJSONRemoveExpr creates a deep clone of the input.
func (*JSONRemoveExpr) CachedSize ¶
func (cached *JSONRemoveExpr) CachedSize(alloc bool) int64
func (*JSONRemoveExpr) Format ¶
func (node *JSONRemoveExpr) Format(buf *TrackedBuffer)
Format formats the node.
type JSONSchemaValidFuncExpr ¶
JSONSchemaValidFuncExpr represents the structure of JSON_SCHEMA_VALID() More information available on https://dev.mysql.com/doc/refman/8.0/en/json-validation-functions.html#function_json-schema-valid
func CloneRefOfJSONSchemaValidFuncExpr ¶
func CloneRefOfJSONSchemaValidFuncExpr(n *JSONSchemaValidFuncExpr) *JSONSchemaValidFuncExpr
CloneRefOfJSONSchemaValidFuncExpr creates a deep clone of the input.
func (*JSONSchemaValidFuncExpr) CachedSize ¶
func (cached *JSONSchemaValidFuncExpr) CachedSize(alloc bool) int64
func (*JSONSchemaValidFuncExpr) Format ¶
func (node *JSONSchemaValidFuncExpr) Format(buf *TrackedBuffer)
Format formats the node.
type JSONSchemaValidationReportFuncExpr ¶
JSONSchemaValidationReportFuncExpr represents the structure of JSON_SCHEMA_VALIDATION_REPORT() More information available on https://dev.mysql.com/doc/refman/8.0/en/json-validation-functions.html#function_json-schema-validation-report
func CloneRefOfJSONSchemaValidationReportFuncExpr ¶
func CloneRefOfJSONSchemaValidationReportFuncExpr(n *JSONSchemaValidationReportFuncExpr) *JSONSchemaValidationReportFuncExpr
CloneRefOfJSONSchemaValidationReportFuncExpr creates a deep clone of the input.
func (*JSONSchemaValidationReportFuncExpr) CachedSize ¶
func (cached *JSONSchemaValidationReportFuncExpr) CachedSize(alloc bool) int64
func (*JSONSchemaValidationReportFuncExpr) Format ¶
func (node *JSONSchemaValidationReportFuncExpr) Format(buf *TrackedBuffer)
Format formats the node.
type JSONSearchExpr ¶
type JSONSearchExpr struct { JSONDoc Expr OneOrAll Expr SearchStr Expr EscapeChar Expr PathList []JSONPathParam }
JSONSearchExpr represents the function and arguments for JSON_SEARCH() For more information, see https://dev.mysql.com/doc/refman/8.0/en/json-search-functions.html#function_json-search
func CloneRefOfJSONSearchExpr ¶
func CloneRefOfJSONSearchExpr(n *JSONSearchExpr) *JSONSearchExpr
CloneRefOfJSONSearchExpr creates a deep clone of the input.
func (*JSONSearchExpr) CachedSize ¶
func (cached *JSONSearchExpr) CachedSize(alloc bool) int64
func (*JSONSearchExpr) Format ¶
func (node *JSONSearchExpr) Format(buf *TrackedBuffer)
Format formats the node
type JSONStorageFreeExpr ¶
type JSONStorageFreeExpr struct {
JSONVal Expr
}
JSONStorageFreeExpr represents the function and argument for JSON_STORAGE_FREE() https://dev.mysql.com/doc/refman/8.0/en/json-utility-functions.html#function_json-storage-free
func CloneRefOfJSONStorageFreeExpr ¶
func CloneRefOfJSONStorageFreeExpr(n *JSONStorageFreeExpr) *JSONStorageFreeExpr
CloneRefOfJSONStorageFreeExpr creates a deep clone of the input.
func (*JSONStorageFreeExpr) CachedSize ¶
func (cached *JSONStorageFreeExpr) CachedSize(alloc bool) int64
func (*JSONStorageFreeExpr) Format ¶
func (node *JSONStorageFreeExpr) Format(buf *TrackedBuffer)
Format formats the node
type JSONStorageSizeExpr ¶
type JSONStorageSizeExpr struct {
JSONVal Expr
}
JSONStorageSizeExpr represents the function and argument for JSON_STORAGE_SIZE() https://dev.mysql.com/doc/refman/8.0/en/json-utility-functions.html#function_json-storage-size
func CloneRefOfJSONStorageSizeExpr ¶
func CloneRefOfJSONStorageSizeExpr(n *JSONStorageSizeExpr) *JSONStorageSizeExpr
CloneRefOfJSONStorageSizeExpr creates a deep clone of the input.
func (*JSONStorageSizeExpr) CachedSize ¶
func (cached *JSONStorageSizeExpr) CachedSize(alloc bool) int64
func (*JSONStorageSizeExpr) Format ¶
func (node *JSONStorageSizeExpr) Format(buf *TrackedBuffer)
Format formats the node
type JSONTableExpr ¶
type JSONTableExpr struct { Expr Expr Alias TableIdent Filter Expr Columns []*JtColumnDefinition }
JSONTableExpr describes the components of JSON_TABLE() For more information, visit https://dev.mysql.com/doc/refman/8.0/en/json-table-functions.html#function_json-table
func CloneRefOfJSONTableExpr ¶
func CloneRefOfJSONTableExpr(n *JSONTableExpr) *JSONTableExpr
CloneRefOfJSONTableExpr creates a deep clone of the input.
func (*JSONTableExpr) CachedSize ¶
func (cached *JSONTableExpr) CachedSize(alloc bool) int64
func (*JSONTableExpr) Format ¶
func (node *JSONTableExpr) Format(buf *TrackedBuffer)
type JSONUnquoteExpr ¶
type JSONUnquoteExpr struct {
JSONValue Expr
}
JSONRemoveExpr represents the JSON_UNQUOTE() For more information, visit https://dev.mysql.com/doc/refman/8.0/en/json-modification-functions.html#function_json-unquote
func CloneRefOfJSONUnquoteExpr ¶
func CloneRefOfJSONUnquoteExpr(n *JSONUnquoteExpr) *JSONUnquoteExpr
CloneRefOfJSONUnquoteExpr creates a deep clone of the input.
func (*JSONUnquoteExpr) CachedSize ¶
func (cached *JSONUnquoteExpr) CachedSize(alloc bool) int64
func (*JSONUnquoteExpr) Format ¶
func (node *JSONUnquoteExpr) Format(buf *TrackedBuffer)
Format formats the node.
type JSONValueExpr ¶
type JSONValueExpr struct { JSONDoc Expr Path JSONPathParam ReturningType *ConvertType EmptyOnResponse *JtOnResponse ErrorOnResponse *JtOnResponse }
JSONValueExpr represents the function and arguments for JSON_VALUE() For more information, see https://dev.mysql.com/doc/refman/8.0/en/json-search-functions.html#function_json-value
func CloneRefOfJSONValueExpr ¶
func CloneRefOfJSONValueExpr(n *JSONValueExpr) *JSONValueExpr
CloneRefOfJSONValueExpr creates a deep clone of the input.
func (*JSONValueExpr) CachedSize ¶
func (cached *JSONValueExpr) CachedSize(alloc bool) int64
func (*JSONValueExpr) Format ¶
func (node *JSONValueExpr) Format(buf *TrackedBuffer)
Format formats the node
type JSONValueMergeExpr ¶
type JSONValueMergeExpr struct { Type JSONValueMergeType JSONDoc Expr JSONDocList Exprs }
JSONValueMergeExpr represents the json value modifier functions which merges documents. Functions falling under this class: JSON_MERGE, JSON_MERGE_PATCH, JSON_MERGE_PRESERVE
func CloneRefOfJSONValueMergeExpr ¶
func CloneRefOfJSONValueMergeExpr(n *JSONValueMergeExpr) *JSONValueMergeExpr
CloneRefOfJSONValueMergeExpr creates a deep clone of the input.
func (*JSONValueMergeExpr) CachedSize ¶
func (cached *JSONValueMergeExpr) CachedSize(alloc bool) int64
func (*JSONValueMergeExpr) Format ¶
func (node *JSONValueMergeExpr) Format(buf *TrackedBuffer)
Format formats the node.
type JSONValueMergeType ¶
type JSONValueMergeType int8
JSONValueModifierType is an enum to get types of TrimFunc. TrimFunc stand for one of the following: JSON_DEPTH JSON_TYPE JSON_VALID ENUM
const ( JSONMergeType JSONValueMergeType = iota JSONMergePatchType JSONMergePreserveType )
Constants for Enum Type - JSONValueMergeType
func (JSONValueMergeType) ToString ¶
func (ty JSONValueMergeType) ToString() string
ToString returns the type as a string
type JSONValueModifierExpr ¶
type JSONValueModifierExpr struct { Type JSONValueModifierType JSONDoc Expr Params []*JSONObjectParam }
*********** Expressions
func CloneRefOfJSONValueModifierExpr ¶
func CloneRefOfJSONValueModifierExpr(n *JSONValueModifierExpr) *JSONValueModifierExpr
CloneRefOfJSONValueModifierExpr creates a deep clone of the input.
func (*JSONValueModifierExpr) CachedSize ¶
func (cached *JSONValueModifierExpr) CachedSize(alloc bool) int64
func (*JSONValueModifierExpr) Format ¶
func (node *JSONValueModifierExpr) Format(buf *TrackedBuffer)
Format formats the node.
type JSONValueModifierType ¶
type JSONValueModifierType int8
JSONValueModifierType is an enum to get types of TrimFunc. TrimFunc stand for one of the following: JSON_DEPTH JSON_TYPE JSON_VALID ENUM
const ( JSONArrayAppendType JSONValueModifierType = iota JSONArrayInsertType JSONInsertType JSONReplaceType JSONSetType )
Constants for Enum Type - JSONValueModifierType
func (JSONValueModifierType) ToString ¶
func (ty JSONValueModifierType) ToString() string
ToString returns the type as a string
type JoinCondition ¶
JoinCondition represents the join conditions (either a ON or USING clause) of a JoinTableExpr.
func CloneRefOfJoinCondition ¶
func CloneRefOfJoinCondition(n *JoinCondition) *JoinCondition
CloneRefOfJoinCondition creates a deep clone of the input.
func (*JoinCondition) CachedSize ¶
func (cached *JoinCondition) CachedSize(alloc bool) int64
func (*JoinCondition) Format ¶
func (node *JoinCondition) Format(buf *TrackedBuffer)
Format formats the node.
type JoinTableExpr ¶
type JoinTableExpr struct { LeftExpr TableExpr Join JoinType RightExpr TableExpr Condition *JoinCondition }
JoinTableExpr represents a TableExpr that's a JOIN operation.
func CloneRefOfJoinTableExpr ¶
func CloneRefOfJoinTableExpr(n *JoinTableExpr) *JoinTableExpr
CloneRefOfJoinTableExpr creates a deep clone of the input.
func (*JoinTableExpr) CachedSize ¶
func (cached *JoinTableExpr) CachedSize(alloc bool) int64
func (*JoinTableExpr) Format ¶
func (node *JoinTableExpr) Format(buf *TrackedBuffer)
Format formats the node.
type JoinType ¶
type JoinType int8
JoinType represents the type of Join for JoinTableExpr
type JtColumnDefinition ¶
type JtColumnDefinition struct { JtOrdinal *JtOrdinalColDef JtPath *JtPathColDef JtNestedPath *JtNestedPathColDef }
JtColumnDefinition represents the structure of column definition in JSON_TABLE
func CloneRefOfJtColumnDefinition ¶
func CloneRefOfJtColumnDefinition(n *JtColumnDefinition) *JtColumnDefinition
CloneRefOfJtColumnDefinition creates a deep clone of the input.
func CloneSliceOfRefOfJtColumnDefinition ¶
func CloneSliceOfRefOfJtColumnDefinition(n []*JtColumnDefinition) []*JtColumnDefinition
CloneSliceOfRefOfJtColumnDefinition creates a deep clone of the input.
func (*JtColumnDefinition) CachedSize ¶
func (cached *JtColumnDefinition) CachedSize(alloc bool) int64
func (*JtColumnDefinition) Format ¶
func (node *JtColumnDefinition) Format(buf *TrackedBuffer)
type JtNestedPathColDef ¶
type JtNestedPathColDef struct { Path Expr Columns []*JtColumnDefinition }
JtNestedPathColDef is type of column definition with nested column definitions
func CloneRefOfJtNestedPathColDef ¶
func CloneRefOfJtNestedPathColDef(n *JtNestedPathColDef) *JtNestedPathColDef
CloneRefOfJtNestedPathColDef creates a deep clone of the input.
func (*JtNestedPathColDef) CachedSize ¶
func (cached *JtNestedPathColDef) CachedSize(alloc bool) int64
type JtOnResponse ¶
type JtOnResponse struct { ResponseType JtOnResponseType Expr Expr }
JtOnResponse specifies for a column the JtOnResponseType along with the expression for default and error
func CloneRefOfJtOnResponse ¶
func CloneRefOfJtOnResponse(n *JtOnResponse) *JtOnResponse
CloneRefOfJtOnResponse creates a deep clone of the input.
func (*JtOnResponse) CachedSize ¶
func (cached *JtOnResponse) CachedSize(alloc bool) int64
func (*JtOnResponse) Format ¶
func (node *JtOnResponse) Format(buf *TrackedBuffer)
type JtOnResponseType ¶
type JtOnResponseType int
JtOnResponseType describes the type of column: default, error or null
const ( ErrorJSONType JtOnResponseType = iota NullJSONType DefaultJSONType )
Constant for Enum Type - JtOnResponseType
type JtOrdinalColDef ¶
type JtOrdinalColDef struct {
Name ColIdent
}
JtOrdinalColDef is a type of column definition similar to using AUTO_INCREMENT with a column
func CloneRefOfJtOrdinalColDef ¶
func CloneRefOfJtOrdinalColDef(n *JtOrdinalColDef) *JtOrdinalColDef
CloneRefOfJtOrdinalColDef creates a deep clone of the input.
func (*JtOrdinalColDef) CachedSize ¶
func (cached *JtOrdinalColDef) CachedSize(alloc bool) int64
type JtPathColDef ¶
type JtPathColDef struct { Name ColIdent Type ColumnType JtColExists bool Path Expr EmptyOnResponse *JtOnResponse ErrorOnResponse *JtOnResponse }
JtPathColDef is a type of column definition specifying the path in JSON structure to extract values
func CloneRefOfJtPathColDef ¶
func CloneRefOfJtPathColDef(n *JtPathColDef) *JtPathColDef
CloneRefOfJtPathColDef creates a deep clone of the input.
func (*JtPathColDef) CachedSize ¶
func (cached *JtPathColDef) CachedSize(alloc bool) int64
type KeyState ¶
type KeyState struct {
Enable bool
}
KeyState is used to disable or enable the keys in an alter table statement
func CloneRefOfKeyState ¶
CloneRefOfKeyState creates a deep clone of the input.
func (*KeyState) CachedSize ¶
type LengthScaleOption ¶
LengthScaleOption is used for types that have an optional length and scale
type Limit ¶
type Limit struct {
Offset, Rowcount Expr
}
Limit represents a LIMIT clause.
func CloneRefOfLimit ¶
CloneRefOfLimit creates a deep clone of the input.
func (*Limit) CachedSize ¶
type Literal ¶
Literal represents a fixed value.
func CloneRefOfLiteral ¶
CloneRefOfLiteral creates a deep clone of the input.
func NewBitLiteral ¶
NewBitLiteral builds a new BitVal containing a bit literal.
func NewDecimalLiteral ¶
func NewFloatLiteral ¶
NewFloatLiteral builds a new FloatVal.
func NewHexNumLiteral ¶
NewHexNumLiteral builds a new HexNum.
func (*Literal) CachedSize ¶
type Load ¶
type Load struct { }
Load represents a LOAD statement
func CloneRefOfLoad ¶
CloneRefOfLoad creates a deep clone of the input.
type LockOption ¶
type LockOption struct {
Type LockOptionType
}
LockOption is used to specify the type of lock to use in an alter table statement
func CloneRefOfLockOption ¶
func CloneRefOfLockOption(n *LockOption) *LockOption
CloneRefOfLockOption creates a deep clone of the input.
func (*LockOption) CachedSize ¶
func (cached *LockOption) CachedSize(alloc bool) int64
func (*LockOption) Format ¶
func (node *LockOption) Format(buf *TrackedBuffer)
Format formats the node
type LockOptionType ¶
type LockOptionType int8
LockOptionType is an enum for LockOption.Type
const ( DefaultType LockOptionType = iota NoneType ExclusiveType )
LockOptionType constants
func (LockOptionType) ToString ¶
func (lock LockOptionType) ToString() string
ToString returns the LockOptionType as a string
type LockTables ¶
type LockTables struct {
Tables TableAndLockTypes
}
LockTables represents the lock statement
func CloneRefOfLockTables ¶
func CloneRefOfLockTables(n *LockTables) *LockTables
CloneRefOfLockTables creates a deep clone of the input.
func (*LockTables) CachedSize ¶
func (cached *LockTables) CachedSize(alloc bool) int64
func (*LockTables) Format ¶
func (node *LockTables) Format(buf *TrackedBuffer)
Format formats the LockTables node.
type MarginComments ¶
MarginComments holds the leading and trailing comments that surround a query.
func SplitMarginComments ¶
func SplitMarginComments(sql string) (query string, comments MarginComments)
SplitMarginComments pulls out any leading or trailing comments from a raw sql query. This function also trims leading (if there's a comment) and trailing whitespace.
type MatchAction ¶
type MatchAction int
MatchAction indicates the type of match for a referential constraint, so a `MATCH FULL`, `MATCH SIMPLE` or `MATCH PARTIAL`.
const ( // DefaultAction indicates no action was explicitly specified. DefaultMatch MatchAction = iota Full Partial Simple )
func (MatchAction) Format ¶
func (a MatchAction) Format(buf *TrackedBuffer)
Format formats the node.
type MatchExpr ¶
type MatchExpr struct { Columns SelectExprs Expr Expr Option MatchExprOption }
MatchExpr represents a call to the MATCH function
func CloneRefOfMatchExpr ¶
CloneRefOfMatchExpr creates a deep clone of the input.
func (*MatchExpr) CachedSize ¶
func (*MatchExpr) Format ¶
func (node *MatchExpr) Format(buf *TrackedBuffer)
Format formats the node
type MatchExprOption ¶
type MatchExprOption int8
MatchExprOption is an enum for MatchExpr.Option
const ( NoOption MatchExprOption = iota BooleanModeOpt NaturalLanguageModeOpt NaturalLanguageModeWithQueryExpansionOpt QueryExpansionOpt )
Constant for Enum Type - MatchExprOption
func (MatchExprOption) ToString ¶
func (option MatchExprOption) ToString() string
ToString returns the option as a string
type MemberOfExpr ¶
MemberOf represents the function and arguments for MEMBER OF() For more information, see https://dev.mysql.com/doc/refman/8.0/en/json-search-functions.html#operator_member-of
func CloneRefOfMemberOfExpr ¶
func CloneRefOfMemberOfExpr(n *MemberOfExpr) *MemberOfExpr
CloneRefOfMemberOfExpr creates a deep clone of the input.
func (*MemberOfExpr) CachedSize ¶
func (cached *MemberOfExpr) CachedSize(alloc bool) int64
func (*MemberOfExpr) Format ¶
func (node *MemberOfExpr) Format(buf *TrackedBuffer)
Format formats the node
type ModifyColumn ¶
type ModifyColumn struct { NewColDefinition *ColumnDefinition First bool After *ColName }
ModifyColumn is used to change the column definition in alter table command
func CloneRefOfModifyColumn ¶
func CloneRefOfModifyColumn(n *ModifyColumn) *ModifyColumn
CloneRefOfModifyColumn creates a deep clone of the input.
func (*ModifyColumn) CachedSize ¶
func (cached *ModifyColumn) CachedSize(alloc bool) int64
func (*ModifyColumn) Format ¶
func (node *ModifyColumn) Format(buf *TrackedBuffer)
Format formats the node
type Nextval ¶
type Nextval struct {
Expr Expr
}
Nextval defines the NEXT VALUE expression.
func CloneRefOfNextval ¶
CloneRefOfNextval creates a deep clone of the input.
func (*Nextval) CachedSize ¶
type NodeFormatter ¶
type NodeFormatter func(buf *TrackedBuffer, node SQLNode)
NodeFormatter defines the signature of a custom node formatter function that can be given to TrackedBuffer for code generation.
type NotExpr ¶
type NotExpr struct {
Expr Expr
}
NotExpr represents a NOT expression.
func CloneRefOfNotExpr ¶
CloneRefOfNotExpr creates a deep clone of the input.
func (*NotExpr) CachedSize ¶
type NullVal ¶
type NullVal struct{}
NullVal represents a NULL value.
func CloneRefOfNullVal ¶
CloneRefOfNullVal creates a deep clone of the input.
type Offset ¶
type Offset int
Offset is another AST type that is used during planning and never produced by the parser
type OptLike ¶
type OptLike struct {
LikeTable TableName
}
OptLike works for create table xxx like xxx
func CloneRefOfOptLike ¶
CloneRefOfOptLike creates a deep clone of the input.
func (*OptLike) CachedSize ¶
type OrExpr ¶
type OrExpr struct {
Left, Right Expr
}
OrExpr represents an OR expression.
func CloneRefOfOrExpr ¶
CloneRefOfOrExpr creates a deep clone of the input.
func (*OrExpr) CachedSize ¶
type Order ¶
type Order struct { Expr Expr Direction OrderDirection }
Order represents an ordering expression.
func CloneRefOfOrder ¶
CloneRefOfOrder creates a deep clone of the input.
func (*Order) CachedSize ¶
type OrderBy ¶
type OrderBy []*Order
OrderBy represents an ORDER By clause.
func CloneOrderBy ¶
CloneOrderBy creates a deep clone of the input.
type OrderByOption ¶
type OrderByOption struct {
Cols Columns
}
OrderByOption clause is used to specify the order by in an alter table statement
func CloneRefOfOrderByOption ¶
func CloneRefOfOrderByOption(n *OrderByOption) *OrderByOption
CloneRefOfOrderByOption creates a deep clone of the input.
func (*OrderByOption) CachedSize ¶
func (cached *OrderByOption) CachedSize(alloc bool) int64
func (*OrderByOption) Format ¶
func (node *OrderByOption) Format(buf *TrackedBuffer)
Format formats the node
type OrderDirection ¶
type OrderDirection int8
OrderDirection is an enum for the direction in which to order - asc or desc.
const ( AscOrder OrderDirection = iota DescOrder )
Constant for Enum Type - OrderDirection
func (OrderDirection) ToString ¶
func (dir OrderDirection) ToString() string
ToString returns the direction as a string
type OtherAdmin ¶
type OtherAdmin struct{}
OtherAdmin represents a misc statement that relies on ADMIN privileges, such as REPAIR, OPTIMIZE, or TRUNCATE statement. It should be used only as an indicator. It does not contain the full AST for the statement.
func CloneRefOfOtherAdmin ¶
func CloneRefOfOtherAdmin(n *OtherAdmin) *OtherAdmin
CloneRefOfOtherAdmin creates a deep clone of the input.
func (*OtherAdmin) Format ¶
func (node *OtherAdmin) Format(buf *TrackedBuffer)
Format formats the node.
type OtherRead ¶
type OtherRead struct{}
OtherRead represents a DESCRIBE, or EXPLAIN statement. It should be used only as an indicator. It does not contain the full AST for the statement.
func CloneRefOfOtherRead ¶
CloneRefOfOtherRead creates a deep clone of the input.
func (*OtherRead) Format ¶
func (node *OtherRead) Format(buf *TrackedBuffer)
Format formats the node.
type ParenTableExpr ¶
type ParenTableExpr struct {
Exprs TableExprs
}
ParenTableExpr represents a parenthesized list of TableExpr.
func CloneRefOfParenTableExpr ¶
func CloneRefOfParenTableExpr(n *ParenTableExpr) *ParenTableExpr
CloneRefOfParenTableExpr creates a deep clone of the input.
func (*ParenTableExpr) CachedSize ¶
func (cached *ParenTableExpr) CachedSize(alloc bool) int64
func (*ParenTableExpr) Format ¶
func (node *ParenTableExpr) Format(buf *TrackedBuffer)
Format formats the node.
type ParsedComments ¶
type ParsedComments struct {
// contains filtered or unexported fields
}
func CloneRefOfParsedComments ¶
func CloneRefOfParsedComments(n *ParsedComments) *ParsedComments
CloneRefOfParsedComments creates a deep clone of the input.
func (*ParsedComments) AddQueryHint ¶
func (node *ParsedComments) AddQueryHint(queryHint string) (Comments, error)
AddQueryHint adds the given string to list of comment. If the list is empty, one will be created containing the query hint. If the list already contains a query hint, the given string will be merged with the existing one. This is done because only one query hint is allowed per query.
func (*ParsedComments) CachedSize ¶
func (cached *ParsedComments) CachedSize(alloc bool) int64
func (*ParsedComments) Directives ¶
func (c *ParsedComments) Directives() CommentDirectives
Directives parses the comment list for any execution directives of the form:
/*vt+ OPTION_ONE=1 OPTION_TWO OPTION_THREE=abcd */
It returns the map of the directive values or nil if there aren't any.
func (*ParsedComments) Format ¶
func (node *ParsedComments) Format(buf *TrackedBuffer)
Format formats the node.
func (*ParsedComments) Length ¶
func (c *ParsedComments) Length() int
func (*ParsedComments) Prepend ¶
func (c *ParsedComments) Prepend(comment string) Comments
type PartitionByType ¶
type PartitionByType int8
PartitionByType is an enum storing how we are partitioning a table
const ( HashType PartitionByType = iota KeyType RangeType ListType )
Constant for Enum Type - PartitionByType
func (PartitionByType) ToString ¶
func (partitionType PartitionByType) ToString() string
ToString returns the partition type as a string
type PartitionDefinition ¶
type PartitionDefinition struct { Name ColIdent Options *PartitionDefinitionOptions }
PartitionDefinition describes a very minimal partition definition
func CloneRefOfPartitionDefinition ¶
func CloneRefOfPartitionDefinition(n *PartitionDefinition) *PartitionDefinition
CloneRefOfPartitionDefinition creates a deep clone of the input.
func CloneSliceOfRefOfPartitionDefinition ¶
func CloneSliceOfRefOfPartitionDefinition(n []*PartitionDefinition) []*PartitionDefinition
CloneSliceOfRefOfPartitionDefinition creates a deep clone of the input.
func (*PartitionDefinition) CachedSize ¶
func (cached *PartitionDefinition) CachedSize(alloc bool) int64
func (*PartitionDefinition) Format ¶
func (node *PartitionDefinition) Format(buf *TrackedBuffer)
Format formats the node
type PartitionDefinitionOptions ¶
type PartitionDefinitionOptions struct { ValueRange *PartitionValueRange Comment *Literal Engine *PartitionEngine DataDirectory *Literal IndexDirectory *Literal MaxRows *int MinRows *int TableSpace string SubPartitionDefinitions SubPartitionDefinitions }
func CloneRefOfPartitionDefinitionOptions ¶
func CloneRefOfPartitionDefinitionOptions(n *PartitionDefinitionOptions) *PartitionDefinitionOptions
CloneRefOfPartitionDefinitionOptions creates a deep clone of the input.
func (*PartitionDefinitionOptions) CachedSize ¶
func (cached *PartitionDefinitionOptions) CachedSize(alloc bool) int64
func (*PartitionDefinitionOptions) Format ¶
func (node *PartitionDefinitionOptions) Format(buf *TrackedBuffer)
Format formats the node
type PartitionEngine ¶
func CloneRefOfPartitionEngine ¶
func CloneRefOfPartitionEngine(n *PartitionEngine) *PartitionEngine
CloneRefOfPartitionEngine creates a deep clone of the input.
func (*PartitionEngine) CachedSize ¶
func (cached *PartitionEngine) CachedSize(alloc bool) int64
func (*PartitionEngine) Format ¶
func (node *PartitionEngine) Format(buf *TrackedBuffer)
Format formats the node
type PartitionOption ¶
type PartitionOption struct { Type PartitionByType IsLinear bool KeyAlgorithm int ColList Columns Expr Expr Partitions int SubPartition *SubPartition Definitions []*PartitionDefinition }
PartitionOption describes partitioning control (for create table statements)
func CloneRefOfPartitionOption ¶
func CloneRefOfPartitionOption(n *PartitionOption) *PartitionOption
CloneRefOfPartitionOption creates a deep clone of the input.
func (*PartitionOption) CachedSize ¶
func (cached *PartitionOption) CachedSize(alloc bool) int64
func (*PartitionOption) Format ¶
func (node *PartitionOption) Format(buf *TrackedBuffer)
Format formats the node.
type PartitionSpec ¶
type PartitionSpec struct { Action PartitionSpecAction Names Partitions Number *Literal IsAll bool TableName TableName WithoutValidation bool Definitions []*PartitionDefinition }
PartitionSpec describe partition actions (for alter statements)
func CloneRefOfPartitionSpec ¶
func CloneRefOfPartitionSpec(n *PartitionSpec) *PartitionSpec
CloneRefOfPartitionSpec creates a deep clone of the input.
func (*PartitionSpec) CachedSize ¶
func (cached *PartitionSpec) CachedSize(alloc bool) int64
func (*PartitionSpec) Format ¶
func (node *PartitionSpec) Format(buf *TrackedBuffer)
Format formats the node.
type PartitionSpecAction ¶
type PartitionSpecAction int8
PartitionSpecAction is an enum for PartitionSpec.Action
const ( ReorganizeAction PartitionSpecAction = iota AddAction DiscardAction DropAction ImportAction TruncateAction CoalesceAction ExchangeAction AnalyzeAction CheckAction OptimizeAction RebuildAction RepairAction RemoveAction UpgradeAction )
Constant for Enum Type - PartitionSpecAction
type PartitionValueRange ¶
type PartitionValueRange struct { Type PartitionValueRangeType Range ValTuple Maxvalue bool }
func CloneRefOfPartitionValueRange ¶
func CloneRefOfPartitionValueRange(n *PartitionValueRange) *PartitionValueRange
CloneRefOfPartitionValueRange creates a deep clone of the input.
func (*PartitionValueRange) CachedSize ¶
func (cached *PartitionValueRange) CachedSize(alloc bool) int64
func (*PartitionValueRange) Format ¶
func (node *PartitionValueRange) Format(buf *TrackedBuffer)
Format formats the node
type PartitionValueRangeType ¶
type PartitionValueRangeType int8
PartitionValueRangeType is an enum for PartitionValueRange.Type
const ( LessThanType PartitionValueRangeType = iota InType )
Constant for Enum Type - PartitionValueRangeType
func (PartitionValueRangeType) ToString ¶
func (t PartitionValueRangeType) ToString() string
ToString returns the partition value range type as a string
type Partitions ¶
type Partitions Columns
Partitions is a type alias for Columns so we can handle printing efficiently
func ClonePartitions ¶
func ClonePartitions(n Partitions) Partitions
ClonePartitions creates a deep clone of the input.
func (Partitions) Format ¶
func (node Partitions) Format(buf *TrackedBuffer)
Format formats the node
type PositionedErr ¶
PositionedErr holds context related to parser errors
func (PositionedErr) Error ¶
func (p PositionedErr) Error() string
type Precendence ¶
type Precendence int
Precendence is used to know the precedence between operators, so we can introduce parens when needed in the String representation of the AST
const ( Syntactic Precendence = iota P1 P2 P3 P4 P5 P6 P7 P8 P9 P10 P11 P12 P13 P14 P15 P16 P17 )
type PrepareStmt ¶
type PrepareStmt struct { Name ColIdent Statement Expr Comments *ParsedComments }
PrepareStmt represents a Prepare Statement More info available on https://dev.mysql.com/doc/refman/8.0/en/sql-prepared-statements.html
func CloneRefOfPrepareStmt ¶
func CloneRefOfPrepareStmt(n *PrepareStmt) *PrepareStmt
CloneRefOfPrepareStmt creates a deep clone of the input.
func (*PrepareStmt) CachedSize ¶
func (cached *PrepareStmt) CachedSize(alloc bool) int64
func (*PrepareStmt) Format ¶
func (node *PrepareStmt) Format(buf *TrackedBuffer)
Format formats the node.
type RangeCondOperator ¶
type RangeCondOperator int8
RangeCondOperator is an enum for RangeCond.Operator
type ReferenceAction ¶
type ReferenceAction int
ReferenceAction indicates the action takes by a referential constraint e.g. the `CASCADE` in a `FOREIGN KEY .. ON DELETE CASCADE` table definition.
const ( // DefaultAction indicates no action was explicitly specified. DefaultAction ReferenceAction = iota Restrict Cascade NoAction SetNull SetDefault )
These map to the SQL-defined reference actions. See https://dev.mysql.com/doc/refman/8.0/en/create-table-foreign-keys.html#foreign-keys-referential-actions
func (ReferenceAction) Format ¶
func (a ReferenceAction) Format(buf *TrackedBuffer)
Format formats the node.
type ReferenceDefinition ¶
type ReferenceDefinition struct { ReferencedTable TableName ReferencedColumns Columns Match MatchAction OnDelete ReferenceAction OnUpdate ReferenceAction }
ReferenceDefinition describes the referenced tables and columns that the foreign key references
func CloneRefOfReferenceDefinition ¶
func CloneRefOfReferenceDefinition(n *ReferenceDefinition) *ReferenceDefinition
CloneRefOfReferenceDefinition creates a deep clone of the input.
func (*ReferenceDefinition) CachedSize ¶
func (cached *ReferenceDefinition) CachedSize(alloc bool) int64
func (*ReferenceDefinition) Format ¶
func (ref *ReferenceDefinition) Format(buf *TrackedBuffer)
Format formats the node.
type Release ¶
type Release struct {
Name ColIdent
}
Release represents a release savepoint statement.
func CloneRefOfRelease ¶
CloneRefOfRelease creates a deep clone of the input.
func (*Release) CachedSize ¶
type RenameIndex ¶
RenameIndex clause is used to rename indexes in an alter table statement
func CloneRefOfRenameIndex ¶
func CloneRefOfRenameIndex(n *RenameIndex) *RenameIndex
CloneRefOfRenameIndex creates a deep clone of the input.
func (*RenameIndex) CachedSize ¶
func (cached *RenameIndex) CachedSize(alloc bool) int64
func (*RenameIndex) Format ¶
func (node *RenameIndex) Format(buf *TrackedBuffer)
Format formats the node
type RenameTable ¶
type RenameTable struct {
TablePairs []*RenameTablePair
}
RenameTable represents a RENAME TABLE statement.
func CloneRefOfRenameTable ¶
func CloneRefOfRenameTable(n *RenameTable) *RenameTable
CloneRefOfRenameTable creates a deep clone of the input.
func (*RenameTable) AffectedTables ¶
func (node *RenameTable) AffectedTables() TableNames
AffectedTables returns the list table names affected by the DDLStatement.
func (*RenameTable) CachedSize ¶
func (cached *RenameTable) CachedSize(alloc bool) int64
func (*RenameTable) Format ¶
func (node *RenameTable) Format(buf *TrackedBuffer)
Format formats the node.
func (*RenameTable) GetAction ¶
func (node *RenameTable) GetAction() DDLAction
GetAction implements the DDLStatement interface
func (*RenameTable) GetFromTables ¶
func (node *RenameTable) GetFromTables() TableNames
GetFromTables implements the DDLStatement interface
func (*RenameTable) GetIfExists ¶
func (node *RenameTable) GetIfExists() bool
GetIfExists implements the DDLStatement interface
func (*RenameTable) GetIfNotExists ¶
func (node *RenameTable) GetIfNotExists() bool
GetIfNotExists implements the DDLStatement interface
func (*RenameTable) GetIsReplace ¶
func (node *RenameTable) GetIsReplace() bool
GetIsReplace implements the DDLStatement interface
func (*RenameTable) GetOptLike ¶
func (node *RenameTable) GetOptLike() *OptLike
GetOptLike implements the DDLStatement interface
func (*RenameTable) GetParsedComments ¶
func (node *RenameTable) GetParsedComments() *ParsedComments
GetParsedComments implements DDLStatement.
func (*RenameTable) GetTable ¶
func (node *RenameTable) GetTable() TableName
GetTable implements the DDLStatement interface
func (*RenameTable) GetTableSpec ¶
func (node *RenameTable) GetTableSpec() *TableSpec
GetTableSpec implements the DDLStatement interface
func (*RenameTable) GetToTables ¶
func (node *RenameTable) GetToTables() TableNames
GetToTables implements the DDLStatement interface
func (*RenameTable) IsFullyParsed ¶
func (*RenameTable) IsFullyParsed() bool
IsFullyParsed implements the DDLStatement interface
func (*RenameTable) IsTemporary ¶
func (*RenameTable) IsTemporary() bool
IsTemporary implements the DDLStatement interface
func (*RenameTable) SetComments ¶
func (node *RenameTable) SetComments(comments Comments)
SetComments implements DDLStatement.
func (*RenameTable) SetFromTables ¶
func (node *RenameTable) SetFromTables(tables TableNames)
SetFromTables implements DDLStatement.
func (*RenameTable) SetFullyParsed ¶
func (node *RenameTable) SetFullyParsed(fullyParsed bool)
SetFullyParsed implements the DDLStatement interface
func (*RenameTable) SetTable ¶
func (node *RenameTable) SetTable(qualifier string, name string)
SetTable implements DDLStatement.
type RenameTableName ¶
type RenameTableName struct {
Table TableName
}
RenameTableName clause is used to rename the table in an alter table statement
func CloneRefOfRenameTableName ¶
func CloneRefOfRenameTableName(n *RenameTableName) *RenameTableName
CloneRefOfRenameTableName creates a deep clone of the input.
func (*RenameTableName) CachedSize ¶
func (cached *RenameTableName) CachedSize(alloc bool) int64
func (*RenameTableName) Format ¶
func (node *RenameTableName) Format(buf *TrackedBuffer)
Format formats the node
type RenameTablePair ¶
RenameTablePair represents the name of the original table and what it is going to be set in a RENAME TABLE statement.
func CloneRefOfRenameTablePair ¶
func CloneRefOfRenameTablePair(n *RenameTablePair) *RenameTablePair
CloneRefOfRenameTablePair creates a deep clone of the input.
func CloneSliceOfRefOfRenameTablePair ¶
func CloneSliceOfRefOfRenameTablePair(n []*RenameTablePair) []*RenameTablePair
CloneSliceOfRefOfRenameTablePair creates a deep clone of the input.
func (*RenameTablePair) CachedSize ¶
func (cached *RenameTablePair) CachedSize(alloc bool) int64
type RevertMigration ¶
type RevertMigration struct { UUID string Comments *ParsedComments }
RevertMigration represents a REVERT VITESS_MIGRATION statement
func CloneRefOfRevertMigration ¶
func CloneRefOfRevertMigration(n *RevertMigration) *RevertMigration
CloneRefOfRevertMigration creates a deep clone of the input.
func (*RevertMigration) CachedSize ¶
func (cached *RevertMigration) CachedSize(alloc bool) int64
func (*RevertMigration) Format ¶
func (node *RevertMigration) Format(buf *TrackedBuffer)
Format formats the node.
func (*RevertMigration) SetComments ¶
func (node *RevertMigration) SetComments(comments Comments)
SetComments for RevertMigration, does not implement DDLStatement
type Rollback ¶
type Rollback struct{}
Rollback represents a Rollback statement.
func CloneRefOfRollback ¶
CloneRefOfRollback creates a deep clone of the input.
type RootNode ¶
type RootNode struct {
SQLNode
}
RootNode is the root node of the AST when rewriting. It is the first element of the tree.
func CloneRefOfRootNode ¶
CloneRefOfRootNode creates a deep clone of the input.
func CloneRootNode ¶
CloneRootNode creates a deep clone of the input.
func (*RootNode) CachedSize ¶
type SQLNode ¶
type SQLNode interface { Format(buf *TrackedBuffer) // contains filtered or unexported methods }
SQLNode defines the interface for all nodes generated by the parser.
func CloneSQLNode ¶
CloneSQLNode creates a deep clone of the input.
func RemoveKeyspace ¶
RemoveKeyspace removes the Qualifier.Qualifier on all ColNames in the AST
func Rewrite ¶
Rewrite traverses a syntax tree recursively, starting with root, and calling pre and post for each node as described below. Rewrite returns the syntax tree, possibly modified.
If pre is not nil, it is called for each node before the node's children are traversed (pre-order). If pre returns false, no children are traversed, and post is not called for that node.
If post is not nil, and a prior call of pre didn't return false, post is called for each node after its children are traversed (post-order). If post returns false, traversal is terminated and Apply returns immediately.
Only fields that refer to AST nodes are considered children; i.e., fields of basic types (strings, []byte, etc.) are ignored.
type SRollback ¶
type SRollback struct {
Name ColIdent
}
SRollback represents a rollback to savepoint statement.
func CloneRefOfSRollback ¶
CloneRefOfSRollback creates a deep clone of the input.
func (*SRollback) CachedSize ¶
func (*SRollback) Format ¶
func (node *SRollback) Format(buf *TrackedBuffer)
Format formats the node.
type Savepoint ¶
type Savepoint struct {
Name ColIdent
}
Savepoint represents a savepoint statement.
func CloneRefOfSavepoint ¶
CloneRefOfSavepoint creates a deep clone of the input.
func (*Savepoint) CachedSize ¶
func (*Savepoint) Format ¶
func (node *Savepoint) Format(buf *TrackedBuffer)
Format formats the node.
type Scope ¶
type Scope int8
Scope is an enum for scope of query
type Select ¶
type Select struct { Cache *bool // a reference here so it can be nil Distinct bool StraightJoinHint bool SQLCalcFoundRows bool // The From field must be the first AST element of this struct so the rewriter sees it first From []TableExpr Comments *ParsedComments SelectExprs SelectExprs Where *Where With *With GroupBy GroupBy Having *Where OrderBy OrderBy Limit *Limit Lock Lock Into *SelectInto }
Select represents a SELECT statement.
func CloneRefOfSelect ¶
CloneRefOfSelect creates a deep clone of the input.
func GetAllSelects ¶
func GetAllSelects(selStmt SelectStatement) []*Select
GetAllSelects gets all the select statement s
func GetFirstSelect ¶
func GetFirstSelect(selStmt SelectStatement) *Select
GetFirstSelect gets the first select statement
func NewSelect ¶
func NewSelect(comments Comments, exprs SelectExprs, selectOptions []string, into *SelectInto, from TableExprs, where *Where, groupBy GroupBy, having *Where) *Select
NewSelect is used to create a select statement
func (*Select) AddGroupBy ¶
AddGroupBy adds a grouping expression, unless it's already present
func (*Select) AddHaving ¶
AddHaving adds the boolean expression to the HAVING clause as an AND condition.
func (*Select) AddWhere ¶
AddWhere adds the boolean expression to the WHERE clause as an AND condition.
func (*Select) CachedSize ¶
func (*Select) GetColumnCount ¶
GetColumnCount return SelectExprs count.
func (*Select) GetOrderBy ¶
GetOrderBy gets the order by clause
func (*Select) GetParsedComments ¶
func (node *Select) GetParsedComments() *ParsedComments
GetComments implements the SelectStatement interface
func (*Select) MakeDistinct ¶
func (node *Select) MakeDistinct()
MakeDistinct makes the statement distinct
func (*Select) SetComments ¶
SetComments implements the SelectStatement interface
func (*Select) SetOrderBy ¶
SetOrderBy sets the order by clause
type SelectExpr ¶
type SelectExpr interface { SQLNode // contains filtered or unexported methods }
SelectExpr represents a SELECT expression.
func CloneSelectExpr ¶
func CloneSelectExpr(in SelectExpr) SelectExpr
CloneSelectExpr creates a deep clone of the input.
type SelectExprs ¶
type SelectExprs []SelectExpr
SelectExprs represents SELECT expressions.
func CloneSelectExprs ¶
func CloneSelectExprs(n SelectExprs) SelectExprs
CloneSelectExprs creates a deep clone of the input.
func (SelectExprs) Format ¶
func (node SelectExprs) Format(buf *TrackedBuffer)
Format formats the node.
type SelectInto ¶
type SelectInto struct { Type SelectIntoType FileName string Charset ColumnCharset FormatOption string ExportOption string Manifest string Overwrite string }
SelectInto is a struct that represent the INTO part of a select query
func CloneRefOfSelectInto ¶
func CloneRefOfSelectInto(n *SelectInto) *SelectInto
CloneRefOfSelectInto creates a deep clone of the input.
func (*SelectInto) CachedSize ¶
func (cached *SelectInto) CachedSize(alloc bool) int64
func (*SelectInto) Format ¶
func (node *SelectInto) Format(buf *TrackedBuffer)
Format formats the node.
type SelectIntoType ¶
type SelectIntoType int8
SelectIntoType is an enum for SelectInto.Type
const ( IntoOutfile SelectIntoType = iota IntoOutfileS3 IntoDumpfile )
Constant for Enum Type - SelectIntoType
func (SelectIntoType) ToString ¶
func (sel SelectIntoType) ToString() string
ToString returns the type as a string
type SelectStatement ¶
type SelectStatement interface { Statement InsertRows AddOrder(*Order) SetOrderBy(OrderBy) GetOrderBy() OrderBy SetLimit(*Limit) SetLock(lock Lock) SetInto(into *SelectInto) SetWith(with *With) MakeDistinct() GetColumnCount() int Commented // contains filtered or unexported methods }
SelectStatement any SELECT statement.
func CloneSelectStatement ¶
func CloneSelectStatement(in SelectStatement) SelectStatement
CloneSelectStatement creates a deep clone of the input.
type Set ¶
type Set struct { Comments *ParsedComments Exprs SetExprs }
Set represents a SET statement.
func CloneRefOfSet ¶
CloneRefOfSet creates a deep clone of the input.
func (*Set) CachedSize ¶
type SetExpr ¶
SetExpr represents a set expression.
func CloneRefOfSetExpr ¶
CloneRefOfSetExpr creates a deep clone of the input.
func (*SetExpr) CachedSize ¶
type SetExprs ¶
type SetExprs []*SetExpr
SetExprs represents a list of set expressions.
func CloneSetExprs ¶
CloneSetExprs creates a deep clone of the input.
type SetTransaction ¶
type SetTransaction struct { SQLNode Comments *ParsedComments Scope Scope Characteristics []Characteristic }
SetTransaction represents a SET TRANSACTION statement.
func CloneRefOfSetTransaction ¶
func CloneRefOfSetTransaction(n *SetTransaction) *SetTransaction
CloneRefOfSetTransaction creates a deep clone of the input.
func (*SetTransaction) CachedSize ¶
func (cached *SetTransaction) CachedSize(alloc bool) int64
func (*SetTransaction) Format ¶
func (node *SetTransaction) Format(buf *TrackedBuffer)
Format formats the node.
type Show ¶
type Show struct {
Internal ShowInternal
}
Show represents a show statement.
func CloneRefOfShow ¶
CloneRefOfShow creates a deep clone of the input.
func (*Show) CachedSize ¶
type ShowBasic ¶
type ShowBasic struct { Command ShowCommandType Full bool Tbl TableName DbName TableIdent Filter *ShowFilter }
ShowBasic is of ShowInternal type, holds Simple SHOW queries with a filter.
func CloneRefOfShowBasic ¶
CloneRefOfShowBasic creates a deep clone of the input.
func (*ShowBasic) CachedSize ¶
func (*ShowBasic) Format ¶
func (node *ShowBasic) Format(buf *TrackedBuffer)
Format formats the node.
type ShowCommandType ¶
type ShowCommandType int8
ShowCommandType represents the show statement type.
const ( UnknownCommandType ShowCommandType = iota Charset Collation Column CreateDb CreateE CreateF CreateProc CreateTbl CreateTr CreateV Database Engines FunctionC Function GtidExecGlobal Index OpenTable Plugins Privilege ProcedureC Procedure StatusGlobal StatusSession Table TableStatus Trigger VariableGlobal VariableSession VGtidExecGlobal VitessMigrations VitessReplicationStatus VitessShards VitessTablets VitessTarget VitessVariables VschemaTables VschemaVindexes Warnings Keyspace )
ShowCommandType constants
func (ShowCommandType) ToString ¶
func (ty ShowCommandType) ToString() string
ToString returns ShowCommandType as a string
type ShowCreate ¶
type ShowCreate struct { Command ShowCommandType Op TableName }
ShowCreate is of ShowInternal type, holds SHOW CREATE queries.
func CloneRefOfShowCreate ¶
func CloneRefOfShowCreate(n *ShowCreate) *ShowCreate
CloneRefOfShowCreate creates a deep clone of the input.
func (*ShowCreate) CachedSize ¶
func (cached *ShowCreate) CachedSize(alloc bool) int64
func (*ShowCreate) Format ¶
func (node *ShowCreate) Format(buf *TrackedBuffer)
Format formats the node.
type ShowFilter ¶
ShowFilter is show tables filter
func CloneRefOfShowFilter ¶
func CloneRefOfShowFilter(n *ShowFilter) *ShowFilter
CloneRefOfShowFilter creates a deep clone of the input.
func (*ShowFilter) CachedSize ¶
func (cached *ShowFilter) CachedSize(alloc bool) int64
func (*ShowFilter) Format ¶
func (node *ShowFilter) Format(buf *TrackedBuffer)
Format formats the node.
type ShowInternal ¶
type ShowInternal interface { SQLNode // contains filtered or unexported methods }
ShowInternal will represent all the show statement types.
func CloneShowInternal ¶
func CloneShowInternal(in ShowInternal) ShowInternal
CloneShowInternal creates a deep clone of the input.
type ShowMigrationLogs ¶
type ShowMigrationLogs struct { UUID string Comments *ParsedComments }
ShowMigrationLogs represents a SHOW VITESS_MIGRATION '<uuid>' LOGS statement
func CloneRefOfShowMigrationLogs ¶
func CloneRefOfShowMigrationLogs(n *ShowMigrationLogs) *ShowMigrationLogs
CloneRefOfShowMigrationLogs creates a deep clone of the input.
func (*ShowMigrationLogs) CachedSize ¶
func (cached *ShowMigrationLogs) CachedSize(alloc bool) int64
func (*ShowMigrationLogs) Format ¶
func (node *ShowMigrationLogs) Format(buf *TrackedBuffer)
Format formats the node.
type ShowOther ¶
type ShowOther struct {
Command string
}
ShowOther is of ShowInternal type, holds show queries that is not handled specially.
func CloneRefOfShowOther ¶
CloneRefOfShowOther creates a deep clone of the input.
func (*ShowOther) CachedSize ¶
func (*ShowOther) Format ¶
func (node *ShowOther) Format(buf *TrackedBuffer)
Format formats the node.
type ShowTablesOpt ¶
type ShowTablesOpt struct { Full string DbName string Filter *ShowFilter }
ShowTablesOpt is show tables option
type ShowThrottledApps ¶
type ShowThrottledApps struct {
Comments Comments
}
ShowThrottledApps represents a SHOW VITESS_THROTTLED_APPS statement
func CloneRefOfShowThrottledApps ¶
func CloneRefOfShowThrottledApps(n *ShowThrottledApps) *ShowThrottledApps
CloneRefOfShowThrottledApps creates a deep clone of the input.
func (*ShowThrottledApps) CachedSize ¶
func (cached *ShowThrottledApps) CachedSize(alloc bool) int64
func (*ShowThrottledApps) Format ¶
func (node *ShowThrottledApps) Format(buf *TrackedBuffer)
Format formats the node.
type SimpleTableExpr ¶
type SimpleTableExpr interface { SQLNode // contains filtered or unexported methods }
SimpleTableExpr represents a simple table expression.
func CloneSimpleTableExpr ¶
func CloneSimpleTableExpr(in SimpleTableExpr) SimpleTableExpr
CloneSimpleTableExpr creates a deep clone of the input.
type StarExpr ¶
type StarExpr struct {
TableName TableName
}
StarExpr defines a '*' or 'table.*' expression.
func CloneRefOfStarExpr ¶
CloneRefOfStarExpr creates a deep clone of the input.
func (*StarExpr) CachedSize ¶
type Statement ¶
type Statement interface { SQLNode // contains filtered or unexported methods }
Statement represents a statement.
func CloneStatement ¶
CloneStatement creates a deep clone of the input.
func ParseNext ¶
ParseNext parses a single SQL statement from the tokenizer returning a Statement which is the AST representation of the query. The tokenizer will always read up to the end of the statement, allowing for the next call to ParseNext to parse any subsequent SQL statements. When there are no more statements to parse, a error of io.EOF is returned.
func ParseNextStrictDDL ¶
ParseNextStrictDDL is the same as ParseNext except it errors on partially parsed DDL statements.
func ParseStrictDDL ¶
ParseStrictDDL is the same as Parse except it errors on partially parsed DDL statements.
type StatementType ¶
type StatementType int
StatementType encodes the type of a SQL statement
const ( StmtSelect StatementType = iota StmtStream StmtInsert StmtReplace StmtUpdate StmtDelete StmtDDL StmtBegin StmtCommit StmtRollback StmtSet StmtShow StmtUse StmtOther StmtUnknown StmtComment StmtPriv StmtExplain StmtSavepoint StmtSRollback StmtRelease StmtVStream StmtLockTables StmtUnlockTables StmtFlush StmtCallProc StmtRevert StmtShowMigrationLogs )
These constants are used to identify the SQL statement type. Changing this list will require reviewing all calls to Preview.
func ASTToStatementType ¶
func ASTToStatementType(stmt Statement) StatementType
ASTToStatementType returns a StatementType from an AST stmt
func Preview ¶
func Preview(sql string) StatementType
Preview analyzes the beginning of the query using a simpler and faster textual comparison to identify the statement type.
func (StatementType) String ¶
func (s StatementType) String() string
type Stream ¶
type Stream struct { Comments *ParsedComments SelectExpr SelectExpr Table TableName }
Stream represents a SELECT statement.
func CloneRefOfStream ¶
CloneRefOfStream creates a deep clone of the input.
func (*Stream) CachedSize ¶
func (*Stream) GetParsedComments ¶
func (node *Stream) GetParsedComments() *ParsedComments
GetParsedComments implements Stream.
func (*Stream) SetComments ¶
SetComments for Stream
type SubPartition ¶
type SubPartition struct { Type PartitionByType IsLinear bool KeyAlgorithm int ColList Columns Expr Expr SubPartitions int }
SubPartition describes subpartitions control
func CloneRefOfSubPartition ¶
func CloneRefOfSubPartition(n *SubPartition) *SubPartition
CloneRefOfSubPartition creates a deep clone of the input.
func (*SubPartition) CachedSize ¶
func (cached *SubPartition) CachedSize(alloc bool) int64
func (*SubPartition) Format ¶
func (node *SubPartition) Format(buf *TrackedBuffer)
Format formats the node.
type SubPartitionDefinition ¶
type SubPartitionDefinition struct { Name ColIdent Options *SubPartitionDefinitionOptions }
Subpartition Definition Corresponds to the subpartition_definition option of partition_definition
func CloneRefOfSubPartitionDefinition ¶
func CloneRefOfSubPartitionDefinition(n *SubPartitionDefinition) *SubPartitionDefinition
CloneRefOfSubPartitionDefinition creates a deep clone of the input.
func (*SubPartitionDefinition) CachedSize ¶
func (cached *SubPartitionDefinition) CachedSize(alloc bool) int64
func (*SubPartitionDefinition) Format ¶
func (node *SubPartitionDefinition) Format(buf *TrackedBuffer)
Format formats the node
type SubPartitionDefinitionOptions ¶
type SubPartitionDefinitionOptions struct { Comment *Literal Engine *PartitionEngine DataDirectory *Literal IndexDirectory *Literal MaxRows *int MinRows *int TableSpace string }
Different options/attributes that can be provided to a subpartition_definition.
func CloneRefOfSubPartitionDefinitionOptions ¶
func CloneRefOfSubPartitionDefinitionOptions(n *SubPartitionDefinitionOptions) *SubPartitionDefinitionOptions
CloneRefOfSubPartitionDefinitionOptions creates a deep clone of the input.
func (*SubPartitionDefinitionOptions) CachedSize ¶
func (cached *SubPartitionDefinitionOptions) CachedSize(alloc bool) int64
func (*SubPartitionDefinitionOptions) Format ¶
func (node *SubPartitionDefinitionOptions) Format(buf *TrackedBuffer)
Format formats the node
type SubPartitionDefinitions ¶
type SubPartitionDefinitions []*SubPartitionDefinition
This is a list of SubPartitionDefinition
func CloneSubPartitionDefinitions ¶
func CloneSubPartitionDefinitions(n SubPartitionDefinitions) SubPartitionDefinitions
CloneSubPartitionDefinitions creates a deep clone of the input.
func (SubPartitionDefinitions) Format ¶
func (node SubPartitionDefinitions) Format(buf *TrackedBuffer)
Format formats the node
type Subquery ¶
type Subquery struct {
Select SelectStatement
}
Subquery represents a subquery used as an value expression.
func CloneRefOfSubquery ¶
CloneRefOfSubquery creates a deep clone of the input.
func (*Subquery) CachedSize ¶
type SubstrExpr ¶
SubstrExpr represents a calls to - SubstrExpr(expression, expression, expression) - SubstrExpr(expression, expression) - SubstrExpr(expression FROM expression) - SubstrExpr(expression FROM expression FOR expression)
func CloneRefOfSubstrExpr ¶
func CloneRefOfSubstrExpr(n *SubstrExpr) *SubstrExpr
CloneRefOfSubstrExpr creates a deep clone of the input.
func (*SubstrExpr) CachedSize ¶
func (cached *SubstrExpr) CachedSize(alloc bool) int64
func (*SubstrExpr) Format ¶
func (node *SubstrExpr) Format(buf *TrackedBuffer)
Format formats the node.
type SupportOptimizerHint ¶
type SupportOptimizerHint interface { Commented // contains filtered or unexported methods }
SupportOptimizerHint represents a statement that accepts optimizer hints.
type TableAndLockType ¶
TableAndLockType contains table and lock association
func CloneRefOfTableAndLockType ¶
func CloneRefOfTableAndLockType(n *TableAndLockType) *TableAndLockType
CloneRefOfTableAndLockType creates a deep clone of the input.
func (*TableAndLockType) CachedSize ¶
func (cached *TableAndLockType) CachedSize(alloc bool) int64
type TableAndLockTypes ¶
type TableAndLockTypes []*TableAndLockType
TableAndLockTypes is a slice of TableAndLockType
func CloneTableAndLockTypes ¶
func CloneTableAndLockTypes(n TableAndLockTypes) TableAndLockTypes
CloneTableAndLockTypes creates a deep clone of the input.
type TableExpr ¶
type TableExpr interface { SQLNode // contains filtered or unexported methods }
TableExpr represents a table expression.
func CloneSliceOfTableExpr ¶
CloneSliceOfTableExpr creates a deep clone of the input.
func CloneTableExpr ¶
CloneTableExpr creates a deep clone of the input.
type TableExprs ¶
type TableExprs []TableExpr
TableExprs represents a list of table expressions.
func CloneTableExprs ¶
func CloneTableExprs(n TableExprs) TableExprs
CloneTableExprs creates a deep clone of the input.
func (TableExprs) Format ¶
func (node TableExprs) Format(buf *TrackedBuffer)
Format formats the node.
type TableIdent ¶
type TableIdent struct {
// contains filtered or unexported fields
}
TableIdent is a case sensitive SQL identifier. It will be escaped with backquotes if necessary.
func CloneRefOfTableIdent ¶
func CloneRefOfTableIdent(n *TableIdent) *TableIdent
CloneRefOfTableIdent creates a deep clone of the input.
func CloneTableIdent ¶
func CloneTableIdent(n TableIdent) TableIdent
CloneTableIdent creates a deep clone of the input.
func GetTableName ¶
func GetTableName(node SimpleTableExpr) TableIdent
GetTableName returns the table name from the SimpleTableExpr only if it's a simple expression. Otherwise, it returns "".
func NewTableIdent ¶
func NewTableIdent(str string) TableIdent
NewTableIdent creates a new TableIdent.
func (*TableIdent) CachedSize ¶
func (cached *TableIdent) CachedSize(alloc bool) int64
func (TableIdent) CompliantName ¶
func (node TableIdent) CompliantName() string
CompliantName returns a compliant id name that can be used for a bind var.
func (TableIdent) Format ¶
func (node TableIdent) Format(buf *TrackedBuffer)
Format formats the node.
func (TableIdent) IsEmpty ¶
func (node TableIdent) IsEmpty() bool
IsEmpty returns true if TabIdent is empty.
func (TableIdent) MarshalJSON ¶
func (node TableIdent) MarshalJSON() ([]byte, error)
MarshalJSON marshals into JSON.
func (TableIdent) String ¶
func (node TableIdent) String() string
String returns the unescaped table name. It must not be used for SQL generation. Use sqlparser.String instead. The Stringer conformance is for usage in templates.
func (*TableIdent) UnmarshalJSON ¶
func (node *TableIdent) UnmarshalJSON(b []byte) error
UnmarshalJSON unmarshals from JSON.
type TableName ¶
type TableName struct {
Name, Qualifier TableIdent
}
TableName represents a table name. Qualifier, if specified, represents a database or keyspace. TableName is a value struct whose fields are case sensitive. This means two TableName vars can be compared for equality and a TableName can also be used as key in a map.
func CloneRefOfTableName ¶
CloneRefOfTableName creates a deep clone of the input.
func CloneTableName ¶
CloneTableName creates a deep clone of the input.
func TableFromStatement ¶
TableFromStatement returns the qualified table name for the query. This works only for select statements.
func (*TableName) CachedSize ¶
func (TableName) ToViewName ¶
ToViewName returns a TableName acceptable for use as a VIEW. VIEW names are always lowercase, so ToViewName lowercasese the name. Databases are case-sensitive so Qualifier is left untouched.
type TableNames ¶
type TableNames []TableName
TableNames is a list of TableName.
func CloneTableNames ¶
func CloneTableNames(n TableNames) TableNames
CloneTableNames creates a deep clone of the input.
func (TableNames) Format ¶
func (node TableNames) Format(buf *TrackedBuffer)
Format formats the node.
type TableOption ¶
type TableOption struct { Name string Value *Literal String string Tables TableNames CaseSensitive bool }
TableOption is used for create table options like AUTO_INCREMENT, INSERT_METHOD, etc
func CloneRefOfTableOption ¶
func CloneRefOfTableOption(n *TableOption) *TableOption
CloneRefOfTableOption creates a deep clone of the input.
func (*TableOption) CachedSize ¶
func (cached *TableOption) CachedSize(alloc bool) int64
type TableOptions ¶
type TableOptions []*TableOption
TableOptions specifies a list of table options
func CloneTableOptions ¶
func CloneTableOptions(n TableOptions) TableOptions
CloneTableOptions creates a deep clone of the input.
func (TableOptions) Format ¶
func (node TableOptions) Format(buf *TrackedBuffer)
Format formats the node
type TableSpec ¶
type TableSpec struct { Columns []*ColumnDefinition Indexes []*IndexDefinition Constraints []*ConstraintDefinition Options TableOptions PartitionOption *PartitionOption }
TableSpec describes the structure of a table from a CREATE TABLE statement
func CloneRefOfTableSpec ¶
CloneRefOfTableSpec creates a deep clone of the input.
func (*TableSpec) AddColumn ¶
func (ts *TableSpec) AddColumn(cd *ColumnDefinition)
AddColumn appends the given column to the list in the spec
func (*TableSpec) AddConstraint ¶
func (ts *TableSpec) AddConstraint(cd *ConstraintDefinition)
AddConstraint appends the given index to the list in the spec
func (*TableSpec) AddIndex ¶
func (ts *TableSpec) AddIndex(id *IndexDefinition)
AddIndex appends the given index to the list in the spec
func (*TableSpec) CachedSize ¶
type TablespaceOperation ¶
type TablespaceOperation struct {
Import bool
}
TablespaceOperation is used to discard or import the tablespace in an alter table statement
func CloneRefOfTablespaceOperation ¶
func CloneRefOfTablespaceOperation(n *TablespaceOperation) *TablespaceOperation
CloneRefOfTablespaceOperation creates a deep clone of the input.
func (*TablespaceOperation) CachedSize ¶
func (cached *TablespaceOperation) CachedSize(alloc bool) int64
func (*TablespaceOperation) Format ¶
func (node *TablespaceOperation) Format(buf *TrackedBuffer)
Format formats the node
type TimestampFuncExpr ¶
TimestampFuncExpr represents the function and arguments for TIMESTAMP{ADD,DIFF} functions.
func CloneRefOfTimestampFuncExpr ¶
func CloneRefOfTimestampFuncExpr(n *TimestampFuncExpr) *TimestampFuncExpr
CloneRefOfTimestampFuncExpr creates a deep clone of the input.
func (*TimestampFuncExpr) CachedSize ¶
func (cached *TimestampFuncExpr) CachedSize(alloc bool) int64
func (*TimestampFuncExpr) Format ¶
func (node *TimestampFuncExpr) Format(buf *TrackedBuffer)
Format formats the node.
type Tokenizer ¶
type Tokenizer struct { AllowComments bool SkipSpecialComments bool SkipToEnd bool LastError error ParseTree Statement BindVars map[string]struct{} Pos int // contains filtered or unexported fields }
Tokenizer is the struct used to generate SQL tokens for the parser.
func NewStringTokenizer ¶
NewStringTokenizer creates a new Tokenizer for the sql string.
type TrackedBuffer ¶
TrackedBuffer is used to rebuild a query from the ast. bindLocations keeps track of locations in the buffer that use bind variables for efficient future substitutions. nodeFormatter is the formatting function the buffer will use to format a node. By default(nil), it's FormatNode. But you can supply a different formatting function if you want to generate a query that's different from the default.
func NewTrackedBuffer ¶
func NewTrackedBuffer(nodeFormatter NodeFormatter) *TrackedBuffer
NewTrackedBuffer creates a new TrackedBuffer.
func (*TrackedBuffer) HasBindVars ¶
func (buf *TrackedBuffer) HasBindVars() bool
HasBindVars returns true if the parsed query uses bind vars.
func (*TrackedBuffer) Myprintf ¶
func (buf *TrackedBuffer) Myprintf(format string, values ...any)
Myprintf mimics fmt.Fprintf(buf, ...), but limited to Node(%v), Node.Value(%s) and string(%s). It also allows a %a for a value argument, in which case it adds tracking info for future substitutions. It adds parens as needed to follow precedence rules when printing expressions. To handle parens correctly for left associative binary operators, use %l and %r to tell the TrackedBuffer which value is on the LHS and RHS
The name must be something other than the usual Printf() to avoid "go vet" warnings due to our custom format specifiers. *** THIS METHOD SHOULD NOT BE USED FROM ast.go. USE astPrintf INSTEAD ***
func (*TrackedBuffer) SetEscapeAllIdentifiers ¶
func (buf *TrackedBuffer) SetEscapeAllIdentifiers(enable bool)
SetEscapeAllIdentifiers sets whether ALL identifiers in the serialized SQL query should be quoted and escaped. By default, identifiers are only escaped if they match the name of a SQL keyword or they contain characters that must be escaped. Enabling this option will prevent the optimized fastFormat routines from running.
func (*TrackedBuffer) SetUpperCase ¶
func (buf *TrackedBuffer) SetUpperCase(enable bool)
SetUpperCase sets whether all SQL statements formatted by this TrackedBuffer will be normalized into uppercase. By default, formatted statements are normalized into lowercase. Enabling this option will prevent the optimized fastFormat routines from running.
func (*TrackedBuffer) WriteArg ¶
func (buf *TrackedBuffer) WriteArg(prefix, arg string)
WriteArg writes a value argument into the buffer along with tracking information for future substitutions.
func (*TrackedBuffer) WriteNode ¶
func (buf *TrackedBuffer) WriteNode(node SQLNode) *TrackedBuffer
WriteNode function, initiates the writing of a single SQLNode tree by passing through to Myprintf with a default format string
type TrimFuncExpr ¶
type TrimFuncExpr struct { TrimFuncType TrimFuncType Type TrimType TrimArg Expr StringArg Expr }
TrimFuncExpr represents a TRIM function More information available on https://dev.mysql.com/doc/refman/5.7/en/string-functions.html#function_trim
func CloneRefOfTrimFuncExpr ¶
func CloneRefOfTrimFuncExpr(n *TrimFuncExpr) *TrimFuncExpr
CloneRefOfTrimFuncExpr creates a deep clone of the input.
func (*TrimFuncExpr) CachedSize ¶
func (cached *TrimFuncExpr) CachedSize(alloc bool) int64
func (*TrimFuncExpr) Format ¶
func (node *TrimFuncExpr) Format(buf *TrackedBuffer)
Format formats the node.
type TrimFuncType ¶
type TrimFuncType int8
TrimFuncType is an enum to get types of TrimFunc. TrimFunc stand for one of the following: LTRIM, RTRIM, TRIM
const ( NormalTrimType TrimFuncType = iota LTrimType RTrimType )
Constants for Enum Type - TrimFuncType
func (TrimFuncType) ToString ¶
func (ty TrimFuncType) ToString() string
ToString returns the type as a string
type TrimType ¶
type TrimType int8
TrimType is an enum to get types of Trim
Constants for Enum Type - TrimType
type TruncateTable ¶
type TruncateTable struct {
Table TableName
}
TruncateTable represents a TRUNCATE TABLE statement.
func CloneRefOfTruncateTable ¶
func CloneRefOfTruncateTable(n *TruncateTable) *TruncateTable
CloneRefOfTruncateTable creates a deep clone of the input.
func (*TruncateTable) AffectedTables ¶
func (node *TruncateTable) AffectedTables() TableNames
AffectedTables implements DDLStatement.
func (*TruncateTable) CachedSize ¶
func (cached *TruncateTable) CachedSize(alloc bool) int64
func (*TruncateTable) Format ¶
func (node *TruncateTable) Format(buf *TrackedBuffer)
Format formats the node
func (*TruncateTable) GetAction ¶
func (node *TruncateTable) GetAction() DDLAction
GetAction implements the DDLStatement interface
func (*TruncateTable) GetFromTables ¶
func (node *TruncateTable) GetFromTables() TableNames
GetFromTables implements the DDLStatement interface
func (*TruncateTable) GetIfExists ¶
func (node *TruncateTable) GetIfExists() bool
GetIfExists implements the DDLStatement interface
func (*TruncateTable) GetIfNotExists ¶
func (node *TruncateTable) GetIfNotExists() bool
GetIfNotExists implements the DDLStatement interface
func (*TruncateTable) GetIsReplace ¶
func (node *TruncateTable) GetIsReplace() bool
GetIsReplace implements the DDLStatement interface
func (*TruncateTable) GetOptLike ¶
func (node *TruncateTable) GetOptLike() *OptLike
GetOptLike implements the DDLStatement interface
func (*TruncateTable) GetParsedComments ¶
func (node *TruncateTable) GetParsedComments() *ParsedComments
GetParsedComments implements DDLStatement.
func (*TruncateTable) GetTable ¶
func (node *TruncateTable) GetTable() TableName
GetTable implements the DDLStatement interface
func (*TruncateTable) GetTableSpec ¶
func (node *TruncateTable) GetTableSpec() *TableSpec
GetTableSpec implements the DDLStatement interface
func (*TruncateTable) GetToTables ¶
func (node *TruncateTable) GetToTables() TableNames
GetToTables implements the DDLStatement interface
func (*TruncateTable) IsFullyParsed ¶
func (*TruncateTable) IsFullyParsed() bool
IsFullyParsed implements the DDLStatement interface
func (*TruncateTable) IsTemporary ¶
func (*TruncateTable) IsTemporary() bool
IsTemporary implements the DDLStatement interface
func (*TruncateTable) SetComments ¶
func (node *TruncateTable) SetComments(comments Comments)
SetComments implements DDLStatement.
func (*TruncateTable) SetFromTables ¶
func (node *TruncateTable) SetFromTables(tables TableNames)
SetFromTables implements DDLStatement.
func (*TruncateTable) SetFullyParsed ¶
func (*TruncateTable) SetFullyParsed(bool)
SetFullyParsed implements the DDLStatement interface
func (*TruncateTable) SetTable ¶
func (node *TruncateTable) SetTable(qualifier string, name string)
SetTable implements DDLStatement.
type TupleEqualityList ¶
TupleEqualityList is for generating equality constraints for tables that have composite primary keys.
func (*TupleEqualityList) EncodeSQL ¶
func (tpl *TupleEqualityList) EncodeSQL(buf *strings.Builder)
EncodeSQL generates the where clause constraints for the tuple equality.
type UnaryExpr ¶
type UnaryExpr struct { Operator UnaryExprOperator Expr Expr }
UnaryExpr represents a unary value expression.
func CloneRefOfUnaryExpr ¶
CloneRefOfUnaryExpr creates a deep clone of the input.
func (*UnaryExpr) CachedSize ¶
func (*UnaryExpr) Format ¶
func (node *UnaryExpr) Format(buf *TrackedBuffer)
Format formats the node.
type UnaryExprOperator ¶
type UnaryExprOperator int8
UnaryExprOperator is an enum for UnaryExpr.Operator
const ( UPlusOp UnaryExprOperator = iota UMinusOp TildaOp BangOp NStringOp )
Constant for Enum Type - UnaryExprOperator
func (UnaryExprOperator) ToString ¶
func (op UnaryExprOperator) ToString() string
ToString returns the operator as a string
type Union ¶
type Union struct { Left SelectStatement Right SelectStatement Distinct bool OrderBy OrderBy With *With Limit *Limit Lock Lock Into *SelectInto }
Union represents a UNION statement.
func CloneRefOfUnion ¶
CloneRefOfUnion creates a deep clone of the input.
func (*Union) CachedSize ¶
func (*Union) GetColumnCount ¶
GetColumnCount implements the SelectStatement interface
func (*Union) GetOrderBy ¶
GetOrderBy gets the order by clause
func (*Union) GetParsedComments ¶
func (node *Union) GetParsedComments() *ParsedComments
GetComments implements the SelectStatement interface
func (*Union) MakeDistinct ¶
func (node *Union) MakeDistinct()
MakeDistinct implements the SelectStatement interface
func (*Union) SetComments ¶
SetComments implements the SelectStatement interface
func (*Union) SetOrderBy ¶
SetOrderBy sets the order by clause
type UnlockTables ¶
type UnlockTables struct{}
UnlockTables represents the unlock statement
func CloneRefOfUnlockTables ¶
func CloneRefOfUnlockTables(n *UnlockTables) *UnlockTables
CloneRefOfUnlockTables creates a deep clone of the input.
func (*UnlockTables) Format ¶
func (node *UnlockTables) Format(buf *TrackedBuffer)
Format formats the UnlockTables node.
type Update ¶
type Update struct { With *With Comments *ParsedComments Ignore Ignore TableExprs TableExprs Exprs UpdateExprs Where *Where OrderBy OrderBy Limit *Limit }
Update represents an UPDATE statement. If you add fields here, consider adding them to calls to validateUnshardedRoute.
func CloneRefOfUpdate ¶
CloneRefOfUpdate creates a deep clone of the input.
func (*Update) AddWhere ¶
AddWhere adds the boolean expression to the WHERE clause as an AND condition.
func (*Update) CachedSize ¶
func (*Update) GetParsedComments ¶
func (node *Update) GetParsedComments() *ParsedComments
GetParsedComments implements Update.
func (*Update) SetComments ¶
SetComments for Update
type UpdateExpr ¶
UpdateExpr represents an update expression.
func CloneRefOfUpdateExpr ¶
func CloneRefOfUpdateExpr(n *UpdateExpr) *UpdateExpr
CloneRefOfUpdateExpr creates a deep clone of the input.
func (*UpdateExpr) CachedSize ¶
func (cached *UpdateExpr) CachedSize(alloc bool) int64
func (*UpdateExpr) Format ¶
func (node *UpdateExpr) Format(buf *TrackedBuffer)
Format formats the node.
type UpdateExprs ¶
type UpdateExprs []*UpdateExpr
UpdateExprs represents a list of update expressions.
func CloneUpdateExprs ¶
func CloneUpdateExprs(n UpdateExprs) UpdateExprs
CloneUpdateExprs creates a deep clone of the input.
func (UpdateExprs) Format ¶
func (node UpdateExprs) Format(buf *TrackedBuffer)
Format formats the node.
type Use ¶
type Use struct {
DBName TableIdent
}
Use represents a use statement.
func CloneRefOfUse ¶
CloneRefOfUse creates a deep clone of the input.
func (*Use) CachedSize ¶
type VStream ¶
type VStream struct { Comments *ParsedComments SelectExpr SelectExpr Table TableName Where *Where Limit *Limit }
VStream represents a VSTREAM statement.
func CloneRefOfVStream ¶
CloneRefOfVStream creates a deep clone of the input.
func (*VStream) CachedSize ¶
func (*VStream) GetParsedComments ¶
func (node *VStream) GetParsedComments() *ParsedComments
GetParsedComments implements VStream.
func (*VStream) SetComments ¶
SetComments for VStream
type ValTuple ¶
type ValTuple Exprs
ValTuple represents a tuple of actual values.
func CloneValTuple ¶
CloneValTuple creates a deep clone of the input.
type Validation ¶
type Validation struct {
With bool
}
Validation clause is used to specify whether to use validation or not
func CloneRefOfValidation ¶
func CloneRefOfValidation(n *Validation) *Validation
CloneRefOfValidation creates a deep clone of the input.
func (*Validation) CachedSize ¶
func (cached *Validation) CachedSize(alloc bool) int64
func (*Validation) Format ¶
func (node *Validation) Format(buf *TrackedBuffer)
Format formats the node
type ValuesFuncExpr ¶
type ValuesFuncExpr struct {
Name *ColName
}
ValuesFuncExpr represents a function call.
func CloneRefOfValuesFuncExpr ¶
func CloneRefOfValuesFuncExpr(n *ValuesFuncExpr) *ValuesFuncExpr
CloneRefOfValuesFuncExpr creates a deep clone of the input.
func (*ValuesFuncExpr) CachedSize ¶
func (cached *ValuesFuncExpr) CachedSize(alloc bool) int64
func (*ValuesFuncExpr) Format ¶
func (node *ValuesFuncExpr) Format(buf *TrackedBuffer)
Format formats the node.
type VindexParam ¶
VindexParam defines a key/value parameter for a CREATE VINDEX statement
func CloneRefOfVindexParam ¶
func CloneRefOfVindexParam(n *VindexParam) *VindexParam
CloneRefOfVindexParam creates a deep clone of the input.
func CloneSliceOfVindexParam ¶
func CloneSliceOfVindexParam(n []VindexParam) []VindexParam
CloneSliceOfVindexParam creates a deep clone of the input.
func CloneVindexParam ¶
func CloneVindexParam(n VindexParam) VindexParam
CloneVindexParam creates a deep clone of the input.
func (*VindexParam) CachedSize ¶
func (cached *VindexParam) CachedSize(alloc bool) int64
func (VindexParam) Format ¶
func (node VindexParam) Format(buf *TrackedBuffer)
Format formats the node.
type VindexSpec ¶
type VindexSpec struct { Name ColIdent Type ColIdent Params []VindexParam }
VindexSpec defines a vindex for a CREATE VINDEX or DROP VINDEX statement
func CloneRefOfVindexSpec ¶
func CloneRefOfVindexSpec(n *VindexSpec) *VindexSpec
CloneRefOfVindexSpec creates a deep clone of the input.
func (*VindexSpec) CachedSize ¶
func (cached *VindexSpec) CachedSize(alloc bool) int64
func (*VindexSpec) Format ¶
func (node *VindexSpec) Format(buf *TrackedBuffer)
Format formats the node. The "CREATE VINDEX" preamble was formatted in the containing DDL node Format, so this just prints the type, any parameters, and optionally the owner
func (*VindexSpec) ParseParams ¶
func (node *VindexSpec) ParseParams() (string, map[string]string)
ParseParams parses the vindex parameter list, pulling out the special-case "owner" parameter
type Visit ¶
Visit defines the signature of a function that can be used to visit all nodes of a parse tree. returning false on kontinue means that children will not be visited returning an error will abort the visitation and return the error
type WeightStringFuncExpr ¶
type WeightStringFuncExpr struct { Expr Expr As *ConvertType }
WeightStringFuncExpr represents the function and arguments for WEIGHT_STRING('string' AS [CHAR|BINARY](n))
func CloneRefOfWeightStringFuncExpr ¶
func CloneRefOfWeightStringFuncExpr(n *WeightStringFuncExpr) *WeightStringFuncExpr
CloneRefOfWeightStringFuncExpr creates a deep clone of the input.
func (*WeightStringFuncExpr) CachedSize ¶
func (cached *WeightStringFuncExpr) CachedSize(alloc bool) int64
func (*WeightStringFuncExpr) Format ¶
func (node *WeightStringFuncExpr) Format(buf *TrackedBuffer)
Format formats the node.
type When ¶
When represents a WHEN sub-expression.
func CloneRefOfWhen ¶
CloneRefOfWhen creates a deep clone of the input.
func CloneSliceOfRefOfWhen ¶
CloneSliceOfRefOfWhen creates a deep clone of the input.
func (*When) CachedSize ¶
type Where ¶
Where represents a WHERE or HAVING clause.
func CloneRefOfWhere ¶
CloneRefOfWhere creates a deep clone of the input.
func NewWhere ¶
NewWhere creates a WHERE or HAVING clause out of a Expr. If the expression is nil, it returns nil.
func (*Where) CachedSize ¶
type With ¶
type With struct { Recursive bool // contains filtered or unexported fields }
With contains the lists of common table expression and specifies if it is recursive or not
func CloneRefOfWith ¶
CloneRefOfWith creates a deep clone of the input.
func (*With) CachedSize ¶
type XorExpr ¶
type XorExpr struct {
Left, Right Expr
}
XorExpr represents an XOR expression.
func CloneRefOfXorExpr ¶
CloneRefOfXorExpr creates a deep clone of the input.
func (*XorExpr) CachedSize ¶
Source Files
¶
- analyzer.go
- ast.go
- ast_clone.go
- ast_equals.go
- ast_format.go
- ast_format_fast.go
- ast_funcs.go
- ast_rewrite.go
- ast_visit.go
- cached_size.go
- comments.go
- constants.go
- encodable.go
- keywords.go
- like_filter.go
- mysqlversion.go
- parse_table.go
- parser.go
- precedence.go
- random_expr.go
- rewriter_api.go
- set_normalizer.go
- sql.y
- token.go
- tracked_buffer.go
- truncate_query.go