SELECT Syntax
- reference
This page enables you to drill down through the syntax of a SELECT query.
select-query ::= [ with-clause ] select
data:image/s3,"s3://crabby-images/01ba5/01ba5dfed59f4d08c6ab4372259ebd7c8ebad26a" alt="select query"
select ::= select-term [ set-op [ ALL ] select-term ]* [ order-by-clause | limit-clause | offset-clause ]
data:image/s3,"s3://crabby-images/75134/751348bb035aabb0ffbb2a281a64fad2b00fc30c" alt="select"
data:image/s3,"s3://crabby-images/b642f/b642f8d68010225aeeb877ce6bbf46784a904f5d" alt="select term"
subselect ::= select-from | from-select
data:image/s3,"s3://crabby-images/914e5/914e50377eebb88f0c0f8cd3413bed6648e88371" alt="subselect"
select-from ::= select-clause [ from-clause ] [ let-clause ] [ where-clause ] [ group-by-clause ] [ window-clause ]
data:image/s3,"s3://crabby-images/b2ead/b2eadcbb1608ef414ffb987b58fbfc04ffac7337" alt="select from"
from-select ::= from-clause [ let-clause ] [ where-clause ] [ group-by-clause ] [ window-clause ] select-clause
data:image/s3,"s3://crabby-images/ba378/ba3782c6ffdb7831e4d85c2f922a1245b35eee93" alt="from select"
set-op ::= UNION | INTERSECT | EXCEPT
data:image/s3,"s3://crabby-images/3b5bb/3b5bbf2edc046dcfbf5d5a035d3d4145ff525229" alt="set op"
WITH Clause
with-clause ::= WITH alias AS '(' ( select | expression ) ')' [ ',' alias AS '(' ( select | expression ) ')' ]*
data:image/s3,"s3://crabby-images/b5461/b5461149e8f3120dcbc6bf3d6607837ca2b22864" alt="with clause"
SELECT Clause
select-clause ::= SELECT [ ALL | DISTINCT ] ( result-expr [ , result-expr ]* | ( RAW | ELEMENT | VALUE ) expr [ [ AS ] alias ] )
data:image/s3,"s3://crabby-images/a3db4/a3db4af480f0dcb169c9229a8c6c1e8e621b92ff" alt="select clause"
FROM Clause
from-clause ::= FROM from-term
data:image/s3,"s3://crabby-images/a89b1/a89b13a37733c96ab91f0ea8e07eb932cbc890c8" alt="from clause"
from-term ::= from-keyspace | from-subquery | from-generic | join-clause | nest-clause | unnest-clause
data:image/s3,"s3://crabby-images/407e1/407e138874399a851fa66007c69bf973ebd9dbe0" alt="from-keyspace | from-subquery | from-generic | join-clause | nest-clause | unnest-clause"
from-keyspace ::= keyspace-ref [ [ AS ] alias ] [ use-clause ]
data:image/s3,"s3://crabby-images/eb5c4/eb5c49996117732200c978e2d16df499f4cdb5ba" alt="from keyspace"
keyspace-ref ::= keyspace-path | keyspace-partial
data:image/s3,"s3://crabby-images/78d74/78d744fbcbb772a8a65190828d961316ed93d0df" alt="keyspace-path | keyspace-partial"
keyspace-path ::= [ namespace ':' ] bucket [ '.' scope '.' collection ]
data:image/s3,"s3://crabby-images/e91b0/e91b092c3f64efc936d1a6d161da71927b6cce74" alt="( namespace ':' )? bucket ( '.' scope '.' collection )?"
keyspace-partial ::= collection
data:image/s3,"s3://crabby-images/58504/585048825a5403b472335d4a35e1d7fd99d5ce11" alt="collection"
namespace ::= identifier
data:image/s3,"s3://crabby-images/a7105/a71051812c9975ba946c614ebb6c8de99fb18822" alt="namespace"
bucket ::= identifier
data:image/s3,"s3://crabby-images/71325/71325afd861b8631fe6d4bbf7bb703746bae6a6e" alt="keyspace"
scope ::= identifier
data:image/s3,"s3://crabby-images/71325/71325afd861b8631fe6d4bbf7bb703746bae6a6e" alt="keyspace"
collection ::= identifier
data:image/s3,"s3://crabby-images/71325/71325afd861b8631fe6d4bbf7bb703746bae6a6e" alt="keyspace"
from-subquery ::= subquery-expr [ AS ] alias
data:image/s3,"s3://crabby-images/b883c/b883ceddb41ef196e9e00caa196cdf8c17d2470b" alt="select expr"
subquery-expr ::= '(' select ')'
data:image/s3,"s3://crabby-images/897e4/897e472335a253525858a256b0ea8a4ed918ea81" alt="subquery expr"
data:image/s3,"s3://crabby-images/9b5f9/9b5f97c2c10920f630755fea506ba4602a37f4fe" alt="generic expr"
JOIN Clause
join-clause ::= from-term ( ansi-join-clause | lookup-join-clause | index-join-clause )
data:image/s3,"s3://crabby-images/9d289/9d289578456d7590f65ce7882d0e363e3b5c04af" alt="join clause"
ANSI JOIN
ansi-join-clause ::= [ ansi-join-type ] JOIN ansi-join-rhs [ ansi-join-hints ] ansi-join-predicate
data:image/s3,"s3://crabby-images/45788/457885c26f8b7d2115f1ba00a27b1aecc0940c23" alt="ansi-join-type? 'JOIN' ansi-join-rhs ansi-join-hints? ansi-join-predicate"
ansi-join-type ::= INNER | ( LEFT [ OUTER ] ) | ( RIGHT [ OUTER ] )
data:image/s3,"s3://crabby-images/cf942/cf9428f69139c704f9c64ebd79d4998427ae3c42" alt="ansi join type"
ansi-join-rhs ::= rhs-keyspace | rhs-subquery | rhs-generic
data:image/s3,"s3://crabby-images/7d491/7d491b9115896f61ae975d8dc6007d3d2e419750" alt="rhs-keyspace | rhs-subquery | rhs-generic"
rhs-keyspace ::= keyspace-ref [ [ AS ] alias ]
data:image/s3,"s3://crabby-images/140fe/140feee21cbd4b13240977c19e3660da1248e451" alt="keyspace-ref ( 'AS'? alias )?"
rhs-subquery ::= subquery-expr [ AS ] alias
data:image/s3,"s3://crabby-images/1e0ae/1e0ae55a74b9ff9877dbe270858000e31bd0f47f" alt="subquery-expr 'AS'? alias"
data:image/s3,"s3://crabby-images/ce3b0/ce3b0f45d10dca75558932d265c49b1939d4d07b" alt="expr 'AS'? alias"
ansi-join-hints ::= use-hash-hint | use-nl-hint | multiple-hints
data:image/s3,"s3://crabby-images/6b01a/6b01a90062ecd283078946da9d0b5226b0729088" alt="ansi join hints"
use-hash-hint ::= USE use-hash-term
data:image/s3,"s3://crabby-images/cdbdc/cdbdcff2a7a59d33a6fdcc276255125e4b804687" alt="use hash hint"
use-hash-term ::= HASH '(' ( BUILD | PROBE ) ')'
data:image/s3,"s3://crabby-images/09200/09200e0569895ac0455c29a95759f6589ac06c62" alt="use hash term"
use-nl-hint ::= USE use-nl-term
data:image/s3,"s3://crabby-images/b9e8f/b9e8f8f38389aa6b93efcfc0d1b9992aabea8150" alt="use nl hint"
use-nl-term ::= NL
data:image/s3,"s3://crabby-images/cb76e/cb76eebfa1aca5056644efd55bd3cbe2d41ecbde" alt="use nl term"
multiple-hints ::= USE ( ansi-hint-terms other-hint-terms ) | ( other-hint-terms ansi-hint-terms )
data:image/s3,"s3://crabby-images/b5812/b5812ceed3c575e29fe31789b4a4318da790dca2" alt="multiple hints"
ansi-hint-terms ::= use-hash-term | use-nl-term
data:image/s3,"s3://crabby-images/b3ee1/b3ee18593350ab2f35d19f811ad788c99bd069b1" alt="ansi hint terms"
other-hint-terms ::= use-index-term | use-keys-term
data:image/s3,"s3://crabby-images/84f9b/84f9bcadf54d58992cd399b8adc557865fbf0190" alt="other hint terms"
ansi-join-predicate ::= ON expr
data:image/s3,"s3://crabby-images/38390/38390dbb5d73d3ad77354cbadd4a4b52eaa7fb7f" alt="ansi join predicate"
Lookup JOIN
lookup-join-clause ::= [ lookup-join-type ] JOIN lookup-join-rhs lookup-join-predicate
data:image/s3,"s3://crabby-images/8e340/8e34093e68cbdd89830246e07e8c00530903da65" alt="lookup-join-type? 'JOIN' lookup-join-rhs lookup-join-predicate"
lookup-join-type ::= INNER | ( LEFT [ OUTER ] )
data:image/s3,"s3://crabby-images/d2547/d2547e27d7105dd81b913f35ebecb2c01a654a02" alt="lookup join type"
lookup-join-rhs ::= keyspace-ref [ [ AS ] alias ]
data:image/s3,"s3://crabby-images/140fe/140feee21cbd4b13240977c19e3660da1248e451" alt="keyspace-ref ( 'AS'? alias )?"
lookup-join-predicate ::= ON [ PRIMARY ] KEYS expr
data:image/s3,"s3://crabby-images/56516/56516e6e1e7ce74f3fc74f505901fe3b3c0ba7ac" alt="lookup join predicate"
Index JOIN
index-join-clause ::= [ index-join-type ] JOIN index-join-rhs index-join-predicate
data:image/s3,"s3://crabby-images/9427c/9427c422456cc0a2015888addb58110e56822068" alt="index-join-type? 'JOIN' index-join-rhs index-join-predicate"
index-join-type ::= INNER | ( LEFT [ OUTER ] )
data:image/s3,"s3://crabby-images/d2057/d205737b6925a4b83a35956bfc6d2248b54d7840" alt="index join type"
index-join-rhs ::= keyspace-ref [ [ AS ] alias ]
data:image/s3,"s3://crabby-images/140fe/140feee21cbd4b13240977c19e3660da1248e451" alt="keyspace-ref ( 'AS'? alias )?"
data:image/s3,"s3://crabby-images/e5d6a/e5d6a4a8d8336c62909340983c0c9a114e48aef2" alt="index join predicate"
NEST Clause
nest-clause ::= from-term ( ansi-nest-clause | lookup-nest-clause | index-nest-clause )
data:image/s3,"s3://crabby-images/98ac5/98ac5955e7970d8b682e64fb896cb5ae15493b8a" alt="nest clause"
ANSI NEST
ansi-nest-clause ::= [ ansi-nest-type ] NEST ansi-nest-rhs ansi-nest-predicate
data:image/s3,"s3://crabby-images/d2f58/d2f58cf86b2a782df47ece8a8ea04a8c05209507" alt="ansi-nest-type? 'NEST' ansi-nest-rhs ansi-nest-predicate"
ansi-nest-type ::= INNER | ( LEFT [ OUTER ] )
data:image/s3,"s3://crabby-images/6d4c5/6d4c582ffe39a2b17aa1a055ccad0fa6741de72e" alt="ansi nest type"
ansi-nest-rhs ::= keyspace-ref [ [ AS ] alias ]
data:image/s3,"s3://crabby-images/140fe/140feee21cbd4b13240977c19e3660da1248e451" alt="keyspace-ref ( 'AS'? alias )?"
ansi-nest-predicate ::= ON expr
data:image/s3,"s3://crabby-images/b5df2/b5df20c3eb4a06c127ad4e15fdcbd93ff7c834db" alt="ansi nest predicate"
Lookup NEST
lookup-nest-clause ::= [ lookup-nest-type ] NEST lookup-nest-rhs lookup-nest-predicate
data:image/s3,"s3://crabby-images/2e5fe/2e5feec2fa8a6febd75c7c19157032222ae715ef" alt="lookup-nest-type? 'NEST' lookup-nest-rhs lookup-nest-predicate"
lookup-nest-type ::= INNER | ( LEFT [ OUTER ] )
data:image/s3,"s3://crabby-images/65660/656604f7d68116cd591b074f1be5f2d99b5e4591" alt="lookup nest type"
lookup-nest-rhs ::= keyspace-ref [ [ AS ] alias ]
data:image/s3,"s3://crabby-images/140fe/140feee21cbd4b13240977c19e3660da1248e451" alt="keyspace-ref ( 'AS'? alias )?"
lookup-nest-predicate ::= ON KEYS expr
data:image/s3,"s3://crabby-images/3d138/3d1381cd66570e519e9eae7a35a6d1c7d676fa62" alt="lookup nest predicate"
Index NEST
index-nest-clause ::= [ index-nest-type ] NEST index-nest-rhs index-nest-predicate
data:image/s3,"s3://crabby-images/6c2c3/6c2c3725b2ccd2caad4fb82018215522a46275e3" alt="index-nest-type? 'NEST' index-nest-rhs index-nest-predicate"
index-nest-type ::= INNER | ( LEFT [ OUTER ] )
data:image/s3,"s3://crabby-images/57127/57127e793aaec7434c7d08104714c98220a22b53" alt="index nest type"
index-nest-rhs ::= keyspace-ref [ [ AS ] alias ]
data:image/s3,"s3://crabby-images/140fe/140feee21cbd4b13240977c19e3660da1248e451" alt="keyspace-ref ( 'AS'? alias )?"
data:image/s3,"s3://crabby-images/640bc/640bc8b6ae28743fc9408d1bc49f109db41770b2" alt="index nest predicate"
UNNEST Clause
unnest-clause ::= from-term [ unnest-type ] ( UNNEST | FLATTEN ) expr [ [ AS ] alias ]
data:image/s3,"s3://crabby-images/83cbd/83cbd6d980784063795e5e990104c13e58f89a2a" alt="unnest clause"
unnest-type ::= INNER | ( LEFT [ OUTER ] )
data:image/s3,"s3://crabby-images/c196b/c196b84bddc16aa81e493137a45db2e7ef53acd3" alt="unnest type"
USE Clause
use-clause ::= use-keys-clause | use-index-clause
data:image/s3,"s3://crabby-images/c24e2/c24e2f3a329169bda899faeb103c3c4fe1c75a07" alt="use clause"
use-keys-clause ::= USE use-keys-term
data:image/s3,"s3://crabby-images/b096f/b096f2e16e7a4b1a8116d53d94e0ff153a8739fb" alt="use keys clause"
use-keys-term ::= [ PRIMARY ] KEYS expr
data:image/s3,"s3://crabby-images/11118/11118326269ddfdef166c05990f66b5474f19a4d" alt="use keys term"
use-index-clause ::= USE use-index-term
data:image/s3,"s3://crabby-images/35e4c/35e4cb953546de4baa27e5ef1465aa6926f0538d" alt="use index clause"
data:image/s3,"s3://crabby-images/ad34a/ad34a0705b3e2c6397efea074d518d9687c9a238" alt="use index term"
index-ref ::= [ index-name ] [ index-type ]
data:image/s3,"s3://crabby-images/64abe/64abe8010fd07e8bd93c5964dd58f072a3e837cf" alt="index ref"
index-name ::= identifier
data:image/s3,"s3://crabby-images/dd24c/dd24c7a61dcb0ee6881897b6220bf2b54c30e8e4" alt="index name"
index-type ::= USING ( GSI | FTS )
data:image/s3,"s3://crabby-images/8fc67/8fc678a8926fed67ca0f98ad0ee99b3a42439448" alt="'USING' ( 'GSI' | 'FTS' )"
GROUP BY Clause
group-by-clause ::= GROUP BY expr [ ',' expr ]* [ letting-clause ] [ having-clause ] | letting-clause
data:image/s3,"s3://crabby-images/021a3/021a3d3834f53ad327fd740786f57259b6b2b8eb" alt="group by clause"
data:image/s3,"s3://crabby-images/4f898/4f898d9481eaaaaadb4bd418f27361d3138a4c44" alt="letting clause"
having-clause ::= HAVING cond
data:image/s3,"s3://crabby-images/77fb1/77fb1e27bfa41c30397b8e90bf259408861eeca0" alt="having clause"
WINDOW Clause
window-clause ::= WINDOW window-declaration [ ',' window-declaration ]*
data:image/s3,"s3://crabby-images/438e6/438e6783591be1d82c713bc1815953c7dc80a996" alt="window clause"
window-declaration ::= window-name AS '(' window-definition ')'
data:image/s3,"s3://crabby-images/e504b/e504b3c12470f2a55a61f5d2b77b277a5df27012" alt="window declaration"
window-name ::= identifier
data:image/s3,"s3://crabby-images/d1b81/d1b81c05592799ea6c1e17fdee483d5dc179a0a6" alt="window name"
window-definition ::= [ window-ref ] [ window-partition-clause ] [ window-order-clause ] [ window-frame-clause ]
data:image/s3,"s3://crabby-images/9e433/9e433d9dc2636848dbc1ee727bffa7b651544ecc" alt="window definition"
window-ref ::= identifier
data:image/s3,"s3://crabby-images/412fe/412fef6c05a9384735a6a7817d3803d691a61b83" alt="window ref"
data:image/s3,"s3://crabby-images/8b2be/8b2be102edc732942e566618e4da1d2087f20458" alt="window partition clause"
window-order-clause ::= ORDER BY ordering-term [ ',' ordering-term ]*
data:image/s3,"s3://crabby-images/f012c/f012c5486616f3026376858a9ae72826d649ae7b" alt="window order clause"
window-frame-clause ::= ( ROWS | RANGE | GROUPS ) window-frame-extent [ window-frame-exclusion ]
data:image/s3,"s3://crabby-images/5d95f/5d95f923bbf9362f8812c36232b5955da89ea5b0" alt="window frame clause"
data:image/s3,"s3://crabby-images/2ec83/2ec83b6704eb0ae80d89db324778bbb5e1034969" alt="window frame extent"
window-frame-exclusion ::= EXCLUDE ( CURRENT ROW | GROUP | TIES | NO OTHERS )
data:image/s3,"s3://crabby-images/798a8/798a8036805fa3d9b194a6b38d0fb19b00656859" alt="window frame exclusion"
ORDER BY Clause
order-by-clause ::= ORDER BY ordering-term [ ',' ordering-term ]*
data:image/s3,"s3://crabby-images/2aada/2aadaf662c4d6318a0d11e7cd1e1c50992531c03" alt="order by clause"
ordering-term::= expr [ ASC | DESC ] [ NULLS ( FIRST | LAST ) ]
data:image/s3,"s3://crabby-images/cdd07/cdd0765f84bad5dc3324177cd89eef5968fa2f93" alt="ordering term"
LIMIT Clause
limit-clause ::= LIMIT expr
data:image/s3,"s3://crabby-images/210fc/210fc19008860a8e1baba3c8385b30450fae2fb7" alt="limit clause"
OFFSET Clause
offset-clause ::= OFFSET expr
data:image/s3,"s3://crabby-images/e553e/e553ef662e5f1ccf99c33f1169e444858e06612d" alt="offset clause"