parser

package
v0.0.0-...-4b82dee Latest Latest
Warning

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

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

Documentation

Index

Constants

View Source
const ABORT = 57358
View Source
const ABSOLUTE = 57359
View Source
const ACCESS = 57360
View Source
const ACTION = 57361
View Source
const ADD = 57362
View Source
const ADMIN = 57363
View Source
const AFTER = 57364
View Source
const AGGREGATE = 57365
View Source
const ALL = 57366
View Source
const ALSO = 57367
View Source
const ALTER = 57368
View Source
const ALWAYS = 57369
View Source
const ANALYSE = 57370
View Source
const ANALYZE = 57371
View Source
const AND = 57372
View Source
const ANY = 57373
View Source
const ARRAY = 57374
View Source
const AS = 57375
View Source
const ASC = 57376
View Source
const ASSERTION = 57377
View Source
const ASSIGNMENT = 57378
View Source
const ASYMMETRIC = 57379
View Source
const AT = 57380
View Source
const ATTRIBUTE = 57381
View Source
const AUTHORIZATION = 57382
View Source
const BACKWARD = 57383
View Source
const BCONST = 57349
View Source
const BEFORE = 57384
View Source
const BEGIN = 57385
View Source
const BETWEEN = 57386
View Source
const BIGINT = 57387
View Source
const BINARY = 57388
View Source
const BIT = 57389
View Source
const BLOB = 57390
View Source
const BOOL = 57391
View Source
const BOOLEAN = 57392
View Source
const BOTH = 57393
View Source
const BY = 57394
View Source
const BYTES = 57395
View Source
const CACHE = 57396
View Source
const CALLED = 57397
View Source
const CASCADE = 57398
View Source
const CASCADED = 57399
View Source
const CASE = 57400
View Source
const CAST = 57401
View Source
const CHAIN = 57402
View Source
const CHAR = 57403
View Source
const CHARACTER = 57404
View Source
const CHARACTERISTICS = 57405
View Source
const CHECK = 57406
View Source
const CHECKPOINT = 57407
View Source
const CLASS = 57408
View Source
const CLOSE = 57409
View Source
const CLUSTER = 57410
View Source
const COALESCE = 57411
View Source
const COLLATE = 57412
View Source
const COLLATION = 57413
View Source
const COLUMN = 57414
View Source
const COLUMNS = 57415
View Source
const COMMENT = 57416
View Source
const COMMENTS = 57417
View Source
const COMMIT = 57418
View Source
const COMMITTED = 57419
View Source
const CONCAT = 57420
View Source
const CONCURRENTLY = 57421
View Source
const CONFIGURATION = 57422
View Source
const CONFLICT = 57423
View Source
const CONNECTION = 57424
View Source
const CONSTRAINT = 57425
View Source
const CONSTRAINTS = 57426
View Source
const CONTENT = 57427
View Source
const CONTINUE = 57428
View Source
const CONVERSION = 57429
View Source
const COPY = 57430
View Source
const COST = 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 EXCLUDE = 57481
View Source
const EXCLUDING = 57482
View Source
const EXCLUSIVE = 57483
View Source
const EXECUTE = 57484
View Source
const EXISTS = 57485
View Source
const EXPLAIN = 57486
View Source
const EXTENSION = 57487
View Source
const EXTERNAL = 57488
View Source
const EXTRACT = 57489
View Source
const FALSE = 57490
View Source
const FAMILY = 57491
View Source
const FCONST = 57347
View Source
const FETCH = 57492
View Source
const FILTER = 57493
View Source
const FIRST = 57494
View Source
const FLOAT = 57495
View Source
const FOLLOWING = 57496
View Source
const FOR = 57497
View Source
const FORCE = 57498
View Source
const FOREIGN = 57499
View Source
const FORWARD = 57500
View Source
const FREEZE = 57501
View Source
const FROM = 57502
View Source
const FULL = 57503
View Source
const FUNCTION = 57504
View Source
const FUNCTIONS = 57505
View Source
const GLOBAL = 57506
View Source
const GRANT = 57507
View Source
const GRANTED = 57508
View Source
const GRANTS = 57509
View Source
const GREATER_EQUALS = 57355
View Source
const GREATEST = 57510
View Source
const GROUP = 57511
View Source
const GROUPING = 57512
View Source
const HANDLER = 57513
View Source
const HAVING = 57514
View Source
const HEADER = 57515
View Source
const HOLD = 57516
View Source
const HOUR = 57517
View Source
const ICONST = 57350
View Source
const IDENT = 57346
View Source
const IDENTITY = 57518
View Source
const IF = 57519
View Source
const IMMEDIATE = 57520
View Source
const IMMUTABLE = 57521
View Source
const IMPLICIT = 57522
View Source
const IMPORT = 57523
View Source
const IN = 57524
View Source
const INCLUDING = 57525
View Source
const INCREMENT = 57526
View Source
const INDEX = 57527
View Source
const INDEXES = 57528
View Source
const INHERIT = 57529
View Source
const INHERITS = 57530
View Source
const INITIALLY = 57531
View Source
const INLINE = 57532
View Source
const INNER = 57533
View Source
const INOUT = 57534
View Source
const INPUT = 57535
View Source
const INSENSITIVE = 57536
View Source
const INSERT = 57537
View Source
const INSTEAD = 57538
View Source
const INT = 57539
View Source
const INT64 = 57540
View Source
const INTEGER = 57541
View Source
const INTERSECT = 57542
View Source
const INTERVAL = 57543
View Source
const INTO = 57544
View Source
const INVOKER = 57545
View Source
const IS = 57546
View Source
const ISOLATION = 57547
View Source
const JOIN = 57548
View Source
const KEY = 57549
View Source
const LABEL = 57550
View Source
const LANGUAGE = 57551
View Source
const LARGE = 57552
View Source
const LAST = 57553
View Source
const LATERAL = 57554
View Source
const LEADING = 57555
View Source
const LEAKPROOF = 57556
View Source
const LEAST = 57557
View Source
const LEFT = 57558
View Source
const LESS_EQUALS = 57354
View Source
const LEVEL = 57559
View Source
const LIKE = 57560
View Source
const LIMIT = 57561
View Source
const LISTEN = 57562
View Source
const LOAD = 57563
View Source
const LOCAL = 57564
View Source
const LOCALTIME = 57565
View Source
const LOCALTIMESTAMP = 57566
View Source
const LOCATION = 57567
View Source
const LOCK = 57568
View Source
const LOCKED = 57569
View Source
const LOGGED = 57570
View Source
const LSHIFT = 57571
View Source
const MAPPING = 57572
View Source
const MATCH = 57573
View Source
const MATERIALIZED = 57574
View Source
const MAXVALUE = 57575
View Source
const MINUTE = 57576
View Source
const MINVALUE = 57577
View Source
const MODE = 57578
View Source
const MONTH = 57579
View Source
const MOVE = 57580
View Source
const NAME = 57581
View Source
const NAMES = 57582
View Source
const NATIONAL = 57583
View Source
const NATURAL = 57584
View Source
const NCHAR = 57585
View Source
const NEXT = 57586
View Source
const NO = 57587
View Source
const NONE = 57588
View Source
const NOT = 57589
View Source
const NOTHING = 57590
View Source
const NOTIFY = 57591
View Source
const NOT_EQUALS = 57356
View Source
const NOT_LA = 57756
View Source
const NOWAIT = 57592
View Source
const NULL = 57593
View Source
const NULLIF = 57594
View Source
const NULLS = 57595
View Source
const NULLS_LA = 57757
View Source
const NUMERIC = 57596
View Source
const OBJECT = 57597
View Source
const OF = 57598
View Source
const OFF = 57599
View Source
const OFFSET = 57600
View Source
const OIDS = 57601
View Source
const ON = 57602
View Source
const ONLY = 57603
View Source
const OPTION = 57604
View Source
const OPTIONS = 57605
View Source
const OR = 57606
View Source
const ORDER = 57607
View Source
const ORDINALITY = 57608
View Source
const OUT = 57609
View Source
const OUTER = 57610
View Source
const OVER = 57611
View Source
const OVERLAPS = 57612
View Source
const OVERLAY = 57613
View Source
const OWNED = 57614
View Source
const OWNER = 57615
View Source
const PARAM = 57351
View Source
const PARSER = 57616
View Source
const PARTIAL = 57617
View Source
const PARTITION = 57618
View Source
const PASSING = 57619
View Source
const PASSWORD = 57620
View Source
const PLACING = 57621
View Source
const PLANS = 57622
View Source
const POLICY = 57623
View Source
const POSITION = 57624
View Source
const POSTFIXOP = 57759
View Source
const PRECEDING = 57625
View Source
const PRECISION = 57626
View Source
const PREPARE = 57628
View Source
const PREPARED = 57629
View Source
const PRESERVE = 57627
View Source
const PRIMARY = 57630
View Source
const PRIOR = 57631
View Source
const PRIVILEGES = 57632
View Source
const PROCEDURAL = 57633
View Source
const PROCEDURE = 57634
View Source
const PROGRAM = 57635
View Source
const QUOTE = 57636
View Source
const RANGE = 57637
View Source
const READ = 57638
View Source
const REAL = 57639
View Source
const REASSIGN = 57640
View Source
const RECHECK = 57641
View Source
const RECURSIVE = 57642
View Source
const REF = 57643
View Source
const REFERENCES = 57644
View Source
const REFRESH = 57645
View Source
const REINDEX = 57646
View Source
const RELATIVE = 57647
View Source
const RELEASE = 57648
View Source
const RENAME = 57649
View Source
const REPEATABLE = 57650
View Source
const REPLACE = 57651
View Source
const REPLICA = 57652
View Source
const RESET = 57653
View Source
const RESTART = 57654
View Source
const RESTRICT = 57655
View Source
const RETURNING = 57656
View Source
const RETURNS = 57657
View Source
const REVOKE = 57658
View Source
const RIGHT = 57659
View Source
const ROLLBACK = 57660
View Source
const ROLLUP = 57661
View Source
const ROW = 57662
View Source
const ROWS = 57663
View Source
const RSHIFT = 57664
View Source
const RULE = 57665
View Source
const SAVEPOINT = 57666
View Source
const SCONST = 57348
View Source
const SCROLL = 57667
View Source
const SEARCH = 57668
View Source
const SECOND = 57669
View Source
const SECURITY = 57670
View Source
const SELECT = 57671
View Source
const SEQUENCE = 57672
View Source
const SEQUENCES = 57673
View Source
const SERIALIZABLE = 57674
View Source
const SERVER = 57675
View Source
const SESSION = 57676
View Source
const SESSION_USER = 57677
View Source
const SET = 57678
View Source
const SETOF = 57680
View Source
const SETS = 57679
View Source
const SHARE = 57681
View Source
const SHOW = 57682
View Source
const SIMILAR = 57683
View Source
const SIMPLE = 57684
View Source
const SKIP = 57685
View Source
const SMALLINT = 57686
View Source
const SNAPSHOT = 57687
View Source
const SOME = 57688
View Source
const SQL = 57689
View Source
const STABLE = 57690
View Source
const STANDALONE = 57691
View Source
const START = 57692
View Source
const STATEMENT = 57693
View Source
const STATISTICS = 57694
View Source
const STDIN = 57695
View Source
const STDOUT = 57696
View Source
const STRICT = 57697
View Source
const STRING = 57698
View Source
const STRIP = 57699
View Source
const SUBSTRING = 57700
View Source
const SYMMETRIC = 57701
View Source
const SYSID = 57702
View Source
const SYSTEM = 57703
View Source
const TABLE = 57704
View Source
const TABLES = 57705
View Source
const TEXT = 57706
View Source
const THEN = 57707
View Source
const TIME = 57708
View Source
const TIMESTAMP = 57709
View Source
const TO = 57710
View Source
const TRAILING = 57711
View Source
const TRANSACTION = 57712
View Source
const TRANSFORM = 57713
View Source
const TREAT = 57714
View Source
const TRIGGER = 57715
View Source
const TRIM = 57716
View Source
const TRUE = 57717
View Source
const TRUNCATE = 57718
View Source
const TRUSTED = 57719
View Source
const TYPE = 57720
View Source
const TYPECAST = 57352
View Source
const TYPES = 57721
View Source
const UMINUS = 57760
View Source
const UNBOUNDED = 57722
View Source
const UNCOMMITTED = 57723
View Source
const UNENCRYPTED = 57724
View Source
const UNION = 57725
View Source
const UNIQUE = 57726
View Source
const UNKNOWN = 57727
View Source
const UNLISTEN = 57728
View Source
const UNLOGGED = 57729
View Source
const UNTIL = 57730
View Source
const UPDATE = 57731
View Source
const USER = 57732
View Source
const USING = 57733
View Source
const VACUUM = 57734
View Source
const VALID = 57735
View Source
const VALIDATE = 57736
View Source
const VALUE = 57737
View Source
const VALUES = 57738
View Source
const VARCHAR = 57739
View Source
const VARIADIC = 57740
View Source
const VARYING = 57741
View Source
const VERBOSE = 57742
View Source
const VERSION = 57743
View Source
const WHEN = 57744
View Source
const WHERE = 57745
View Source
const WINDOW = 57746
View Source
const WITH = 57747
View Source
const WITHIN = 57748
View Source
const WITHOUT = 57749
View Source
const WITH_LA = 57758
View Source
const WORK = 57750
View Source
const WRAPPER = 57751
View Source
const WRITE = 57752
View Source
const YEAR = 57753
View Source
const YES = 57754
View Source
const ZONE = 57755

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("")
	// 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 FillArgs

func FillArgs(stmt Statement, args Args) error

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

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 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{}

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 BoolVal

type BoolVal bool

BoolVal represents a boolean.

func (BoolVal) String

func (node BoolVal) 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 BytesVal

type BytesVal string

BytesVal represents a string of unprintable value.

func (BytesVal) String

func (node BytesVal) 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 ColumnConstraint

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

ColumnConstraint represents a constraint on a column.

type ColumnTableDef

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

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
)

ComparisonExpr.Operator

func (ComparisonOp) String

func (i ComparisonOp) String() string

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
}

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 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 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 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 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
	PrimaryKey bool
	Unique     bool
	Columns    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) 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 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 NullCheck

type NullCheck struct {
	Not  bool
	Expr Expr
}

NullCheck represents an IS NULL or an IS NOT NULL expression.

func (*NullCheck) String

func (node *NullCheck) String() string

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 string
	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 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 StrVal

type StrVal string

StrVal represents a string value.

func (StrVal) String

func (node StrVal) 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
}

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 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 {
	Name *QualifiedName
	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