Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Postgres FD Implementation
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Abuhujair Javed
Postgres FD Implementation
Commits
a7f85783
Commit
a7f85783
authored
Feb 21, 2000
by
Tom Lane
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update SELECT documentation to have a more thorough discussion
of LIMIT, and fix a few other glitches too.
parent
be05edd8
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
95 additions
and
49 deletions
+95
-49
doc/src/sgml/ref/select.sgml
doc/src/sgml/ref/select.sgml
+86
-41
doc/src/sgml/ref/select_into.sgml
doc/src/sgml/ref/select_into.sgml
+9
-8
No files found.
doc/src/sgml/ref/select.sgml
View file @
a7f85783
<!--
<!--
$Header: /cvsroot/pgsql/doc/src/sgml/ref/select.sgml,v 1.2
4 2000/01/27 18:11:25
tgl Exp $
$Header: /cvsroot/pgsql/doc/src/sgml/ref/select.sgml,v 1.2
5 2000/02/21 01:13:52
tgl Exp $
Postgres documentation
Postgres documentation
-->
-->
...
@@ -30,9 +30,9 @@ SELECT [ ALL | DISTINCT [ ON ( <replaceable class="PARAMETER">expression</replac
...
@@ -30,9 +30,9 @@ SELECT [ ALL | DISTINCT [ ON ( <replaceable class="PARAMETER">expression</replac
[ GROUP BY <replaceable class="PARAMETER">column</replaceable> [, ...] ]
[ GROUP BY <replaceable class="PARAMETER">column</replaceable> [, ...] ]
[ HAVING <replaceable class="PARAMETER">condition</replaceable> [, ...] ]
[ HAVING <replaceable class="PARAMETER">condition</replaceable> [, ...] ]
[ { UNION [ ALL ] | INTERSECT | EXCEPT } <replaceable class="PARAMETER">select</replaceable> ]
[ { UNION [ ALL ] | INTERSECT | EXCEPT } <replaceable class="PARAMETER">select</replaceable> ]
[ ORDER BY <replaceable class="PARAMETER">column</replaceable> [ ASC | DESC ] [, ...] ]
[ ORDER BY <replaceable class="PARAMETER">column</replaceable> [ ASC | DESC
| USING <replaceable class="PARAMETER">operator</replaceable>
] [, ...] ]
[ FOR UPDATE [ OF
class_name...
] ]
[ FOR UPDATE [ OF
<replaceable class="PARAMETER">class_name</replaceable> [, ...]
] ]
[ LIMIT { count | ALL } [ { OFFSET | , } count ]
]
LIMIT { <replaceable class="PARAMETER">count</replaceable> | ALL } [ { OFFSET | , } <replaceable class="PARAMETER">start</replaceable>
]
</synopsis>
</synopsis>
<refsect2 id="R2-SQL-SELECT-1">
<refsect2 id="R2-SQL-SELECT-1">
...
@@ -59,10 +59,10 @@ SELECT [ ALL | DISTINCT [ ON ( <replaceable class="PARAMETER">expression</replac
...
@@ -59,10 +59,10 @@ SELECT [ ALL | DISTINCT [ ON ( <replaceable class="PARAMETER">expression</replac
<listitem>
<listitem>
<para>
<para>
Specifies another name for a column or an expression using
Specifies another name for a column or an expression using
the AS clause.
<replaceable class="PARAMETER">name</replaceable>
the AS clause.
This name is primarily used to label the output
c
annot be used in the WHERE
c
olumn. The <replaceable class="PARAMETER">name</replaceable>
c
ondition. It can, however, be referenced in associated
c
annot be used in the WHERE, GROUP BY, or HAVING clauses.
ORDER BY or GROUP
BY clauses.
It can, however, be referenced in ORDER
BY clauses.
</para>
</para>
</listitem>
</listitem>
</varlistentry>
</varlistentry>
...
@@ -245,18 +245,19 @@ SELECT [ ALL | DISTINCT [ ON ( <replaceable class="PARAMETER">expression</replac
...
@@ -245,18 +245,19 @@ SELECT [ ALL | DISTINCT [ ON ( <replaceable class="PARAMETER">expression</replac
</para>
</para>
<para>
<para>
The UNION
clause
allows the result to be the collection of rows
The UNION
operator
allows the result to be the collection of rows
returned by the queries involved.
returned by the queries involved.
(See <xref linkend="sql-union" endterm="sql-union-title">.)
(See <xref linkend="sql-union" endterm="sql-union-title">.)
</para>
</para>
<para>
<para>
The INTERSECT
give
you the rows that are common to both queries.
The INTERSECT
operator gives
you the rows that are common to both queries.
(See <xref linkend="sql-intersect" endterm="sql-intersect-title">.)
(See <xref linkend="sql-intersect" endterm="sql-intersect-title">.)
</para>
</para>
<para>
<para>
The EXCEPT give you the rows in the upper query not in the lower query.
The EXCEPT operator gives you the rows returned by the first query but
not the second query.
(See <xref linkend="sql-except" endterm="sql-except-title">.)
(See <xref linkend="sql-except" endterm="sql-except-title">.)
</para>
</para>
...
@@ -266,8 +267,9 @@ SELECT [ ALL | DISTINCT [ ON ( <replaceable class="PARAMETER">expression</replac
...
@@ -266,8 +267,9 @@ SELECT [ ALL | DISTINCT [ ON ( <replaceable class="PARAMETER">expression</replac
</para>
</para>
<para>
<para>
The LIMIT clause allows control over which rows are
The LIMIT clause allows a subset of the rows produced by the query
returned by the query.
to be returned to the user.
(See <xref linkend="sql-limit" endterm="sql-limit-title">.)
</para>
</para>
<para>
<para>
...
@@ -395,15 +397,15 @@ ORDER BY <replaceable class="PARAMETER">column</replaceable> [ ASC | DESC ] [, .
...
@@ -395,15 +397,15 @@ ORDER BY <replaceable class="PARAMETER">column</replaceable> [ ASC | DESC ] [, .
of the column. This feature makes it possible to define an ordering
of the column. This feature makes it possible to define an ordering
on the basis of a column that does not have a proper name.
on the basis of a column that does not have a proper name.
This is never absolutely necessary because it is always possible
This is never absolutely necessary because it is always possible
assign a name
to assign a name to a calculated column using the AS clause, e.g.:
to a calculated column using the AS clause, e.g.:
<programlisting>
<programlisting>
SELECT title, date_prod + 1 AS newlen FROM films ORDER BY newlen;
SELECT title, date_prod + 1 AS newlen FROM films ORDER BY newlen;
</programlisting></para>
</programlisting></para>
<para>
<para>
From release 6.4 of PostgreSQL, the columns in the ORDER BY clause
From release 6.4 of PostgreSQL, it is also possible to ORDER BY
do not need to appear in the SELECT clause.
arbitrary expressions, including fields that do not appear in the
SELECT result list.
Thus the following statement is now legal:
Thus the following statement is now legal:
<programlisting>
<programlisting>
SELECT name FROM distributors ORDER BY code;
SELECT name FROM distributors ORDER BY code;
...
@@ -413,7 +415,9 @@ SELECT name FROM distributors ORDER BY code;
...
@@ -413,7 +415,9 @@ SELECT name FROM distributors ORDER BY code;
<para>
<para>
Optionally one may add the keyword DESC (descending)
Optionally one may add the keyword DESC (descending)
or ASC (ascending) after each column name in the ORDER BY clause.
or ASC (ascending) after each column name in the ORDER BY clause.
If not specified, ASC is assumed by default.
If not specified, ASC is assumed by default. Alternatively, a
specific ordering operator name may be specified. ASC is equivalent
to USING '<' and DESC is equivalent to USING '>'.
</para>
</para>
</refsect2>
</refsect2>
...
@@ -436,10 +440,10 @@ SELECT name FROM distributors ORDER BY code;
...
@@ -436,10 +440,10 @@ SELECT name FROM distributors ORDER BY code;
</para>
</para>
<para>
<para>
The UNION
clause
allows the result to be the collection of rows
The UNION
operator
allows the result to be the collection of rows
returned by the queries involved.
(See UNION clause).
returned by the queries involved.
The two
table
s that represent the direct operands of the UNION must
The two
SELECT
s that represent the direct operands of the UNION must
hav
e the same number of columns, and corresponding columns must be
produc
e the same number of columns, and corresponding columns must be
of compatible data types.
of compatible data types.
</para>
</para>
...
@@ -476,16 +480,15 @@ SELECT name FROM distributors ORDER BY code;
...
@@ -476,16 +480,15 @@ SELECT name FROM distributors ORDER BY code;
</para>
</para>
<para>
<para>
The INTERSECT clause allows the result to be all rows that are
The INTERSECT operator gives you the rows that are common to both queries.
common to the involved queries.
The two SELECTs that represent the direct operands of the INTERSECT must
The two tables that represent the direct operands of the INTERSECT must
produce the same number of columns, and corresponding columns must be
have the same number of columns, and corresponding columns must be
of compatible data types.
of compatible data types.
</para>
</para>
<para>
<para>
Multiple INTERSECT operators in the same SELECT statement are
Multiple INTERSECT operators in the same SELECT statement are
evaluated left to right.
evaluated left to right
, unless parentheses dictate otherwise
.
</para>
</para>
</refsect2>
</refsect2>
...
@@ -508,16 +511,65 @@ SELECT name FROM distributors ORDER BY code;
...
@@ -508,16 +511,65 @@ SELECT name FROM distributors ORDER BY code;
</para>
</para>
<para>
<para>
The EXCEPT
clause allows the result to be rows from the upper query
The EXCEPT
operator gives you the rows returned by the first query but
that are not in the lower query. (See EXCEPT clause)
.
not the second query
.
The two
table
s that represent the direct operands of the EXCEPT must
The two
SELECT
s that represent the direct operands of the EXCEPT must
hav
e the same number of columns, and corresponding columns must be
produc
e the same number of columns, and corresponding columns must be
of compatible data types.
of compatible data types.
</para>
</para>
<para>
<para>
Multiple EXCEPT operators in the same SELECT statement are
Multiple EXCEPT operators in the same SELECT statement are
evaluated left to right.
evaluated left to right, unless parentheses dictate otherwise.
</para>
</refsect2>
<refsect2 id="SQL-LIMIT">
<refsect2info>
<date>2000-02-20</date>
</refsect2info>
<title id="sql-limit-title">
LIMIT Clause
</title>
<para>
<synopsis>
LIMIT { <replaceable class="PARAMETER">count</replaceable> | ALL } [ { OFFSET | , } <replaceable class="PARAMETER">start</replaceable> ]
OFFSET <replaceable class="PARAMETER">start</replaceable>
</synopsis>
where
<replaceable class="PARAMETER">count</replaceable> specifies the
maximum number of rows to return, and
<replaceable class="PARAMETER">start</replaceable> specifies the
number of rows to skip before starting to return rows.
</para>
<para>
LIMIT allows you to retrieve just a portion of the rows that are generated
by the rest of the query. If a limit count is given, no more than that
many rows will be returned. If an offset is given, that many rows will
be skipped before starting to return rows.
</para>
<para>
When using LIMIT, it is a good idea to use an ORDER BY clause that
constrains the result rows into a unique order. Otherwise you will get
an unpredictable subset of the query's rows --- you may be asking for
the tenth through twentieth rows, but tenth through twentieth in what
ordering? You don't know what ordering, unless you specified ORDER BY.
</para>
<para>
As of Postgres 7.0, the
query optimizer takes LIMIT into account when generating a query plan,
so you are very likely to get different plans (yielding different row
orders) depending on what you give for LIMIT and OFFSET. Thus, using
different LIMIT/OFFSET values to select different subsets of a query
result <emphasis>will give inconsistent results</emphasis> unless
you enforce a predictable result ordering with ORDER BY. This is not
a bug; it is an inherent consequence of the fact that SQL does not
promise to deliver the results of a query in any particular order
unless ORDER BY is used to constrain the order.
</para>
</para>
</refsect2>
</refsect2>
</refsect1>
</refsect1>
...
@@ -624,7 +676,7 @@ SELECT * FROM distributors ORDER BY 2;
...
@@ -624,7 +676,7 @@ SELECT * FROM distributors ORDER BY 2;
This example shows how to obtain the union of the tables
This example shows how to obtain the union of the tables
<literal>distributors</literal> and
<literal>distributors</literal> and
<literal>actors</literal>, restricting the results to those that begin
<literal>actors</literal>, restricting the results to those that begin
with letter W in each table. Only distinct rows are
to be us
ed, so the
with letter W in each table. Only distinct rows are
want
ed, so the
ALL keyword is omitted:
ALL keyword is omitted:
<programlisting>
<programlisting>
...
@@ -709,16 +761,9 @@ SELECT distributors.* WHERE name = 'Westwood';
...
@@ -709,16 +761,9 @@ SELECT distributors.* WHERE name = 'Westwood';
parsing ambiguities
parsing ambiguities
in this context.</para>
in this context.</para>
<para>
In the <acronym>SQL92</acronym> standard, the new column name
specified in an
"AS" clause may be referenced in GROUP BY and HAVING clauses.
This is not currently
allowed in <productname>Postgres</productname>.
</para>
<para>
<para>
The DISTINCT ON phrase is not part of <acronym>SQL92</acronym>.
The DISTINCT ON phrase is not part of <acronym>SQL92</acronym>.
Nor are LIMIT and OFFSET.
</para>
</para>
</refsect3>
</refsect3>
...
...
doc/src/sgml/ref/select_into.sgml
View file @
a7f85783
<!--
<!--
$Header: /cvsroot/pgsql/doc/src/sgml/ref/select_into.sgml,v 1.
4 1999/07/22 15:09:14 thomas
Exp $
$Header: /cvsroot/pgsql/doc/src/sgml/ref/select_into.sgml,v 1.
5 2000/02/21 01:13:52 tgl
Exp $
Postgres documentation
Postgres documentation
-->
-->
...
@@ -22,16 +22,17 @@ Postgres documentation
...
@@ -22,16 +22,17 @@ Postgres documentation
<date>1999-07-20</date>
<date>1999-07-20</date>
</refsynopsisdivinfo>
</refsynopsisdivinfo>
<synopsis>
<synopsis>
SELECT [ ALL | DISTINCT ] <replaceable class="PARAMETER">expression</replaceable> [ AS <replaceable class="PARAMETER">name</replaceable> ] [, ...]
SELECT [ ALL | DISTINCT [ ON ( <replaceable class="PARAMETER">expression</replaceable> [, ...] ) ] ]
INTO [TEMP] [ TABLE ] <replaceable class="PARAMETER">new_table</replaceable> ]
<replaceable class="PARAMETER">expression</replaceable> [ AS <replaceable class="PARAMETER">name</replaceable> ] [, ...]
[ FROM <replaceable class="PARAMETER">table</replaceable> [<replaceable class="PARAMETER">alias</replaceable>] [, ...] ]
[ INTO [ TEMPORARY | TEMP ] [ TABLE ] <replaceable class="PARAMETER">new_table</replaceable> ]
[ FROM <replaceable class="PARAMETER">table</replaceable> [ <replaceable class="PARAMETER">alias</replaceable> ] [, ...] ]
[ WHERE <replaceable class="PARAMETER">condition</replaceable> ]
[ WHERE <replaceable class="PARAMETER">condition</replaceable> ]
[ GROUP BY <replaceable class="PARAMETER">column</replaceable> [, ...] ]
[ GROUP BY <replaceable class="PARAMETER">column</replaceable> [, ...] ]
[ HAVING <replaceable class="PARAMETER">condition</replaceable> [, ...] ]
[ HAVING <replaceable class="PARAMETER">condition</replaceable> [, ...] ]
[ { UNION [
ALL] | INTERSECT | EXCEPT } <replaceable class="PARAMETER">select</replaceable>
]
[ { UNION [
ALL ] | INTERSECT | EXCEPT } <replaceable class="PARAMETER">select</replaceable>
]
[ ORDER BY <replaceable class="PARAMETER">column</replaceable> [ ASC | DESC ] [, ...] ]
[ ORDER BY <replaceable class="PARAMETER">column</replaceable> [ ASC | DESC
| USING <replaceable class="PARAMETER">operator</replaceable>
] [, ...] ]
[ FOR UPDATE [
OF class_name...]
]
[ FOR UPDATE [
OF <replaceable class="PARAMETER">class_name</replaceable> [, ...] ]
]
[ LIMIT count [OFFSET|, count]
]
LIMIT { <replaceable class="PARAMETER">count</replaceable> | ALL } [ { OFFSET | , } <replaceable class="PARAMETER">start</replaceable>
]
</synopsis>
</synopsis>
<refsect2 id="R2-SQL-SELECTINTO-1">
<refsect2 id="R2-SQL-SELECTINTO-1">
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment