parser

package
v0.0.0-...-e3900cc Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 21, 2015 License: Apache-2.0 Imports: 18 Imported by: 0

Documentation

Index

Constants

View Source
const (
	IsNull = iota
	IsNotNull
	IsTrue
	IsNotTrue
	IsFalse
	IsNotFalse
	IsUnknown
	IsNotUnknown
)

IsExpr.Operator

View Source
const ABSOLUTE = 57358
View Source
const ACCESS = 57359
View Source
const ACTION = 57360
View Source
const ADD = 57361
View Source
const ADMIN = 57362
View Source
const AFTER = 57363
View Source
const AGGREGATE = 57364
View Source
const ALL = 57365
View Source
const ALSO = 57366
View Source
const ALTER = 57367
View Source
const ALWAYS = 57368
View Source
const ANALYSE = 57369
View Source
const ANALYZE = 57370
View Source
const AND = 57371
View Source
const ANY = 57372
View Source
const ARRAY = 57373
View Source
const AS = 57374
View Source
const ASC = 57375
View Source
const ASSERTION = 57376
View Source
const ASSIGNMENT = 57377
View Source
const ASYMMETRIC = 57378
View Source
const AT = 57379
View Source
const ATTRIBUTE = 57380
View Source
const AUTHORIZATION = 57381
View Source
const BACKWARD = 57382
View Source
const BCONST = 57349
View Source
const BEFORE = 57383
View Source
const BEGIN = 57384
View Source
const BETWEEN = 57385
View Source
const BIGINT = 57386
View Source
const BINARY = 57387
View Source
const BIT = 57388
View Source
const BLOB = 57389
View Source
const BOOL = 57390
View Source
const BOOLEAN = 57391
View Source
const BOTH = 57392
View Source
const BY = 57393
View Source
const BYTES = 57394
View Source
const CACHE = 57395
View Source
const CALLED = 57396
View Source
const CASCADE = 57397
View Source
const CASCADED = 57398
View Source
const CASE = 57399
View Source
const CAST = 57400
View Source
const CHAIN = 57401
View Source
const CHAR = 57402
View Source
const CHARACTER = 57403
View Source
const CHARACTERISTICS = 57404
View Source
const CHECK = 57405
View Source
const CHECKPOINT = 57406
View Source
const CLASS = 57407
View Source
const CLOSE = 57408
View Source
const CLUSTER = 57409
View Source
const COALESCE = 57410
View Source
const COLLATE = 57411
View Source
const COLLATION = 57412
View Source
const COLUMN = 57413
View Source
const COLUMNS = 57414
View Source
const COMMENT = 57415
View Source
const COMMENTS = 57416
View Source
const COMMIT = 57417
View Source
const COMMITTED = 57418
View Source
const CONCAT = 57419
View Source
const CONCURRENTLY = 57420
View Source
const CONFIGURATION = 57421
View Source
const CONFLICT = 57422
View Source
const CONNECTION = 57423
View Source
const CONSTRAINT = 57424
View Source
const CONSTRAINTS = 57425
View Source
const CONTENT = 57426
View Source
const CONTINUE = 57427
View Source
const CONVERSION = 57428
View Source
const COPY = 57429
View Source
const COST = 57430
View Source
const COVERING = 57431
View Source
const CREATE = 57432
View Source
const CROSS = 57433
View Source
const CSV = 57434
View Source
const CUBE = 57435
View Source
const CURRENT = 57436
View Source
const CURRENT_CATALOG = 57437
View Source
const CURRENT_DATE = 57438
View Source
const CURRENT_ROLE = 57439
View Source
const CURRENT_TIME = 57440
View Source
const CURRENT_TIMESTAMP = 57441
View Source
const CURRENT_USER = 57442
View Source
const CURSOR = 57443
View Source
const CYCLE = 57444
View Source
const DATA = 57445
View Source
const DATABASE = 57446
View Source
const DATABASES = 57447
View Source
const DATE = 57448
View Source
const DAY = 57449
View Source
const DEALLOCATE = 57450
View Source
const DEC = 57451
View Source
const DECIMAL = 57452
View Source
const DECLARE = 57453
View Source
const DEFAULT = 57454
View Source
const DEFAULTS = 57455
View Source
const DEFERRABLE = 57456
View Source
const DEFERRED = 57457
View Source
const DEFINER = 57458
View Source
const DELETE = 57459
View Source
const DELIMITER = 57460
View Source
const DELIMITERS = 57461
View Source
const DESC = 57462
View Source
const DICTIONARY = 57463
View Source
const DISABLE = 57464
View Source
const DISCARD = 57465
View Source
const DISTINCT = 57466
View Source
const DO = 57467
View Source
const DOMAIN = 57468
View Source
const DOT_DOT = 57353
View Source
const DOUBLE = 57469
View Source
const DROP = 57470
View Source
const EACH = 57471
View Source
const ELSE = 57472
View Source
const ENABLE = 57473
View Source
const ENCODING = 57474
View Source
const ENCRYPTED = 57475
View Source
const END = 57476
View Source
const ENUM = 57477
View Source
const ERROR = 57357
View Source
const ESCAPE = 57478
View Source
const EVENT = 57479
View Source
const EXCEPT = 57480
View Source
const EXCLUSIVE = 57481
View Source
const EXECUTE = 57482
View Source
const EXISTS = 57483
View Source
const EXPLAIN = 57484
View Source
const EXTENSION = 57485
View Source
const EXTERNAL = 57486
View Source
const EXTRACT = 57487
View Source
const FALSE = 57488
View Source
const FAMILY = 57489
View Source
const FCONST = 57347
View Source
const FETCH = 57490
View Source
const FILTER = 57491
View Source
const FIRST = 57492
View Source
const FLOAT = 57493
View Source
const FOLLOWING = 57494
View Source
const FOR = 57495
View Source
const FORCE = 57496
View Source
const FOREIGN = 57497
View Source
const FORWARD = 57498
View Source
const FREEZE = 57499
View Source
const FROM = 57500
View Source
const FULL = 57501
View Source
const FUNCTION = 57502
View Source
const FUNCTIONS = 57503
View Source
const GLOBAL = 57504
View Source
const GRANT = 57505
View Source
const GRANTED = 57506
View Source
const GRANTS = 57507
View Source
const GREATER_EQUALS = 57355
View Source
const GREATEST = 57508
View Source
const GROUP = 57509
View Source
const GROUPING = 57510
View Source
const HANDLER = 57511
View Source
const HAVING = 57512
View Source
const HEADER = 57513
View Source
const HOLD = 57514
View Source
const HOUR = 57515
View Source
const ICONST = 57350
View Source
const IDENT = 57346
View Source
const IDENTITY = 57516
View Source
const IF = 57517
View Source
const IMMEDIATE = 57518
View Source
const IMMUTABLE = 57519
View Source
const IMPLICIT = 57520
View Source
const IMPORT = 57521
View Source
const IN = 57522
View Source
const INCLUDING = 57523
View Source
const INCREMENT = 57524
View Source
const INDEX = 57525
View Source
const INDEXES = 57526
View Source
const INHERIT = 57527
View Source
const INHERITS = 57528
View Source
const INITIALLY = 57529
View Source
const INLINE = 57530
View Source
const INNER = 57531
View Source
const INOUT = 57532
View Source
const INPUT = 57533
View Source
const INSENSITIVE = 57534
View Source
const INSERT = 57535
View Source
const INSTEAD = 57536
View Source
const INT = 57537
View Source
const INT64 = 57538
View Source
const INTEGER = 57539
View Source
const INTERSECT = 57540
View Source
const INTERVAL = 57541
View Source
const INTO = 57542
View Source
const INVOKER = 57543
View Source
const IS = 57544
View Source
const ISOLATION = 57545
View Source
const JOIN = 57546
View Source
const KEY = 57547
View Source
const LABEL = 57548
View Source
const LANGUAGE = 57549
View Source
const LARGE = 57550
View Source
const LAST = 57551
View Source
const LATERAL = 57552
View Source
const LEADING = 57553
View Source
const LEAKPROOF = 57554
View Source
const LEAST = 57555
View Source
const LEFT = 57556
View Source
const LESS_EQUALS = 57354
View Source
const LEVEL = 57557
View Source
const LIKE = 57558
View Source
const LIMIT = 57559
View Source
const LISTEN = 57560
View Source
const LOAD = 57561
View Source
const LOCAL = 57562
View Source
const LOCALTIME = 57563
View Source
const LOCALTIMESTAMP = 57564
View Source
const LOCATION = 57565
View Source
const LOCK = 57566
View Source
const LOCKED = 57567
View Source
const LOGGED = 57568
View Source
const LSHIFT = 57569
View Source
const MAPPING = 57570
View Source
const MATCH = 57571
View Source
const MATERIALIZED = 57572
View Source
const MAXVALUE = 57573
View Source
const MINUTE = 57574
View Source
const MINVALUE = 57575
View Source
const MODE = 57576
View Source
const MONTH = 57577
View Source
const MOVE = 57578
View Source
const NAME = 57579
View Source
const NAMES = 57580
View Source
const NATIONAL = 57581
View Source
const NATURAL = 57582
View Source
const NCHAR = 57583
View Source
const NEXT = 57584
View Source
const NO = 57585
View Source
const NONE = 57586
View Source
const NOT = 57587
View Source
const NOTHING = 57588
View Source
const NOTIFY = 57589
View Source
const NOT_EQUALS = 57356
View Source
const NOT_LA = 57751
View Source
const NOWAIT = 57590
View Source
const NULL = 57591
View Source
const NULLIF = 57592
View Source
const NULLS = 57593
View Source
const NULLS_LA = 57752
View Source
const NUMERIC = 57594
View Source
const OBJECT = 57595
View Source
const OF = 57596
View Source
const OFF = 57597
View Source
const OFFSET = 57598
View Source
const OIDS = 57599
View Source
const ON = 57600
View Source
const ONLY = 57601
View Source
const OPTION = 57602
View Source
const OPTIONS = 57603
View Source
const OR = 57604
View Source
const ORDER = 57605
View Source
const ORDINALITY = 57606
View Source
const OUT = 57607
View Source
const OUTER = 57608
View Source
const OVER = 57609
View Source
const OVERLAPS = 57610
View Source
const OVERLAY = 57611
View Source
const OWNED = 57612
View Source
const OWNER = 57613
View Source
const PARAM = 57351
View Source
const PARSER = 57614
View Source
const PARTIAL = 57615
View Source
const PARTITION = 57616
View Source
const PASSING = 57617
View Source
const PASSWORD = 57618
View Source
const PLACING = 57619
View Source
const PLANS = 57620
View Source
const POLICY = 57621
View Source
const POSITION = 57622
View Source
const POSTFIXOP = 57754
View Source
const PRECEDING = 57623
View Source
const PRECISION = 57624
View Source
const PREPARE = 57626
View Source
const PREPARED = 57627
View Source
const PRESERVE = 57625
View Source
const PRIMARY = 57628
View Source
const PRIOR = 57629
View Source
const PRIVILEGES = 57630
View Source
const PROCEDURAL = 57631
View Source
const PROCEDURE = 57632
View Source
const PROGRAM = 57633
View Source
const QUOTE = 57634
View Source
const RANGE = 57635
View Source
const READ = 57636
View Source
const REAL = 57637
View Source
const REASSIGN = 57638
View Source
const RECHECK = 57639
View Source
const RECURSIVE = 57640
View Source
const REF = 57641
View Source
const REFERENCES = 57642
View Source
const REFRESH = 57643
View Source
const REINDEX = 57644
View Source
const RELATIVE = 57645
View Source
const RELEASE = 57646
View Source
const RENAME = 57647
View Source
const REPEATABLE = 57648
View Source
const REPLACE = 57649
View Source
const REPLICA = 57650
View Source
const RESET = 57651
View Source
const RESTART = 57652
View Source
const RESTRICT = 57653
View Source
const RETURNING = 57654
View Source
const RETURNS = 57655
View Source
const REVOKE = 57656
View Source
const RIGHT = 57657
View Source
const ROLLBACK = 57658
View Source
const ROLLUP = 57659
View Source
const ROW = 57660
View Source
const ROWS = 57661
View Source
const RSHIFT = 57662
View Source
const RULE = 57663
View Source
const SCONST = 57348
View Source
const SCROLL = 57664
View Source
const SEARCH = 57665
View Source
const SECOND = 57666
View Source
const SECURITY = 57667
View Source
const SELECT = 57668
View Source
const SEQUENCE = 57669
View Source
const SEQUENCES = 57670
View Source
const SERIALIZABLE = 57671
View Source
const SERVER = 57672
View Source
const SESSION = 57673
View Source
const SESSION_USER = 57674
View Source
const SET = 57675
View Source
const SETS = 57676
View Source
const SHARE = 57677
View Source
const SHOW = 57678
View Source
const SIMILAR = 57679
View Source
const SIMPLE = 57680
View Source
const SKIP = 57681
View Source
const SMALLINT = 57682
View Source
const SNAPSHOT = 57683
View Source
const SOME = 57684
View Source
const SQL = 57685
View Source
const STABLE = 57686
View Source
const STANDALONE = 57687
View Source
const STATEMENT = 57688
View Source
const STATISTICS = 57689
View Source
const STDIN = 57690
View Source
const STDOUT = 57691
View Source
const STORING = 57695
View Source
const STRICT = 57692
View Source
const STRING = 57693
View Source
const STRIP = 57694
View Source
const SUBSTRING = 57696
View Source
const SYMMETRIC = 57697
View Source
const SYSID = 57698
View Source
const SYSTEM = 57699
View Source
const TABLE = 57700
View Source
const TABLES = 57701
View Source
const TEXT = 57702
View Source
const THEN = 57703
View Source
const TIME = 57704
View Source
const TIMESTAMP = 57705
View Source
const TO = 57706
View Source
const TRAILING = 57707
View Source
const TRANSACTION = 57708
View Source
const TRANSFORM = 57709
View Source
const TREAT = 57710
View Source
const TRIGGER = 57711
View Source
const TRIM = 57712
View Source
const TRUE = 57713
View Source
const TRUNCATE = 57714
View Source
const TRUSTED = 57715
View Source
const TYPE = 57716
View Source
const TYPECAST = 57352
View Source
const TYPES = 57717
View Source
const (
	TimestampWithOffsetZoneFormat = "2006-01-02 15:04:05.999999999-07:00"
)

time.Time formats.

View Source
const UMINUS = 57755
View Source
const UNBOUNDED = 57718
View Source
const UNCOMMITTED = 57719
View Source
const UNENCRYPTED = 57720
View Source
const UNION = 57721
View Source
const UNIQUE = 57722
View Source
const UNKNOWN = 57723
View Source
const UNLISTEN = 57724
View Source
const UNLOGGED = 57725
View Source
const UNTIL = 57726
View Source
const UPDATE = 57727
View Source
const USER = 57728
View Source
const USING = 57729
View Source
const VACUUM = 57730
View Source
const VALID = 57731
View Source
const VALIDATE = 57732
View Source
const VALUE = 57733
View Source
const VALUES = 57734
View Source
const VARCHAR = 57735
View Source
const VARIADIC = 57736
View Source
const VARYING = 57737
View Source
const VERBOSE = 57738
View Source
const VERSION = 57739
View Source
const WHEN = 57740
View Source
const WHERE = 57741
View Source
const WINDOW = 57742
View Source
const WITH = 57743
View Source
const WITHIN = 57744
View Source
const WITHOUT = 57745
View Source
const WITH_LA = 57753
View Source
const WRAPPER = 57746
View Source
const WRITE = 57747
View Source
const YEAR = 57748
View Source
const YES = 57749
View Source
const ZONE = 57750

Variables

View Source
var (
	// DummyBool is a placeholder DBool value.
	DummyBool = DBool(false)
	// DummyInt is a placeholder DInt value.
	DummyInt = DInt(0)
	// DummyFloat is a placeholder DFloat value.
	DummyFloat = DFloat(0)
	// DummyString is a placeholder DString value.
	DummyString = DString("")
	// DummyBytes is a placeholder DBytes value.
	DummyBytes = DBytes("")
	// DummyDate is a placeholder DDate value.
	DummyDate = DDate{}
	// DummyTimestamp is a placeholder DTimestamp value.
	DummyTimestamp = DTimestamp{}
	// DummyInterval is a placeholder DInterval value.
	DummyInterval = DInterval{}
	// DummyTuple is a placeholder DTuple value.
	DummyTuple = DTuple{}

	// DNull is the NULL Datum.
	DNull = dNull{}
)

Functions

func ContainsVars

func ContainsVars(expr Expr) bool

ContainsVars returns true if the expression contains any variables.

func FillArgs

func FillArgs(stmt Statement, args Args) error

FillArgs replaces any placeholder nodes in the expression with arguments supplied with the query.

func SimilarEscape

func SimilarEscape(pattern string) string

SimilarEscape converts a SQL:2008 regexp pattern to POSIX style, so it can be used by our regexp engine.

func WalkStmt

func WalkStmt(v Visitor, stmt Statement)

WalkStmt walks the entire parsed stmt calling WalkExpr on each expression, and replacing each expression with the one returned by WalkExpr.

Types

type AliasedTableExpr

type AliasedTableExpr struct {
	Expr SimpleTableExpr
	As   Name
}

AliasedTableExpr represents a table expression coupled with an optional alias.

func (*AliasedTableExpr) String

func (node *AliasedTableExpr) String() string

type AlterTable

type AlterTable struct {
	IfExists bool
	Table    *QualifiedName
	Cmds     AlterTableCmds
}

AlterTable represents an ALTER TABLE statement.

func (*AlterTable) String

func (node *AlterTable) String() string

type AlterTableAddColumn

type AlterTableAddColumn struct {
	IfNotExists bool
	ColumnDef   *ColumnTableDef
	// contains filtered or unexported fields
}

AlterTableAddColumn represents an ADD COLUMN command.

func (*AlterTableAddColumn) String

func (node *AlterTableAddColumn) String() string

type AlterTableAddConstraint

type AlterTableAddConstraint struct {
	ConstraintDef ConstraintTableDef
}

AlterTableAddConstraint represents an ADD CONSTRAINT command.

func (*AlterTableAddConstraint) String

func (node *AlterTableAddConstraint) String() string

type AlterTableCmd

type AlterTableCmd interface {
	// contains filtered or unexported methods
}

AlterTableCmd represents a table modification operation.

type AlterTableCmds

type AlterTableCmds []AlterTableCmd

AlterTableCmds represents a list of table alterations.

func (AlterTableCmds) String

func (node AlterTableCmds) String() string

type AlterTableDropColumn

type AlterTableDropColumn struct {
	IfExists bool
	Column   string
	// contains filtered or unexported fields
}

AlterTableDropColumn represents a DROP COLUMN command.

func (*AlterTableDropColumn) String

func (node *AlterTableDropColumn) String() string

type AlterTableDropConstraint

type AlterTableDropConstraint struct {
	IfExists   bool
	Constraint string
}

AlterTableDropConstraint represents a DROP CONSTRAINT command.

func (*AlterTableDropConstraint) String

func (node *AlterTableDropConstraint) String() string

type AndExpr

type AndExpr struct {
	Left, Right Expr
}

AndExpr represents an AND expression.

func (*AndExpr) String

func (node *AndExpr) String() string

type Args

type Args interface {
	Arg(name string) (Datum, bool)
}

Args defines the interface for retrieving arguments. Return false for the second return value if the argument cannot be found.

type Array

type Array Exprs

Array represents an array constructor.

func (Array) String

func (node Array) String() string

type ArrayIndirection

type ArrayIndirection struct {
	Begin Expr
	End   Expr
}

ArrayIndirection represents "[<begin>:<end>]" in an indirection expression.

func (*ArrayIndirection) String

func (a *ArrayIndirection) String() string

type BeginTransaction

type BeginTransaction struct {
	Isolation IsolationLevel
}

BeginTransaction represents a BEGIN statement

func (*BeginTransaction) String

func (node *BeginTransaction) String() string

type BinaryExpr

type BinaryExpr struct {
	Operator    BinaryOp
	Left, Right Expr
	// contains filtered or unexported fields
}

BinaryExpr represents a binary value expression.

func (*BinaryExpr) String

func (node *BinaryExpr) String() string

type BinaryOp

type BinaryOp int

BinaryOp represents a binary operator.

const (
	Bitand BinaryOp = iota
	Bitor
	Bitxor
	Plus
	Minus
	Mult
	Div
	Mod
	Concat
	LShift
	RShift
)

BinaryExpr.Operator

func (BinaryOp) String

func (i BinaryOp) String() string

type BoolType

type BoolType struct {
	Name string
}

BoolType represents a BOOLEAN type.

func (*BoolType) String

func (node *BoolType) String() string

type BytesType

type BytesType struct {
	Name string
}

BytesType represents a BYTES or BLOB type.

func (*BytesType) String

func (node *BytesType) String() string

type CaseExpr

type CaseExpr struct {
	Expr  Expr
	Whens []*When
	Else  Expr
}

CaseExpr represents a CASE expression.

func (*CaseExpr) String

func (node *CaseExpr) String() string

type CastExpr

type CastExpr struct {
	Expr Expr
	Type ColumnType
}

CastExpr represents a CAST(expr AS type) expression.

func (*CastExpr) String

func (n *CastExpr) String() string

type ColumnDefault

type ColumnDefault struct {
	Expr Expr
}

ColumnDefault represents a DEFAULT clause for a column.

type ColumnQualification

type ColumnQualification interface {
	// contains filtered or unexported methods
}

ColumnQualification represents a constraint on a column.

type ColumnTableDef

type ColumnTableDef struct {
	Name        Name
	Type        ColumnType
	Nullable    Nullability
	PrimaryKey  bool
	Unique      bool
	DefaultExpr Expr
}

ColumnTableDef represents a column definition within a CREATE TABLE statement.

func (*ColumnTableDef) String

func (node *ColumnTableDef) String() string

type ColumnType

type ColumnType interface {
	fmt.Stringer
	// contains filtered or unexported methods
}

ColumnType represents a type in a column definition.

type CommitTransaction

type CommitTransaction struct{}

CommitTransaction represents a COMMIT statement.

func (*CommitTransaction) String

func (node *CommitTransaction) String() string

type ComparisonExpr

type ComparisonExpr struct {
	Operator    ComparisonOp
	Left, Right Expr
}

ComparisonExpr represents a two-value comparison expression.

func (*ComparisonExpr) String

func (node *ComparisonExpr) String() string

type ComparisonOp

type ComparisonOp int

ComparisonOp represents a binary operator.

const (
	EQ ComparisonOp = iota
	LT
	GT
	LE
	GE
	NE
	In
	NotIn
	Like
	NotLike
	SimilarTo
	NotSimilarTo
	IsDistinctFrom
	IsNotDistinctFrom
)

ComparisonExpr.Operator

func (ComparisonOp) String

func (i ComparisonOp) String() string

type ConstraintTableDef

type ConstraintTableDef interface {
	TableDef
	// contains filtered or unexported methods
}

ConstraintTableDef represents a constraint definition within a CREATE TABLE statement.

type CreateDatabase

type CreateDatabase struct {
	IfNotExists bool
	Name        Name
}

CreateDatabase represents a CREATE DATABASE statement.

func (*CreateDatabase) String

func (node *CreateDatabase) String() string

type CreateIndex

type CreateIndex struct {
	Name        Name
	Table       *QualifiedName
	Unique      bool
	IfNotExists bool
	Columns     NameList
	Storing     NameList
}

CreateIndex represents a CREATE INDEX statement.

func (*CreateIndex) String

func (node *CreateIndex) String() string

type CreateTable

type CreateTable struct {
	IfNotExists bool
	Table       *QualifiedName
	Defs        TableDefs
}

CreateTable represents a CREATE TABLE statement.

func (*CreateTable) String

func (node *CreateTable) String() string

type DBool

type DBool bool

DBool is the boolean Datum.

func (DBool) Compare

func (d DBool) Compare(other Datum) int

Compare implements the Datum interface.

func (DBool) IsMax

func (d DBool) IsMax() bool

IsMax implements the Datum interface.

func (DBool) IsMin

func (d DBool) IsMin() bool

IsMin implements the Datum interface.

func (DBool) Next

func (d DBool) Next() Datum

Next implements the Datum interface.

func (DBool) String

func (d DBool) String() string

func (DBool) Type

func (d DBool) Type() string

Type implements the Datum interface.

type DBytes

type DBytes string

DBytes is the bytes Datum. The underlying type is a string because we want the immutability, but this may contain arbitrary bytes.

func (DBytes) Compare

func (d DBytes) Compare(other Datum) int

Compare implements the Datum interface.

func (DBytes) IsMax

func (d DBytes) IsMax() bool

IsMax implements the Datum interface.

func (DBytes) IsMin

func (d DBytes) IsMin() bool

IsMin implements the Datum interface.

func (DBytes) Next

func (d DBytes) Next() Datum

Next implements the Datum interface.

func (DBytes) String

func (d DBytes) String() string

func (DBytes) Type

func (d DBytes) Type() string

Type implements the Datum interface.

type DDate

type DDate struct {
	time.Time
}

DDate is the date Datum.

func ParseDate

func ParseDate(s DString) (DDate, error)

ParseDate parses a date.

func (DDate) Compare

func (d DDate) Compare(other Datum) int

Compare implements the Datum interface.

func (DDate) IsMax

func (d DDate) IsMax() bool

IsMax implements the Datum interface.

func (DDate) IsMin

func (d DDate) IsMin() bool

IsMin implements the Datum interface.

func (DDate) Next

func (d DDate) Next() Datum

Next implements the Datum interface.

func (DDate) String

func (d DDate) String() string

func (DDate) Type

func (d DDate) Type() string

Type implements the Datum interface.

type DFloat

type DFloat float64

DFloat is the float Datum.

func (DFloat) Compare

func (d DFloat) Compare(other Datum) int

Compare implements the Datum interface.

func (DFloat) IsMax

func (d DFloat) IsMax() bool

IsMax implements the Datum interface.

func (DFloat) IsMin

func (d DFloat) IsMin() bool

IsMin implements the Datum interface.

func (DFloat) Next

func (d DFloat) Next() Datum

Next implements the Datum interface.

func (DFloat) String

func (d DFloat) String() string

func (DFloat) Type

func (d DFloat) Type() string

Type implements the Datum interface.

type DInt

type DInt int64

DInt is the int Datum.

func (DInt) Compare

func (d DInt) Compare(other Datum) int

Compare implements the Datum interface.

func (DInt) IsMax

func (d DInt) IsMax() bool

IsMax implements the Datum interface.

func (DInt) IsMin

func (d DInt) IsMin() bool

IsMin implements the Datum interface.

func (DInt) Next

func (d DInt) Next() Datum

Next implements the Datum interface.

func (DInt) String

func (d DInt) String() string

func (DInt) Type

func (d DInt) Type() string

Type implements the Datum interface.

type DInterval

type DInterval struct {
	time.Duration
}

DInterval is the interval Datum.

func (DInterval) Compare

func (d DInterval) Compare(other Datum) int

Compare implements the Datum interface.

func (DInterval) IsMax

func (d DInterval) IsMax() bool

IsMax implements the Datum interface.

func (DInterval) IsMin

func (d DInterval) IsMin() bool

IsMin implements the Datum interface.

func (DInterval) Next

func (d DInterval) Next() Datum

Next implements the Datum interface.

func (DInterval) Type

func (d DInterval) Type() string

Type implements the Datum interface.

type DReference

type DReference interface {
	Datum() Datum
}

DReference holds a pointer to a Datum. It is used as a level of indirection to replace QualifiedNames with a node whose value can change on each row.

type DString

type DString string

DString is the string Datum.

func (DString) Compare

func (d DString) Compare(other Datum) int

Compare implements the Datum interface.

func (DString) IsMax

func (d DString) IsMax() bool

IsMax implements the Datum interface.

func (DString) IsMin

func (d DString) IsMin() bool

IsMin implements the Datum interface.

func (DString) Next

func (d DString) Next() Datum

Next implements the Datum interface.

func (DString) String

func (d DString) String() string

func (DString) Type

func (d DString) Type() string

Type implements the Datum interface.

type DTimestamp

type DTimestamp struct {
	time.Time
}

DTimestamp is the timestamp Datum.

func ParseTimestamp

func ParseTimestamp(s DString) (DTimestamp, error)

ParseTimestamp parses the timestamp.

func (DTimestamp) Compare

func (d DTimestamp) Compare(other Datum) int

Compare implements the Datum interface.

func (DTimestamp) IsMax

func (d DTimestamp) IsMax() bool

IsMax implements the Datum interface.

func (DTimestamp) IsMin

func (d DTimestamp) IsMin() bool

IsMin implements the Datum interface.

func (DTimestamp) Next

func (d DTimestamp) Next() Datum

Next implements the Datum interface.

func (DTimestamp) String

func (d DTimestamp) String() string

TODO:(vivek) implement SET TIME ZONE to improve presentation.

func (DTimestamp) Type

func (d DTimestamp) Type() string

Type implements the Datum interface.

type DTuple

type DTuple []Datum

DTuple is the tuple Datum.

func (DTuple) Compare

func (d DTuple) Compare(other Datum) int

Compare implements the Datum interface.

func (DTuple) IsMax

func (d DTuple) IsMax() bool

IsMax implements the Datum interface.

func (DTuple) IsMin

func (d DTuple) IsMin() bool

IsMin implements the Datum interface.

func (DTuple) Len

func (d DTuple) Len() int

func (DTuple) Less

func (d DTuple) Less(i, j int) bool

func (DTuple) Next

func (d DTuple) Next() Datum

Next implements the Datum interface.

func (DTuple) String

func (d DTuple) String() string

func (DTuple) Swap

func (d DTuple) Swap(i, j int)

func (DTuple) Type

func (d DTuple) Type() string

Type implements the Datum interface.

type DateType

type DateType struct {
}

DateType represents a DATE type.

func (*DateType) String

func (node *DateType) String() string

type Datum

type Datum interface {
	Expr
	Type() string
	// Compare returns -1 if the receiver is less than other, 0 if receiver is
	// equal to other and +1 if receiver is greater than other.
	Compare(other Datum) int
	// Next returns the next datum. If the receiver is "a" and the returned datum
	// is "b", then "a < b" and no other datum will compare such that "a < c <
	// b".
	Next() Datum
	// IsMax returns true if the datum is equal to the maximum value the datum
	// type can hold.
	IsMax() bool
	// IsMin returns true if the datum is equal to the minimum value the datum
	// type can hold.
	IsMin() bool
}

A Datum holds either a bool, int64, float64, string or []Datum.

func EvalExpr

func EvalExpr(expr Expr) (Datum, error)

EvalExpr evaluates an SQL expression. Expression evaluation is a mostly straightforward walk over the parse tree. The only significant complexity is the handling of types and implicit conversions. See binOps and cmpOps for more details. Note that expression evaluation returns an error if certain node types are encountered: ValArg, QualifiedName or Subquery. These nodes should be replaced prior to expression evaluation by an appropriate WalkExpr. For example, ValArg should be replace by the argument passed from the client.

func TypeCheckExpr

func TypeCheckExpr(expr Expr) (Datum, error)

TypeCheckExpr type-checks an SQL expression. Expression checking is a mostly straightforward walk over the parse tree.

type DecimalType

type DecimalType struct {
	Name  string
	Prec  int
	Scale int
}

DecimalType represents a DECIMAL or NUMERIC type.

func (*DecimalType) String

func (node *DecimalType) String() string

type DefaultVal

type DefaultVal struct{}

DefaultVal represents the DEFAULT expression.

func (DefaultVal) String

func (node DefaultVal) String() string

type Delete

type Delete struct {
	Table TableExpr
	Where *Where
}

Delete represents a DELETE statement.

func (*Delete) String

func (node *Delete) String() string

type Direction

type Direction int

Direction for ordering results.

const (
	DefaultDirection Direction = iota
	Ascending
	Descending
)

Direction values.

func (Direction) String

func (d Direction) String() string

type DropDatabase

type DropDatabase struct {
	Name     Name
	IfExists bool
}

DropDatabase represents a DROP DATABASE statement.

func (*DropDatabase) String

func (node *DropDatabase) String() string

type DropIndex

type DropIndex struct {
	Names    QualifiedNames
	IfExists bool
}

DropIndex represents a DROP DATABASE statement.

func (*DropIndex) String

func (node *DropIndex) String() string

type DropTable

type DropTable struct {
	Names    QualifiedNames
	IfExists bool
}

DropTable represents a DROP TABLE statement.

func (*DropTable) String

func (node *DropTable) String() string

type ExistsExpr

type ExistsExpr struct {
	Subquery *Subquery
}

ExistsExpr represents an EXISTS expression.

func (*ExistsExpr) String

func (node *ExistsExpr) String() string

type Explain

type Explain struct {
	Options   []string
	Statement Statement
}

Explain represents an EXPLAIN statement.

func (*Explain) String

func (node *Explain) String() string

type Expr

type Expr interface {
	fmt.Stringer
	// contains filtered or unexported methods
}

Expr represents an expression.

func NormalizeAndTypeCheckExpr

func NormalizeAndTypeCheckExpr(expr Expr) (Expr, error)

NormalizeAndTypeCheckExpr is a combination of NormalizeExpr and TypeCheckExpr. It returns returns an error if either of NormalizeExpr or TypeCheckExpr return one, and otherwise returns the Expr returned by NormalizeExpr.

func NormalizeExpr

func NormalizeExpr(expr Expr) (Expr, error)

NormalizeExpr normalizes an expression, simplifying where possible, but guaranteeing that the result of evaluating the expression is unchanged. Example normalizations:

(a)                   -> a
ROW(a, b, c)          -> (a, b, c)
a = 1 + 1             -> a = 2
a + 1 = 2             -> a = 1
a BETWEEN b AND c     -> (a >= b) AND (a <= c)
a NOT BETWEEN b AND c -> (a < b) OR (a > c)

func ParseExpr

func ParseExpr(expr string, syntax Syntax) (Expr, error)

ParseExpr parses a sql expression.

func WalkExpr

func WalkExpr(v Visitor, expr Expr) Expr

WalkExpr traverses the nodes in an expression. It starts by calling v.Visit(expr, true). If the visitor returned by v.Visit(expr, true) is not nil it recursively calls WalkExpr on the children of the node returned by v.Visit(expr, true) and finishes with a call to v.Visit(expr, false).

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) String

func (node Exprs) String() string

type FloatType

type FloatType struct {
	Name string
	Prec int
}

FloatType represents a REAL, DOUBLE or FLOAT type.

func (*FloatType) String

func (node *FloatType) String() string

type FuncExpr

type FuncExpr struct {
	Name     *QualifiedName
	Distinct bool
	Exprs    Exprs
	// contains filtered or unexported fields
}

FuncExpr represents a function call.

func (*FuncExpr) String

func (node *FuncExpr) String() string

type Grant

type Grant struct {
	Privileges privilege.List
	Targets    TargetList
	Grantees   NameList
}

Grant represents a GRANT statement.

func (*Grant) String

func (node *Grant) String() string

type GroupBy

type GroupBy []Expr

GroupBy represents a GROUP BY clause.

func (GroupBy) String

func (node GroupBy) String() string

type IndexIndirection

type IndexIndirection Name

IndexIndirection represents ":<name>" in an indirection expression.

func (IndexIndirection) String

func (n IndexIndirection) String() string

type IndexTableDef

type IndexTableDef struct {
	Name    Name
	Columns NameList
	Storing NameList
}

IndexTableDef represents an index definition within a CREATE TABLE statement.

func (*IndexTableDef) String

func (node *IndexTableDef) String() string

type Indirection

type Indirection []IndirectionElem

Indirection represents an indirection expression composed of a series of indirection elements.

func (Indirection) String

func (i Indirection) String() string

type IndirectionElem

type IndirectionElem interface {
	String() string
	// contains filtered or unexported methods
}

IndirectionElem is a single element in an indirection expression.

type Insert

type Insert struct {
	Table   *QualifiedName
	Columns QualifiedNames
	Rows    SelectStatement
}

Insert represents an INSERT statement.

func (*Insert) DefaultValues

func (node *Insert) DefaultValues() bool

DefaultValues returns true iff only default values are being inserted.

func (*Insert) String

func (node *Insert) String() string

type IntType

type IntType struct {
	Name string
	N    int
}

IntType represents an INT, INTEGER, SMALLINT or BIGINT type.

func (*IntType) String

func (node *IntType) String() string

type IntVal

type IntVal int64

IntVal represents an integer.

func (IntVal) String

func (node IntVal) String() string

type IntervalType

type IntervalType struct {
}

IntervalType represents a INTERVAL type

func (*IntervalType) String

func (node *IntervalType) String() string

type IsExpr

type IsExpr struct {
	Operator IsOp
	Expr     Expr
}

IsExpr represents an IS {,NOT} {NULL,TRUE,FALSE,UNKNOWN} expression.

func (*IsExpr) String

func (node *IsExpr) String() string

type IsOfTypeExpr

type IsOfTypeExpr struct {
	Not   bool
	Expr  Expr
	Types []ColumnType
}

IsOfTypeExpr represents an IS {,NOT} OF (type_list) expression.

func (*IsOfTypeExpr) String

func (node *IsOfTypeExpr) String() string

type IsOp

type IsOp int

IsOp represents an IS expression operator.

func (IsOp) String

func (i IsOp) String() string

type IsolationLevel

type IsolationLevel int

IsolationLevel holds the isolation level for a transaction.

const (
	UnspecifiedIsolation IsolationLevel = iota
	SnapshotIsolation
	SerializableIsolation
)

IsolationLevel values

func (IsolationLevel) String

func (i IsolationLevel) String() string

type JoinCond

type JoinCond interface {
	// contains filtered or unexported methods
}

JoinCond represents a join condition.

type JoinTableExpr

type JoinTableExpr struct {
	Join  string
	Left  TableExpr
	Right TableExpr
	Cond  JoinCond
}

JoinTableExpr represents a TableExpr that's a JOIN operation.

func (*JoinTableExpr) String

func (node *JoinTableExpr) String() string

type Limit

type Limit struct {
	Offset, Count Expr
}

Limit represents a LIMIT clause.

func (*Limit) String

func (node *Limit) String() string

type Name

type Name string

A Name is an SQL identifier.

func (Name) String

func (n Name) String() string

String formats an SQL identifier, applying proper escaping rules.

type NameIndirection

type NameIndirection Name

NameIndirection represents ".<name>" in an indirection expression.

func (NameIndirection) String

func (n NameIndirection) String() string

type NameList

type NameList []string

A NameList is a list of identifier. TODO(tschottdorf): would be nicer to have []Name here but unless we want to introduce new types to the grammar, NameList([]string{...}) needs to work.

func (NameList) String

func (l NameList) String() string

String formats the contained names as a comma-separated, escaped string.

type NotExpr

type NotExpr struct {
	Expr Expr
}

NotExpr represents a NOT expression.

func (*NotExpr) String

func (node *NotExpr) String() string

type NotNullConstraint

type NotNullConstraint struct{}

NotNullConstraint represents NOT NULL on a column.

type NullConstraint

type NullConstraint struct{}

NullConstraint represents NULL on a column.

type Nullability

type Nullability int

Nullability represents either NULL, NOT NULL or an unspecified value (silent NULL).

const (
	NotNull Nullability = iota
	Null
	SilentNull
)

The values for NullType.

type NumVal

type NumVal string

NumVal represents a number.

func (NumVal) String

func (node NumVal) String() string

type OnJoinCond

type OnJoinCond struct {
	Expr Expr
}

OnJoinCond represents an ON join condition.

func (*OnJoinCond) String

func (node *OnJoinCond) String() string

type OrExpr

type OrExpr struct {
	Left, Right Expr
}

OrExpr represents an OR expression.

func (*OrExpr) String

func (node *OrExpr) String() string

type Order

type Order struct {
	Expr      Expr
	Direction Direction
}

Order represents an ordering expression.

func (*Order) String

func (node *Order) String() string

type OrderBy

type OrderBy []*Order

OrderBy represents an ORDER By clause.

func (OrderBy) String

func (node OrderBy) String() string

type ParenExpr

type ParenExpr struct {
	Expr Expr
}

ParenExpr represents a parenthesized expression.

func (*ParenExpr) String

func (node *ParenExpr) String() string

type ParenSelect

type ParenSelect struct {
	Select SelectStatement
}

ParenSelect represents a parenthesized SELECT/UNION/VALUES statement.

func (*ParenSelect) String

func (node *ParenSelect) String() string

type ParenTableExpr

type ParenTableExpr struct {
	Expr TableExpr
}

ParenTableExpr represents a parenthesized TableExpr.

func (*ParenTableExpr) String

func (node *ParenTableExpr) String() string

type PrimaryKeyConstraint

type PrimaryKeyConstraint struct{}

PrimaryKeyConstraint represents NULL on a column.

type QualifiedName

type QualifiedName struct {
	Base     Name
	Indirect Indirection
	// contains filtered or unexported fields
}

QualifiedName is a base name and an optional indirection expression.

func StarExpr

func StarExpr() *QualifiedName

StarExpr is a convenience function that represents an unqualified "*".

func (*QualifiedName) Column

func (n *QualifiedName) Column() string

Column returns the column portion of the name. Note that the returned string is not quoted even if the name is a keyword.

func (*QualifiedName) Database

func (n *QualifiedName) Database() string

Database returns the database portion of the name. Note that the returned string is not quoted even if the name is a keyword.

func (*QualifiedName) Index

func (n *QualifiedName) Index() string

Index returns the index portion of the name. Note that the returned string is not quoted even if the name is a keyword.

func (*QualifiedName) IsStar

func (n *QualifiedName) IsStar() bool

IsStar returns true iff the qualified name contains matches "".* or table.*.

func (*QualifiedName) NormalizeColumnName

func (n *QualifiedName) NormalizeColumnName() error

NormalizeColumnName normalizes the qualified name to contain a table name as prefix, returning an error if unable to do so or if the name is not a valid column name (e.g. it contains too many indirections). If normalization occurred, the modified qualified name will have n.Base == "" to indicate no explicit table was specified. The incoming qualified name should have one of the following forms:

*
table.*
column
column[array-indirection]
table.column
table.column[array-indirection]

Note that "table" may be the empty string. On successful normalization the qualified name will have one of the forms:

table.*
table.column
table.column[array-indirection]

func (*QualifiedName) NormalizeTableName

func (n *QualifiedName) NormalizeTableName(database string) error

NormalizeTableName normalizes the qualified name to contain a database name as prefix, returning an error if unable to do so or if the name is not a valid table name (e.g. it contains an array indirection). The incoming qualified name should have one of the following forms:

table
database.table
table@index
database.table@index

On successful normalization, the qualified name will have the form:

database.table@index

func (*QualifiedName) String

func (n *QualifiedName) String() string

func (*QualifiedName) Table

func (n *QualifiedName) Table() string

Table returns the table portion of the name. Note that the returned string is not quoted even if the name is a keyword.

type QualifiedNames

type QualifiedNames []*QualifiedName

QualifiedNames represents a command separated list (see the String method) of qualified names.

func (QualifiedNames) String

func (n QualifiedNames) String() string

type RangeCond

type RangeCond struct {
	Not      bool
	Left     Expr
	From, To Expr
}

RangeCond represents a BETWEEN or a NOT BETWEEN expression.

func (*RangeCond) String

func (node *RangeCond) String() string

type RenameColumn

type RenameColumn struct {
	Table   *QualifiedName
	Name    Name
	NewName Name
	// IfExists refers to the table, not the column.
	IfExists bool
}

RenameColumn represents a RENAME COLUMN statement.

func (*RenameColumn) String

func (node *RenameColumn) String() string

type RenameDatabase

type RenameDatabase struct {
	Name    Name
	NewName Name
}

RenameDatabase represents a RENAME DATABASE statement.

func (*RenameDatabase) String

func (node *RenameDatabase) String() string

type RenameIndex

type RenameIndex struct {
	Name     *QualifiedName
	NewName  Name
	IfExists bool
}

RenameIndex represents a RENAME INDEX statement.

func (*RenameIndex) String

func (node *RenameIndex) String() string

type RenameTable

type RenameTable struct {
	Name     *QualifiedName
	NewName  *QualifiedName
	IfExists bool
}

RenameTable represents a RENAME TABLE statement.

func (*RenameTable) String

func (node *RenameTable) String() string

type Revoke

type Revoke struct {
	Privileges privilege.List
	Targets    TargetList
	Grantees   NameList
}

Revoke represents a REVOKE statements. PrivilegeList and TargetList are defined in grant.go

func (*Revoke) String

func (node *Revoke) String() string

type RollbackTransaction

type RollbackTransaction struct{}

RollbackTransaction represents a ROLLBACK statement.

func (*RollbackTransaction) String

func (node *RollbackTransaction) String() string

type Row

type Row Exprs

Row represents a parenthesized list of expressions. Similar to Tuple except in how it is textually represented.

func (Row) String

func (node Row) String() string

type Select

type Select struct {
	Distinct bool
	Exprs    SelectExprs
	From     TableExprs
	Where    *Where
	GroupBy  GroupBy
	Having   *Where
	OrderBy  OrderBy
	Limit    *Limit
	Lock     string
	// contains filtered or unexported fields
}

Select represents a SELECT statement.

func (*Select) String

func (node *Select) String() string

type SelectExpr

type SelectExpr struct {
	Expr Expr
	As   Name
}

SelectExpr represents a SELECT expression.

func StarSelectExpr

func StarSelectExpr() SelectExpr

StarSelectExpr is a convenience function that represents an unqualified "*" in a select expression.

func (SelectExpr) String

func (node SelectExpr) String() string

type SelectExprs

type SelectExprs []SelectExpr

SelectExprs represents SELECT expressions.

func (SelectExprs) String

func (node SelectExprs) String() string

type SelectStatement

type SelectStatement interface {
	Statement
	// contains filtered or unexported methods
}

SelectStatement any SELECT statement.

type Set

type Set struct {
	Name   *QualifiedName
	Values Exprs
}

Set represents a SET statement.

func (*Set) String

func (node *Set) String() string

type SetTransaction

type SetTransaction struct {
	Isolation IsolationLevel
}

SetTransaction represents a SET TRANSACTION statement.

func (*SetTransaction) String

func (node *SetTransaction) String() string

type Show

type Show struct {
	Name string
}

Show represents a SHOW statement.

func (*Show) String

func (node *Show) String() string

type ShowColumns

type ShowColumns struct {
	Table *QualifiedName
}

ShowColumns represents a SHOW COLUMNS statement.

func (*ShowColumns) String

func (node *ShowColumns) String() string

type ShowDatabases

type ShowDatabases struct {
}

ShowDatabases represents a SHOW DATABASES statement.

func (*ShowDatabases) String

func (node *ShowDatabases) String() string

type ShowGrants

type ShowGrants struct {
	Targets  *TargetList
	Grantees NameList
}

ShowGrants represents a SHOW GRANTS statement. TargetList is defined in grant.go.

func (*ShowGrants) String

func (node *ShowGrants) String() string

type ShowIndex

type ShowIndex struct {
	Table *QualifiedName
}

ShowIndex represents a SHOW INDEX statement.

func (*ShowIndex) String

func (node *ShowIndex) String() string

type ShowTables

type ShowTables struct {
	Name *QualifiedName
}

ShowTables represents a SHOW TABLES statement.

func (*ShowTables) String

func (node *ShowTables) String() string

type SimpleTableExpr

type SimpleTableExpr interface {
	// contains filtered or unexported methods
}

SimpleTableExpr represents a simple table expression.

type StarIndirection

type StarIndirection string

StarIndirection represents ".*" in an indirection expression.

func (StarIndirection) String

func (s StarIndirection) String() string

type Statement

type Statement interface {
	fmt.Stringer
	// contains filtered or unexported methods
}

Statement represents a statement.

type StatementList

type StatementList []Statement

StatementList is a list of statements.

func Parse

func Parse(sql string, syntax Syntax) (StatementList, error)

Parse parses the sql and returns a list of statements.

func ParseTraditional

func ParseTraditional(sql string) (StatementList, error)

ParseTraditional is short-hand for Parse(sql, Traditional)

func (StatementList) String

func (l StatementList) String() string

type StringType

type StringType struct {
	Name string
	N    int
}

StringType represents a STRING, CHAR or VARCHAR type.

func (*StringType) String

func (node *StringType) String() string

type Subquery

type Subquery struct {
	Select SelectStatement
}

Subquery represents a subquery.

func (*Subquery) String

func (node *Subquery) String() string

type Syntax

type Syntax int

Syntax is an enum of the various syntax types.

const (
	Traditional Syntax = iota
	Modern
)

func (Syntax) String

func (i Syntax) String() string

type TableDef

type TableDef interface {
	// contains filtered or unexported methods
}

TableDef represents a column or index definition within a CREATE TABLE statement.

type TableDefs

type TableDefs []TableDef

TableDefs represents a list of table definitions.

func (TableDefs) String

func (node TableDefs) String() string

type TableExpr

type TableExpr interface {
	// contains filtered or unexported methods
}

TableExpr represents a table expression.

type TableExprs

type TableExprs []TableExpr

TableExprs represents a list of table expressions.

func (TableExprs) String

func (node TableExprs) String() string

type TargetList

type TargetList struct {
	Databases NameList
	Tables    QualifiedNames
}

TargetList represents a list of targets. Only one field may be non-nil.

func (TargetList) String

func (tl TargetList) String() string

type TargetType

type TargetType int

TargetType represents the type of target.

const (
	TargetDatabase TargetType = iota
)

Enums for target and privilege types.

func (TargetType) String

func (tt TargetType) String() string

type TimestampType

type TimestampType struct {
}

TimestampType represents a TIMESTAMP type.

func (*TimestampType) String

func (node *TimestampType) String() string

type Truncate

type Truncate struct {
	Tables QualifiedNames
}

Truncate represents a TRUNCATE statement.

func (*Truncate) String

func (node *Truncate) String() string

type Tuple

type Tuple Exprs

Tuple represents a parenthesized list of expressions.

func (Tuple) String

func (node Tuple) String() string

type UnaryExpr

type UnaryExpr struct {
	Operator UnaryOp
	Expr     Expr
	// contains filtered or unexported fields
}

UnaryExpr represents a unary value expression.

func (*UnaryExpr) String

func (node *UnaryExpr) String() string

type UnaryOp

type UnaryOp int

UnaryOp represents a unary operator.

const (
	UnaryPlus UnaryOp = iota
	UnaryMinus
	UnaryComplement
)

UnaryExpr.Operator

func (UnaryOp) String

func (i UnaryOp) String() string

type Union

type Union struct {
	Type        string
	Left, Right SelectStatement
	All         bool
}

Union represents a UNION statement.

func (*Union) String

func (node *Union) String() string

type UniqueConstraint

type UniqueConstraint struct{}

UniqueConstraint represents UNIQUE on a column.

type UniqueConstraintTableDef

type UniqueConstraintTableDef struct {
	IndexTableDef
	PrimaryKey bool
}

UniqueConstraintTableDef represents a unique constraint within a CREATE TABLE statement.

func (*UniqueConstraintTableDef) String

func (node *UniqueConstraintTableDef) String() string

type Update

type Update struct {
	Table TableExpr
	Exprs UpdateExprs
	Where *Where
}

Update represents an UPDATE statement.

func (*Update) String

func (node *Update) String() string

type UpdateExpr

type UpdateExpr struct {
	Tuple bool
	Names QualifiedNames
	Expr  Expr
}

UpdateExpr represents an update expression.

func (*UpdateExpr) String

func (node *UpdateExpr) String() string

type UpdateExprs

type UpdateExprs []*UpdateExpr

UpdateExprs represents a list of update expressions.

func (UpdateExprs) String

func (node UpdateExprs) String() string

type UsingJoinCond

type UsingJoinCond struct {
	Cols NameList
}

UsingJoinCond represents a USING join condition.

func (*UsingJoinCond) String

func (node *UsingJoinCond) String() string

type ValArg

type ValArg string

ValArg represents a named bind var argument.

func (ValArg) String

func (node ValArg) String() string

type Values

type Values []Tuple

Values represents a VALUES clause.

func (Values) String

func (node Values) String() string

type Visitor

type Visitor interface {
	Visit(expr Expr, pre bool) (Visitor, Expr)
}

The Visitor Visit method is invoked for each Expr node encountered by WalkExpr. The returned Expr replaces the pointer to the visited expression in the parent node and can be used for rewriting expressions. The pre argument indicates whether the visit is a pre-order or post-order visit. On a pre-order visit, if the result Visitor is nil children nodes are skipped from the traversal.

type When

type When struct {
	Cond Expr
	Val  Expr
}

When represents a WHEN sub-expression.

func (*When) String

func (node *When) String() string

type Where

type Where struct {
	Type string
	Expr Expr
}

Where represents a WHERE or HAVING clause.

func (*Where) String

func (node *Where) String() string

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL