Documentation ¶
Index ¶
- Constants
- Variables
- func Append(buf *bytes.Buffer, node SQLNode)
- func Backtick(in string) string
- func CompareLike(str, expr sqltypes.Value) (bool, error)
- func EncodeValue(buf *bytes.Buffer, value *querypb.BindVariable)
- func ErrAmbiguousReference(ref string) error
- func ErrUnrecognizedReference(ref string) error
- func Exec(store cafs.Filestore, query *dataset.Transform, options ...func(o *ExecOpt)) (result *dataset.Transform, resultBytes []byte, err error)
- func ExtractSetValues(sql string) (map[string]interface{}, error)
- func FetchBindVar(name string, bindVariables map[string]*querypb.BindVariable) (val *querypb.BindVariable, isList bool, err error)
- func FormatImpossibleQuery(buf *TrackedBuffer, node SQLNode)
- func GetBindvars(stmt Statement) map[string]struct{}
- func IsColName(node Expr) bool
- func IsDML(sql string) bool
- func IsNull(node Expr) bool
- func IsSimpleTuple(node Expr) bool
- func IsValue(node Expr) bool
- func NewPlanValue(node Expr) (sqltypes.PlanValue, error)
- func NewResultBuffer(stmt Statement, aq *dataset.Transform) (dsio.RowReadWriter, error)
- func Normalize(stmt Statement, bindVars map[string]*querypb.BindVariable, prefix string)
- func NotYetImplemented(feature string) error
- func PrepareStatement(stmt Statement, resources map[string]*dataset.Dataset) (err error)
- func Preview(sql string) int
- func QueryRecordPath(store cafs.Filestore, q *dataset.Transform, opts ...func(o *ExecOpt)) (datastore.Key, error)
- func RemoveUnusedReferences(stmt Statement, q *dataset.Transform) error
- func ResultStructure(stmt Statement, resources map[string]*dataset.Dataset, opts *ExecOpt) (*dataset.Structure, error)
- func SetSourceRow(cols []*ColName, sr SourceRow) error
- func SplitTrailingComments(sql string) (query, comments string)
- func StatementTableNames(sql string) ([]string, error)
- func String(node SQLNode) string
- func StringIn(str string, values ...string) bool
- func StripLeadingComments(sql string) string
- func TruncateForLog(query string) string
- func TruncateForUI(query string) string
- func Walk(visit Visit, nodes ...SQLNode) error
- type AggFunc
- type AliasedExpr
- func (node *AliasedExpr) Eval() (q.Type, []byte, error)
- func (node *AliasedExpr) FieldType(from map[string]*dataset.Structure) datatypes.Type
- func (node *AliasedExpr) Format(buf *TrackedBuffer)
- func (node *AliasedExpr) ResultName() (name string)
- func (node *AliasedExpr) WalkSubtree(visit Visit) error
- type AliasedTableExpr
- type AndExpr
- type BinaryExpr
- type BoolVal
- type CaseExpr
- type ColIdent
- func (node ColIdent) CompliantName() string
- func (node ColIdent) Equal(in ColIdent) bool
- func (node ColIdent) EqualString(str string) bool
- func (node ColIdent) Eval() (q.Type, []byte, error)
- 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
- func (node ColIdent) WalkSubtree(visit Visit) error
- type ColName
- type ColTuple
- type CollateExpr
- type Columns
- type Comments
- type ComparisonExpr
- type ConvertExpr
- type ConvertType
- type ConvertUsingExpr
- type DDL
- type Delete
- type Encodable
- type ExecOpt
- type ExistsExpr
- type Expr
- type Exprs
- type FuncExpr
- func (node *FuncExpr) Datatype() datatypes.Type
- func (node *FuncExpr) Eval() (q.Type, []byte, error)
- func (node *FuncExpr) Format(buf *TrackedBuffer)
- func (node *FuncExpr) Function() (fn AggFunc, err error)
- func (node *FuncExpr) IsAggregate() bool
- func (node *FuncExpr) WalkSubtree(visit Visit) error
- type GroupBy
- type GroupConcatExpr
- type IndexHints
- type Insert
- type InsertRows
- type InsertValues
- type IntervalExpr
- type IsExpr
- type JoinTableExpr
- type Limit
- type ListArg
- type MatchExpr
- type Nextval
- type NotExpr
- type NullVal
- type OnDup
- type OrExpr
- type Order
- type OrderBy
- type OtherAdmin
- type OtherRead
- type ParenExpr
- type ParenSelect
- func (node *ParenSelect) AddOrder(order *Order)
- func (node *ParenSelect) Eval() (q.Type, []byte, error)
- func (node *ParenSelect) Format(buf *TrackedBuffer)
- func (node *ParenSelect) References() []string
- func (node *ParenSelect) SetLimit(limit *Limit)
- func (node *ParenSelect) WalkSubtree(visit Visit) error
- type ParenTableExpr
- type ParsedQuery
- type RangeCond
- type ResultRowGenerator
- type SQLNode
- type SQLVal
- type Select
- func (node *Select) AddHaving(expr Expr)
- func (node *Select) AddOrder(order *Order)
- func (node *Select) AddWhere(expr Expr)
- func (node *Select) Eval() (q.Type, []byte, error)
- func (node *Select) Format(buf *TrackedBuffer)
- func (node *Select) References() []string
- func (node *Select) SetLimit(limit *Limit)
- func (node *Select) WalkSubtree(visit Visit) error
- type SelectExpr
- type SelectExprs
- func (node SelectExprs) Eval() (q.Type, []byte, error)
- func (nodes SelectExprs) FieldTypes(from map[string]*dataset.Structure) (types []datatypes.Type)
- func (node SelectExprs) Format(buf *TrackedBuffer)
- func (nodes SelectExprs) Values() (types []q.Type, vals [][]byte, err error)
- func (node SelectExprs) WalkSubtree(visit Visit) error
- type SelectStatement
- type Set
- type Show
- type SimpleTableExpr
- type SourceRow
- type SourceRowFilter
- type SourceRowGenerator
- type StarExpr
- func (node *StarExpr) Eval() (q.Type, []byte, error)
- func (node *StarExpr) FieldTypes(from map[string]*dataset.Structure) (types []datatypes.Type)
- func (node *StarExpr) Format(buf *TrackedBuffer)
- func (node *StarExpr) Values() ([]q.Type, [][]byte, error)
- func (node *StarExpr) WalkSubtree(visit Visit) error
- type Statement
- type StructureRef
- type Subquery
- type TableExpr
- type TableExprs
- type TableIdent
- func (node TableIdent) CompliantName() string
- func (node TableIdent) Eval() (q.Type, []byte, error)
- 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) TableName() string
- func (node *TableIdent) UnmarshalJSON(b []byte) error
- func (node TableIdent) WalkSubtree(visit Visit) error
- type TableName
- func (node TableName) Eval() (q.Type, []byte, error)
- func (node TableName) Format(buf *TrackedBuffer)
- func (node TableName) IsEmpty() bool
- func (node TableName) String() string
- func (node TableName) TableName() string
- func (node TableName) ToViewName() TableName
- func (node TableName) WalkSubtree(visit Visit) error
- type TableNames
- type Tokenizer
- type TrackedBuffer
- type TupleEqualityList
- type UnaryExpr
- type Union
- type Update
- type UpdateExpr
- type UpdateExprs
- type Use
- type ValTuple
- type ValType
- type Values
- type ValuesFuncExpr
- type Visit
- type When
- type Where
Constants ¶
const ( StmtSelect = iota StmtInsert StmtReplace StmtUpdate StmtDelete StmtDDL StmtBegin StmtCommit StmtRollback StmtSet StmtShow StmtUse StmtOther StmtUnknown )
These constants are used to identify the SQL statement type.
const ( DistinctStr = "distinct " StraightJoinHint = "straight_join " )
Select.Distinct
const ( ForUpdateStr = " for update" )
Select.Lock
const ( SQLCacheStr = "sql_cache " SQLNoCacheStr = "sql_no_cache " )
Select.Cache
const ( UnionStr = "union" UnionAllStr = "union all" UnionDistinctStr = "union distinct" )
Union.Type
const ( InsertStr = "insert" ReplaceStr = "replace" )
DDL strings.
const ( CreateStr = "create" AlterStr = "alter" DropStr = "drop" RenameStr = "rename" )
DDL strings.
const ( ShowDatabasesStr = "databases" ShowKeyspacesStr = "vitess_keyspaces" ShowShardsStr = "vitess_shards" ShowTablesStr = "tables" ShowVSchemaTablesStr = "vschema_tables" ShowUnsupportedStr = "unsupported" )
The frollowing constants represent SHOW statements.
const ( JoinStr = "join" StraightJoinStr = "straight_join" LeftJoinStr = "left join" RightJoinStr = "right join" NaturalJoinStr = "natural join" NaturalLeftJoinStr = "natural left join" NaturalRightJoinStr = "natural right join" )
JoinTableExpr.Join
const ( UseStr = "use " IgnoreStr = "ignore " ForceStr = "force " )
Index hints.
const ( WhereStr = "where" HavingStr = "having" )
Where.Type
const ( EqualStr = "=" LessThanStr = "<" GreaterThanStr = ">" LessEqualStr = "<=" GreaterEqualStr = ">=" NotEqualStr = "!=" NullSafeEqualStr = "<=>" InStr = "in" NotInStr = "not in" LikeStr = "like" NotLikeStr = "not like" RegexpStr = "regexp" NotRegexpStr = "not regexp" JSONExtractOp = "->" JSONUnquoteExtractOp = "->>" )
ComparisonExpr.Operator
const ( BetweenStr = "between" NotBetweenStr = "not between" )
RangeCond.Operator
const ( IsNullStr = "is null" IsNotNullStr = "is not null" IsTrueStr = "is true" IsNotTrueStr = "is not true" IsFalseStr = "is false" IsNotFalseStr = "is not false" )
IsExpr.Operator
const ( StrVal = ValType(iota) IntVal FloatVal HexNum HexVal ValArg )
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 ( BitAndStr = "&" BitOrStr = "|" BitXorStr = "^" PlusStr = "+" MinusStr = "-" MultStr = "*" DivStr = "/" IntDivStr = "div" ModStr = "%" ShiftLeftStr = "<<" ShiftRightStr = ">>" )
BinaryExpr.Operator
const ( UPlusStr = "+" UMinusStr = "-" TildaStr = "~" BangStr = "!" BinaryStr = "binary " )
UnaryExpr.Operator
const ( BooleanModeStr = " in boolean mode" NaturalLanguageModeStr = " in natural language mode" NaturalLanguageModeWithQueryExpansionStr = " in natural language mode with query expansion" QueryExpansionStr = " with query expansion" )
MatchExpr.Option
const ( AscScr = "asc" DescScr = "desc" )
Order.Direction
const AGAINST = 57474
const ALL = 57361
const ALTER = 57432
const ANALYZE = 57435
const AND = 57405
const AS = 57363
const ASC = 57365
const BETWEEN = 57407
const BINARY = 57427
const BOOLEAN = 57475
const BY = 57357
const CASE = 57408
const CAST = 57470
const CHARACTER = 57458
const COLLATE = 57426
const COMMENT = 57400
const CONVERT = 57469
const CREATE = 57431
const CROSS = 57387
const CURRENT_DATE = 57461
const CURRENT_TIME = 57462
const CURRENT_TIMESTAMP = 57459
const (
CharacterSetStr = " character set"
)
this string is "character set" and this comment is required
const DATABASE = 57460
const DATABASES = 57452
const DATE = 57447
const DEFAULT = 57370
const DELETE = 57351
const DESC = 57366
const DESCRIBE = 57445
const DISTINCT = 57362
const DIV = 57423
const DROP = 57433
const DUPLICATE = 57368
const ELSE = 57411
const END = 57412
const ESCAPE = 57448
const EXISTS = 57364
const EXPANSION = 57479
const EXPLAIN = 57446
const FALSE = 57403
const FLOAT = 57396
const FOR = 57360
const FORCE = 57390
const FROM = 57352
const GE = 57414
const GROUP = 57354
const GROUP_CONCAT = 57471
const HAVING = 57355
const HEX = 57393
const HEXNUM = 57397
const ID = 57392
const IF = 57441
const IGNORE = 57440
const IN = 57420
const INDEX = 57437
const INNER = 57385
const INSERT = 57349
const INTEGER = 57457
const INTEGRAL = 57395
const INTERVAL = 57428
const INTO = 57367
const IS = 57417
const JOIN = 57381
const JSON_EXTRACT_OP = 57429
const JSON_UNQUOTE_EXTRACT_OP = 57430
const KEY = 57369
const LANGUAGE = 57476
const LAST_INSERT_ID = 57374
const LE = 57413
const LEFT = 57383
const LEX_ERROR = 57346
const LIKE = 57418
const LIMIT = 57358
const LIST_ARG = 57399
const LOCALTIME = 57463
const LOCALTIMESTAMP = 57464
const LOCK = 57372
const MATCH = 57473
const MOD = 57424
const MODE = 57378
const NATURAL = 57388
const NE = 57415
const NEXT = 57375
const NOT = 57406
const NULL = 57401
const NULL_SAFE_EQUAL = 57416
const OFFSET = 57359
const ON = 57391
const OPTIMIZE = 57450
const OR = 57404
const ORDER = 57356
const OUTER = 57386
const QUERY = 57478
const QueryBoolType = q.Type_UINT8
map bool to a unsigned 8 bit int
const REGEXP = 57419
const RENAME = 57434
const REPAIR = 57449
const REPLACE = 57468
const RIGHT = 57384
const SELECT = 57348
const SEPARATOR = 57472
const SET = 57371
const SHARE = 57377
const SHIFT_LEFT = 57421
const SHIFT_RIGHT = 57422
const SHOW = 57444
const SQL_CACHE = 57380
const SQL_NO_CACHE = 57379
const STRAIGHT_JOIN = 57382
const STRING = 57394
const TABLE = 57436
const TABLES = 57453
const THEN = 57410
const TO = 57439
const TRUE = 57402
const TRUNCATE = 57451
const UNARY = 57425
const UNION = 57347
const UNIQUE = 57442
const UNUSED = 57480
const UPDATE = 57350
const USE = 57389
const USING = 57443
const UTC_DATE = 57465
const UTC_TIME = 57466
const UTC_TIMESTAMP = 57467
const VALUE = 57376
const VALUES = 57373
const VALUE_ARG = 57398
const VIEW = 57438
const VITESS_KEYSPACES = 57454
const VITESS_SHARDS = 57455
const VSCHEMA_TABLES = 57456
const WHEN = 57409
const WHERE = 57353
const WITH = 57477
Variables ¶
var ( ErrAggStmt = fmt.Errorf("this statement only generates an aggregate result row") ErrTableStmt = fmt.Errorf("this statement doesn't generate an aggregate result row") )
var ( // Maximum length for a query in a sqlerror string. 0 means unlimited. TruncateUILen = flag.Int("sql-max-length-ui", 512, "truncate queries in debug UIs to the given length (default 512)") 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.
Functions ¶
func EncodeValue ¶
func EncodeValue(buf *bytes.Buffer, value *querypb.BindVariable)
EncodeValue encodes one bind variable value into the query.
func ErrAmbiguousReference ¶
func ExtractSetValues ¶
ExtractSetValues returns a map of key-value pairs if the query is a SET statement. Values can be int64 or string. Since set variable names are case insensitive, all keys are returned as lower case.
func FetchBindVar ¶
func FetchBindVar(name string, bindVariables map[string]*querypb.BindVariable) (val *querypb.BindVariable, isList bool, err error)
FetchBindVar resolves the bind variable by fetching it from bindVariables.
func FormatImpossibleQuery ¶
func FormatImpossibleQuery(buf *TrackedBuffer, node SQLNode)
FormatImpossibleQuery creates an impossible query in a TrackedBuffer. An impossible query is a modified version of a query where all selects have where clauses that are impossible for mysql to resolve. This is used in the vtgate and vttablet:
- In the vtgate it's used for joins: if the first query returns no result, then vtgate uses the impossible query just to fetch field info from vttablet - In the vttablet, it's just an optimization: the field info is fetched once form MySQL, cached and reused for subsequent queries
func GetBindvars ¶
GetBindvars returns a map of the bind vars referenced in the statement. TODO(sougou); This function gets called again from vtgate/planbuilder. Ideally, this should be done only once.
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 NewPlanValue ¶
NewPlanValue builds a sqltypes.PlanValue from an Expr.
func NewResultBuffer ¶
NewResultBuffer returns either a *RowBuffer or *dsio.Buffer depending on which is required. RowBuffer is (much) more expensive but supports introspection into already-written rows
func Normalize ¶
func Normalize(stmt Statement, bindVars map[string]*querypb.BindVariable, prefix string)
Normalize changes the statement to use bind values, and updates the bind vars to those values. The supplied prefix is used to generate the bind var names. The function ensures that there are no collisions with existing bind vars.
func NotYetImplemented ¶
NotYetImplemented reports missing features. it'd be lovely to not need this ;)
func PrepareStatement ¶
PrepareStatement sets up a statement for exectution. It modifies the passed-in statement making optimizations, associating type information from resources, etc.
func Preview ¶
Preview analyzes the beginning of the query using a simpler and faster textual comparison to identify the statement type.
func QueryRecordPath ¶
func QueryRecordPath(store cafs.Filestore, q *dataset.Transform, opts ...func(o *ExecOpt)) (datastore.Key, error)
QueryRecordPath returns the hash of an abstracted query to be excectuted with a given set of resources. the returned key can be used to see if a a given query has been run before
func RemoveUnusedReferences ¶
RemoveUnusedReferences sets ds.Resources to a new map that that contains only datasets refrerenced in the provided select statement, it errors if it cannot find a named dataset from the provided ds.Resources map.
func ResultStructure ¶
func ResultStructure(stmt Statement, resources map[string]*dataset.Dataset, opts *ExecOpt) (*dataset.Structure, error)
ResultStructure determines the structure of the output for a select statement and a provided resource table map
func SetSourceRow ¶
SetSourceRow sets ColName values to the current SourceRow value for evaluation
func SplitTrailingComments ¶
SplitTrailingComments splits the query trailing comments from the query.
func StatementTableNames ¶
StatementTableNames extracts the names of all referenced tables from a given statement
func StringIn ¶
StringIn is a convenience function that returns true if str matches any of the values.
func StripLeadingComments ¶
StripLeadingComments trims the SQL string and removes any leading comments
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
Types ¶
type AggFunc ¶
func AggregateFuncs ¶
AggregateFuncs extracts a slice of any aggregate functions from an AST, while also writing pointers to newly-generated funcs to the AST
type AliasedExpr ¶
AliasedExpr defines an aliased SELECT expression.
func (*AliasedExpr) FieldType ¶
FieldType returns a string representation of the type of field where datatype is one of: "", "string", "integer", "float", "boolean", "date" TODO - this may need rethinking.
func (*AliasedExpr) Format ¶
func (node *AliasedExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*AliasedExpr) ResultName ¶
func (node *AliasedExpr) ResultName() (name string)
Field returns a name & datatype for the select expr
func (*AliasedExpr) WalkSubtree ¶
func (node *AliasedExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type AliasedTableExpr ¶
type AliasedTableExpr struct { Expr SimpleTableExpr As TableIdent Hints *IndexHints }
AliasedTableExpr represents a table expression coupled with an optional alias or index hint. If As is empty, no alias was used.
func (*AliasedTableExpr) Format ¶
func (node *AliasedTableExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*AliasedTableExpr) TableName ¶
func (node *AliasedTableExpr) TableName() string
func (*AliasedTableExpr) TableNames ¶
func (node *AliasedTableExpr) TableNames() []string
func (*AliasedTableExpr) WalkSubtree ¶
func (node *AliasedTableExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type AndExpr ¶
type AndExpr struct {
Left, Right Expr
}
AndExpr represents an AND expression.
func (*AndExpr) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type BinaryExpr ¶
BinaryExpr represents a binary value expression.
func (*BinaryExpr) Format ¶
func (node *BinaryExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*BinaryExpr) WalkSubtree ¶
func (node *BinaryExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type BoolVal ¶
type BoolVal bool
BoolVal is true or false.
func (BoolVal) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type CaseExpr ¶
CaseExpr represents a CASE expression.
func (*CaseExpr) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
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 (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.
func (ColIdent) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
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 StructureRef Value []byte Name ColIdent Qualifier TableName }
ColName represents a column name.
func CollectColNames ¶
CollectColNames grabs a slice of pointers to all columns in a given SQL statement, used to avoid re-traversing the tree to find all the places column pointers live
func (*ColName) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type ColTuple ¶
type ColTuple interface { Expr // contains filtered or unexported methods }
ColTuple represents a list of column values. It can be ValTuple, Subquery, ListArg.
type CollateExpr ¶
CollateExpr represents dynamic collate operator.
func (*CollateExpr) Format ¶
func (node *CollateExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*CollateExpr) WalkSubtree ¶
func (node *CollateExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type Columns ¶
type Columns []ColIdent
Columns represents an insert column list.
func (Columns) FindColumn ¶
FindColumn finds a column in the column list, returning the index if it exists or -1 otherwise
func (Columns) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type Comments ¶
type Comments [][]byte
Comments represents a list of comments.
func (Comments) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type ComparisonExpr ¶
ComparisonExpr represents a two-value comparison expression.
func (*ComparisonExpr) Compare ¶
func (node *ComparisonExpr) Compare() (bool, error)
func (*ComparisonExpr) Format ¶
func (node *ComparisonExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*ComparisonExpr) WalkSubtree ¶
func (node *ComparisonExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
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 (*ConvertExpr) Format ¶
func (node *ConvertExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*ConvertExpr) WalkSubtree ¶
func (node *ConvertExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type ConvertType ¶
ConvertType represents the type in call to CONVERT(expr, type)
func (*ConvertType) Format ¶
func (node *ConvertType) Format(buf *TrackedBuffer)
Format formats the node.
func (*ConvertType) WalkSubtree ¶
func (node *ConvertType) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type ConvertUsingExpr ¶
ConvertUsingExpr represents a call to CONVERT(expr USING charset).
func (*ConvertUsingExpr) Eval ¶
func (node *ConvertUsingExpr) Eval() (q.Type, []byte, error)
TODO - finish
func (*ConvertUsingExpr) Format ¶
func (node *ConvertUsingExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*ConvertUsingExpr) WalkSubtree ¶
func (node *ConvertUsingExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type DDL ¶
DDL represents a CREATE, ALTER, DROP or RENAME statement. Table is set for AlterStr, DropStr, RenameStr. NewName is set for AlterStr, CreateStr, RenameStr.
func (*DDL) References ¶
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else TODO - finish this
func (*DDL) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type Delete ¶
type Delete struct { Comments Comments Targets TableNames TableExprs TableExprs Where *Where OrderBy OrderBy Limit *Limit }
Delete represents a DELETE statement.
func (*Delete) References ¶
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else TODO - finish this
func (*Delete) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type ExecOpt ¶
type ExecOpt struct {
Format dataset.DataFormat
}
func DefaultExecOpts ¶
func DefaultExecOpts() *ExecOpt
type ExistsExpr ¶
type ExistsExpr struct {
Subquery *Subquery
}
ExistsExpr represents an EXISTS expression.
func (*ExistsExpr) Format ¶
func (node *ExistsExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*ExistsExpr) WalkSubtree ¶
func (node *ExistsExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type Expr ¶
type Expr interface { SQLNode // contains filtered or unexported methods }
Expr represents an expression.
type Exprs ¶
type Exprs []Expr
Exprs represents a list of value expressions. It's not a valid expression because it's not parenthesized.
func (Exprs) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type FuncExpr ¶
type FuncExpr struct { Qualifier TableIdent Name ColIdent Distinct bool Exprs SelectExprs // contains filtered or unexported fields }
FuncExpr represents a function call.
func (*FuncExpr) IsAggregate ¶
IsAggregate returns true if the function is an aggregate.
func (*FuncExpr) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type GroupBy ¶
type GroupBy []Expr
GroupBy represents a GROUP BY clause.
func (GroupBy) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type GroupConcatExpr ¶
type GroupConcatExpr struct { Distinct string Exprs SelectExprs OrderBy OrderBy Separator string }
GroupConcatExpr represents a call to GROUP_CONCAT
func (*GroupConcatExpr) Eval ¶
func (node *GroupConcatExpr) Eval() (q.Type, []byte, error)
TODO - finish
func (*GroupConcatExpr) Format ¶
func (node *GroupConcatExpr) Format(buf *TrackedBuffer)
Format formats the node
func (*GroupConcatExpr) WalkSubtree ¶
func (node *GroupConcatExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type IndexHints ¶
IndexHints represents a list of index hints.
func (*IndexHints) Format ¶
func (node *IndexHints) Format(buf *TrackedBuffer)
Format formats the node.
func (*IndexHints) WalkSubtree ¶
func (node *IndexHints) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type Insert ¶
type Insert struct { Action string Comments Comments Ignore string Table TableName 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.
func (*Insert) References ¶
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else TODO - add test coverage
func (*Insert) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type InsertRows ¶
type InsertRows interface { SQLNode // contains filtered or unexported methods }
InsertRows represents the rows for an INSERT statement.
type InsertValues ¶
InsertValues is a custom SQL encoder for the values of an insert statement.
func (InsertValues) EncodeSQL ¶
func (iv InsertValues) EncodeSQL(buf *bytes.Buffer)
EncodeSQL performs the SQL encoding for InsertValues.
type IntervalExpr ¶
IntervalExpr represents a date-time INTERVAL expression.
func (*IntervalExpr) Format ¶
func (node *IntervalExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*IntervalExpr) WalkSubtree ¶
func (node *IntervalExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type IsExpr ¶
IsExpr represents an IS ... or an IS NOT ... expression.
func (*IsExpr) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type JoinTableExpr ¶
JoinTableExpr represents a TableExpr that's a JOIN operation.
func (*JoinTableExpr) Format ¶
func (node *JoinTableExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*JoinTableExpr) TableNames ¶
func (node *JoinTableExpr) TableNames() (adrs []string)
func (*JoinTableExpr) WalkSubtree ¶
func (node *JoinTableExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type Limit ¶
type Limit struct {
Offset, Rowcount Expr
}
Limit represents a LIMIT clause.
func (*Limit) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type ListArg ¶
type ListArg []byte
ListArg represents a named list argument.
func (ListArg) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type MatchExpr ¶
type MatchExpr struct { Columns SelectExprs Expr Expr Option string }
MatchExpr represents a call to the MATCH function
func (*MatchExpr) Format ¶
func (node *MatchExpr) Format(buf *TrackedBuffer)
Format formats the node
func (*MatchExpr) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type Nextval ¶
type Nextval struct {
Expr Expr
}
Nextval defines the NEXT VALUE expression.
func (Nextval) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type NotExpr ¶
type NotExpr struct {
Expr Expr
}
NotExpr represents a NOT expression.
func (*NotExpr) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type NullVal ¶
type NullVal struct{}
NullVal represents a NULL value.
func (*NullVal) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type OnDup ¶
type OnDup UpdateExprs
OnDup represents an ON DUPLICATE KEY clause.
func (OnDup) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type OrExpr ¶
type OrExpr struct {
Left, Right Expr
}
OrExpr represents an OR expression.
func (*OrExpr) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type Order ¶
Order represents an ordering expression.
func (*Order) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type OrderBy ¶
type OrderBy []*Order
OrderBy represents an ORDER By clause.
func (OrderBy) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
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 (*OtherAdmin) Format ¶
func (node *OtherAdmin) Format(buf *TrackedBuffer)
Format formats the node.
func (*OtherAdmin) References ¶
func (node *OtherAdmin) References() []string
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else TODO - finish this
func (*OtherAdmin) WalkSubtree ¶
func (node *OtherAdmin) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
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 (*OtherRead) Format ¶
func (node *OtherRead) Format(buf *TrackedBuffer)
Format formats the node.
func (*OtherRead) References ¶
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else TODO - finish this
func (*OtherRead) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type ParenExpr ¶
type ParenExpr struct {
Expr Expr
}
ParenExpr represents a parenthesized boolean expression.
func (*ParenExpr) Format ¶
func (node *ParenExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*ParenExpr) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type ParenSelect ¶
type ParenSelect struct {
Select SelectStatement
}
ParenSelect is a parenthesized SELECT statement.
func (*ParenSelect) AddOrder ¶
func (node *ParenSelect) AddOrder(order *Order)
AddOrder adds an order by element
func (*ParenSelect) Format ¶
func (node *ParenSelect) Format(buf *TrackedBuffer)
Format formats the node.
func (*ParenSelect) References ¶
func (node *ParenSelect) References() []string
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else
func (*ParenSelect) SetLimit ¶
func (node *ParenSelect) SetLimit(limit *Limit)
SetLimit sets the limit clause
func (*ParenSelect) WalkSubtree ¶
func (node *ParenSelect) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type ParenTableExpr ¶
type ParenTableExpr struct {
Exprs TableExprs
}
ParenTableExpr represents a parenthesized list of TableExpr.
func (*ParenTableExpr) Format ¶
func (node *ParenTableExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*ParenTableExpr) TableNames ¶
func (node *ParenTableExpr) TableNames() (addrs []string)
func (*ParenTableExpr) WalkSubtree ¶
func (node *ParenTableExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type ParsedQuery ¶
type ParsedQuery struct { Query string // contains filtered or unexported fields }
ParsedQuery represents a parsed query where bind locations are precompued for fast substitutions.
func BuildParsedQuery ¶
func BuildParsedQuery(in string, vars ...interface{}) *ParsedQuery
BuildParsedQuery builds a ParsedQuery from the input.
func GenerateParsedQuery ¶
func GenerateParsedQuery(node SQLNode) *ParsedQuery
GenerateParsedQuery returns a ParsedQuery of the ast.
func (*ParsedQuery) GenerateQuery ¶
func (pq *ParsedQuery) GenerateQuery(bindVariables map[string]*querypb.BindVariable, extras map[string]Encodable) ([]byte, error)
GenerateQuery generates a query by substituting the specified bindVariables. The extras parameter specifies special parameters that can perform custom encoding.
func (*ParsedQuery) MarshalJSON ¶
func (pq *ParsedQuery) MarshalJSON() ([]byte, error)
MarshalJSON is a custom JSON marshaler for ParsedQuery. Note that any queries longer that 512 bytes will be truncated.
type RangeCond ¶
RangeCond represents a BETWEEN or a NOT BETWEEN expression.
func (*RangeCond) Format ¶
func (node *RangeCond) Format(buf *TrackedBuffer)
Format formats the node.
func (*RangeCond) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type ResultRowGenerator ¶
type ResultRowGenerator struct {
// contains filtered or unexported fields
}
ResultRowGenerator makes rows from SourceRows calling eval on a set of select expressions from a given SourceRow
func NewResultRowGenerator ¶
func NewResultRowGenerator(sel *Select, result *dataset.Structure) (rg *ResultRowGenerator, err error)
func (*ResultRowGenerator) GenerateAggregateRow ¶
func (rg *ResultRowGenerator) GenerateAggregateRow() ([][]byte, error)
func (*ResultRowGenerator) GenerateRow ¶
func (rg *ResultRowGenerator) GenerateRow() ([][]byte, error)
GenerateRow generates a row
func (*ResultRowGenerator) HasAggregates ¶
func (rg *ResultRowGenerator) HasAggregates() bool
func (*ResultRowGenerator) Structure ¶
func (rg *ResultRowGenerator) Structure() *dataset.Structure
type SQLNode ¶
type SQLNode interface { Format(buf *TrackedBuffer) // WalkSubtree calls visit on all underlying nodes // of the subtree, but not the current one. Walking // must be interrupted if visit returns an error. WalkSubtree(visit Visit) error Eval() (pbquery.Type, []byte, error) }
SQLNode defines the interface for all nodes generated by the parser.
type SQLVal ¶
SQLVal represents a single value.
func (*SQLVal) Bytes ¶
Bytes returns the node values TODO - alter output based on value type? eg: do Hex Values need to change their output?
func (*SQLVal) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type Select ¶
type Select struct { Cache string Comments Comments Distinct string Hints string SelectExprs SelectExprs From TableExprs Where *Where GroupBy GroupBy Having *Where OrderBy OrderBy Limit *Limit Lock string }
Select represents a SELECT statement.
func (*Select) AddHaving ¶
AddHaving adds the boolean expression to the HAVING clause as an AND condition. If the expression is an OR clause, it parenthesizes it. Currently, the OR operator is the only one that's lower precedence than AND.
func (*Select) AddWhere ¶
AddWhere adds the boolean expression to the WHERE clause as an AND condition. If the expression is an OR clause, it parenthesizes it. Currently, the OR operator is the only one that's lower precedence than AND.
func (*Select) References ¶
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else
func (*Select) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type SelectExpr ¶
type SelectExpr interface { SQLNode // contains filtered or unexported methods }
SelectExpr represents a SELECT expression.
type SelectExprs ¶
type SelectExprs []SelectExpr
SelectExprs represents SELECT expressions.
func (SelectExprs) FieldTypes ¶
func (SelectExprs) Format ¶
func (node SelectExprs) Format(buf *TrackedBuffer)
Format formats the node.
func (SelectExprs) Values ¶
func (nodes SelectExprs) Values() (types []q.Type, vals [][]byte, err error)
func (SelectExprs) WalkSubtree ¶
func (node SelectExprs) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type SelectStatement ¶
type SelectStatement interface { AddOrder(*Order) SetLimit(*Limit) References() []string SQLNode // contains filtered or unexported methods }
SelectStatement any SELECT statement.
type Set ¶
type Set struct { Comments Comments Exprs UpdateExprs }
Set represents a SET statement.
func (*Set) References ¶
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else TODO - finish this
func (*Set) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type Show ¶
type Show struct {
Type string
}
Show represents a show statement.
func (*Show) References ¶
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else TODO - finish this
func (*Show) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type SimpleTableExpr ¶
type SimpleTableExpr interface { TableName() string // SetTableName(string) SQLNode // contains filtered or unexported methods }
SimpleTableExpr represents a simple table expression.
type SourceRow ¶
SourceRow is a row of data from a number of different tables identitifed by a string
type SourceRowFilter ¶
type SourceRowFilter struct {
// contains filtered or unexported fields
}
SourceRowFilter uses type-populated AST to evaluate candidate SourceRows to see if they should be added to the resulting dataset internal state for example, things like current status in a LIMIT / OFFSET
func NewSourceRowFilter ¶
func NewSourceRowFilter(ast Statement, buf dsio.RowReadWriter) (srf *SourceRowFilter, err error)
func (*SourceRowFilter) Done ¶
func (srf *SourceRowFilter) Done() bool
Done indicates we don't need to iterate anymore
func (*SourceRowFilter) Match ¶
func (srf *SourceRowFilter) Match() bool
Match returns weather the row should be allowed to pass through to the table
func (*SourceRowFilter) ShouldWriteRow ¶
func (srf *SourceRowFilter) ShouldWriteRow(row [][]byte) bool
ShouldWriteRow checks to see if a row should be written to a destination
type SourceRowGenerator ¶
type SourceRowGenerator struct {
// contains filtered or unexported fields
}
SourcRowGenerator consumes dataset data readers generating SourceRows. It's main job is to generate the exhastive set of candidate row combinations for comparison
func NewSourceRowGenerator ¶
func NewSourceRowGenerator(store cafs.Filestore, resources map[string]*dataset.Dataset) (*SourceRowGenerator, error)
NewSourceRowGenerator initializes a source row generator
func (*SourceRowGenerator) Next ¶
func (srg *SourceRowGenerator) Next() bool
func (*SourceRowGenerator) Row ¶
func (srg *SourceRowGenerator) Row() (SourceRow, error)
type StarExpr ¶
type StarExpr struct {
TableName TableName
}
StarExpr defines a '*' or 'table.*' expression.
func (*StarExpr) FieldTypes ¶
func (*StarExpr) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type Statement ¶
type Statement interface { References() []string SQLNode // contains filtered or unexported methods }
Statement represents a statement.
func Format ¶
func Format(q *dataset.Transform, opts ...func(o *ExecOpt)) (stmt Statement, abst *dataset.Transform, err error)
Format places an sql statement in it's standard form. This will be *heavily* refined, improved, and moved into a separate package TODO - ^^ It's expected that the query to be exectuted will be a string in the given datset.Data value Format will modify the incoming
func Parse ¶
Parse parses the sql and returns a Statement, which is the AST representation of the query.
func RemapReferences ¶
func RemapReferences(stmt *Select, remap map[string]string, a, b map[string]*dataset.Structure) (Statement, error)
RemapReferences re-writes all table and table column references from remap key to remap value Remap will destroy any table-aliasing ("as" statements) TODO - generalize to apply to Statement instead of *Select TODO - need to finish support for remapping column refs
type StructureRef ¶
StructureRef is placed on ColName SQLNodes to connect typing & data lookup information
type Subquery ¶
type Subquery struct {
Select SelectStatement
}
Subquery represents a subquery.
func (*Subquery) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type TableExpr ¶
type TableExpr interface { TableNames() []string SQLNode // contains filtered or unexported methods }
TableExpr represents a table expression.
type TableExprs ¶
type TableExprs []TableExpr
TableExprs represents a list of table expressions.
func (TableExprs) Format ¶
func (node TableExprs) Format(buf *TrackedBuffer)
Format formats the node.
func (TableExprs) TableNames ¶
func (node TableExprs) TableNames() (names []string)
func (TableExprs) WalkSubtree ¶
func (node TableExprs) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
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 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. TODO - this might not be needed?
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) TableName ¶
func (node TableIdent) TableName() string
func (*TableIdent) UnmarshalJSON ¶
func (node *TableIdent) UnmarshalJSON(b []byte) error
UnmarshalJSON unmarshals from JSON.
func (TableIdent) WalkSubtree ¶
func (node TableIdent) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
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 (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.
func (TableName) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type TableNames ¶
type TableNames []TableName
TableNames is a list of TableName.
func (TableNames) Format ¶
func (node TableNames) Format(buf *TrackedBuffer)
Format formats the node.
func (TableNames) TableNames ¶
func (node TableNames) TableNames() []string
func (TableNames) WalkSubtree ¶
func (node TableNames) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type Tokenizer ¶
type Tokenizer struct { InStream *strings.Reader AllowComments bool ForceEOF bool Position int LastError string ParseTree Statement // 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 func(buf *TrackedBuffer, node SQLNode)) *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 ...interface{})
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.
The name must be something other than the usual Printf() to avoid "go vet" warnings due to our custom format specifiers.
func (*TrackedBuffer) ParsedQuery ¶
func (buf *TrackedBuffer) ParsedQuery() *ParsedQuery
ParsedQuery returns a ParsedQuery that contains bind locations for easy substitution.
func (*TrackedBuffer) WriteArg ¶
func (buf *TrackedBuffer) WriteArg(arg string)
WriteArg writes a value argument into the buffer along with tracking information for future substitutions. arg must contain the ":" or "::" prefix.
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 TupleEqualityList ¶
TupleEqualityList is for generating equality constraints for tables that have composite primary keys.
func (*TupleEqualityList) EncodeSQL ¶
func (tpl *TupleEqualityList) EncodeSQL(buf *bytes.Buffer)
EncodeSQL generates the where clause constraints for the tuple equality.
type UnaryExpr ¶
UnaryExpr represents a unary value expression.
func (*UnaryExpr) Format ¶
func (node *UnaryExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*UnaryExpr) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type Union ¶
type Union struct { Type string Left, Right SelectStatement OrderBy OrderBy Limit *Limit Lock string }
Union represents a UNION statement.
func (*Union) References ¶
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else TODO - write tests to confirm this works, for instance, do we need to deduplicate between left & right references? would that be an err?
func (*Union) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type Update ¶
type Update struct { Comments Comments TableExprs TableExprs Exprs UpdateExprs Where *Where OrderBy OrderBy Limit *Limit }
Update represents an UPDATE statement.
func (*Update) References ¶
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else TODO - finish this
func (*Update) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type UpdateExpr ¶
UpdateExpr represents an update expression.
func (*UpdateExpr) Format ¶
func (node *UpdateExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*UpdateExpr) WalkSubtree ¶
func (node *UpdateExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type UpdateExprs ¶
type UpdateExprs []*UpdateExpr
UpdateExprs represents a list of update expressions.
func (UpdateExprs) Format ¶
func (node UpdateExprs) Format(buf *TrackedBuffer)
Format formats the node.
func (UpdateExprs) WalkSubtree ¶
func (node UpdateExprs) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type Use ¶
type Use struct {
DBName TableIdent
}
Use represents a use statement.
func (*Use) References ¶
References returns a slice of the table names this statement refers to This was added by b5. TODO - determine weather this can be removed in favour of something else TODO - finish this
func (*Use) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type ValTuple ¶
type ValTuple Exprs
ValTuple represents a tuple of actual values.
func (ValTuple) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type Values ¶
type Values []ValTuple
Values represents a VALUES clause.
func (Values) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
type ValuesFuncExpr ¶
ValuesFuncExpr represents a function call.
func (*ValuesFuncExpr) Format ¶
func (node *ValuesFuncExpr) Format(buf *TrackedBuffer)
Format formats the node.
func (*ValuesFuncExpr) WalkSubtree ¶
func (node *ValuesFuncExpr) WalkSubtree(visit Visit) error
WalkSubtree walks the nodes of the subtree.
type Visit ¶
Visit defines the signature of a function that can be used to visit all nodes of a parse tree.
type When ¶
When represents a WHEN sub-expression.
func (*When) WalkSubtree ¶
WalkSubtree walks the nodes of the subtree.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
deps
|
|
cistring
Package cistring implements a case-insensitive string type.
|
Package cistring implements a case-insensitive string type. |
hack
Package hack gives you some efficient functionality at the cost of breaking some Go rules.
|
Package hack gives you some efficient functionality at the cost of breaking some Go rules. |
proto/query
Package query is a generated protocol buffer package.
|
Package query is a generated protocol buffer package. |
proto/topodata
Package topodata is a generated protocol buffer package.
|
Package topodata is a generated protocol buffer package. |
proto/vtrpc
Package vtrpc is a generated protocol buffer package.
|
Package vtrpc is a generated protocol buffer package. |
sqltypes
Package sqltypes implements interfaces and types that represent SQL values.
|
Package sqltypes implements interfaces and types that represent SQL values. |
Package event provides a reflect-based framework for low-frequency global dispatching of events, which are values of any arbitrary type, to a set of listener functions, which are usually registered by plugin packages during init().
|
Package event provides a reflect-based framework for low-frequency global dispatching of events, which are values of any arbitrary type, to a set of listener functions, which are usually registered by plugin packages during init(). |
syslogger
Package syslogger uses the event package to listen for any event that implements the Syslogger interface.
|
Package syslogger uses the event package to listen for any event that implements the Syslogger interface. |
Package hack gives you some efficient functionality at the cost of breaking some Go rules.
|
Package hack gives you some efficient functionality at the cost of breaking some Go rules. |
Package sqltypes implements interfaces and types that represent SQL values.
|
Package sqltypes implements interfaces and types that represent SQL values. |
Package tb exposes some handy traceback functionality buried in the runtime.
|
Package tb exposes some handy traceback functionality buried in the runtime. |
vt
|
|
proto/logutil
Package logutil is a generated protocol buffer package.
|
Package logutil is a generated protocol buffer package. |
proto/query
Package query is a generated protocol buffer package.
|
Package query is a generated protocol buffer package. |
proto/topodata
Package topodata is a generated protocol buffer package.
|
Package topodata is a generated protocol buffer package. |
proto/vtgate
Package vtgate is a generated protocol buffer package.
|
Package vtgate is a generated protocol buffer package. |
proto/vtgateservice
Package vtgateservice is a generated protocol buffer package.
|
Package vtgateservice is a generated protocol buffer package. |
proto/vtrpc
Package vtrpc is a generated protocol buffer package.
|
Package vtrpc is a generated protocol buffer package. |
vterrors
Package vterrors provides helpers for propagating internal errors through the Vitess system (including across RPC boundaries) in a structured way.
|
Package vterrors provides helpers for propagating internal errors through the Vitess system (including across RPC boundaries) in a structured way. |