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
3674ccdf
Commit
3674ccdf
authored
Mar 14, 1998
by
Bruce Momjian
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Change Postgres95 to PostgreSQL. Update CLUSTER manual page.
parent
12429af0
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
51 additions
and
25 deletions
+51
-25
contrib/pginterface/Makefile
contrib/pginterface/Makefile
+2
-2
doc/libpgtcl.doc
doc/libpgtcl.doc
+1
-1
src/bin/pg_dump/README
src/bin/pg_dump/README
+2
-2
src/bin/pg_dump/pg_dump.c
src/bin/pg_dump/pg_dump.c
+2
-2
src/bin/pg_dump/pg_dump.h
src/bin/pg_dump/pg_dump.h
+2
-2
src/interfaces/libpgtcl/README
src/interfaces/libpgtcl/README
+2
-3
src/interfaces/libpq++/README
src/interfaces/libpq++/README
+4
-4
src/interfaces/python/tutorial/basics.py
src/interfaces/python/tutorial/basics.py
+1
-1
src/man/cluster.l
src/man/cluster.l
+34
-7
src/test/regress/sql/create_index.sql
src/test/regress/sql/create_index.sql
+1
-1
No files found.
contrib/pginterface/Makefile
View file @
3674ccdf
...
...
@@ -4,8 +4,8 @@
#
PGINTERFACE
=
pginterface.o halt.o
TARGET
=
pginsert pgwordcount pgnulltest
CFLAGS
=
-g
-Wall
-I
/u
/postgres95
/include
LDFLAGS
=
-L
/u
/postgres95
/lib
-lpq
CFLAGS
=
-g
-Wall
-I
/u
sr/local/pgsql
/include
LDFLAGS
=
-L
/u
sr/local/pgsql
/lib
-lpq
all
:
$(TARGET)
...
...
doc/libpgtcl.doc
View file @
3674ccdf
pgtcl is a tcl package for front-end programs to interface with Postgre
s95
pgtcl is a tcl package for front-end programs to interface with Postgre
SQL
backends. PgTcl does not use the libpq library but communicates to
the backend directly via the frontend-backend protocol. Thus, it is
more efficient than previous postgres->tcl bindings which are layered
...
...
src/bin/pg_dump/README
View file @
3674ccdf
...
...
@@ -11,9 +11,9 @@ To build:
% gmake clean install
This version of the program will read in your postgre
s95
database and
This version of the program will read in your postgre
SQL
database and
output the schema and the data tuples in SQL. The dumps are useful
for moving from one postgre
s95
installation to another.
for moving from one postgre
SQL
installation to another.
How to use pg_dump:
...
...
src/bin/pg_dump/pg_dump.c
View file @
3674ccdf
...
...
@@ -21,7 +21,7 @@
*
*
* IDENTIFICATION
* $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_dump.c,v 1.6
4 1998/02/26 04:38:54
momjian Exp $
* $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_dump.c,v 1.6
5 1998/03/14 21:57:22
momjian Exp $
*
* Modifications - 6/10/96 - dave@bensoft.com - version 1.13.dhb
*
...
...
@@ -2681,7 +2681,7 @@ dumpIndices(FILE *fout, IndInfo *indinfo, int numIndices,
*
* We only need to do this for POSTGRES 4.2 databases since the
* COPY TO statment doesn't escape newlines properly. It's been fixed
* in Postgre
s95
.
* in Postgre
SQL
.
*
* the attrmap passed in tells how to map the attributes copied in to the
* attributes copied out
...
...
src/bin/pg_dump/pg_dump.h
View file @
3674ccdf
...
...
@@ -5,7 +5,7 @@
*
* Copyright (c) 1994, Regents of the University of California
*
* $Id: pg_dump.h,v 1.3
0 1998/02/26 04:39:01
momjian Exp $
* $Id: pg_dump.h,v 1.3
1 1998/03/14 21:57:26
momjian Exp $
*
* Modifications - 6/12/96 - dave@bensoft.com - version 1.13.dhb.2
*
...
...
@@ -176,7 +176,7 @@ extern char g_opaque_type[10]; /* name for the opaque type */
/* pg_dump is really two programs in one
one version works with postgres v4r2
and the other works with postgre
s95
and the other works with postgre
SQL
the common routines are declared here
*/
/*
...
...
src/interfaces/libpgtcl/README
View file @
3674ccdf
libpgtcl is a library that implements Tcl commands for front-end
clients to interact with the Postgres95 backend. See libpgtcl.doc for
details.
libpgtcl is a library that implements Tcl commands for front-end clients
to interact with the PostgreSQL backend. See libpgtcl.doc for details.
For an example of how to build a new tclsh to use libpgtcl, see the
directory ../bin/pgtclsh
...
...
src/interfaces/libpq++/README
View file @
3674ccdf
This directory contains libpq++, the C++ language interface to POSTGRES
95
.
This directory contains libpq++, the C++ language interface to POSTGRES
QL
.
libpq++ is implemented on of the libpq library. Users would benefit
from reading the chapter on libpq in the
postgres95
users manual
from reading the chapter on libpq in the
PostgreSQL
users manual
before using libpq++.
The initial version of this implementation was done by William Wanders
...
...
@@ -8,8 +8,8 @@ The initial version of this implementation was done by William Wanders
This is only a preliminary attempt at providing something useful for
people who would like to use C++ to build frontend applications to
postgres95
. The API provided herein is subject to change in later
versions of
postgres95
.
PostgreSQL
. The API provided herein is subject to change in later
versions of
PostgreSQL
.
For details on how to to use libpq++, see the man page in the man/
subdirectory and the test programs in the examples/ subdirectory.
...
...
src/interfaces/python/tutorial/basics.py
View file @
3674ccdf
#! /usr/local/bin/python
# basics.py - basic SQL commands tutorial
# inspired from the Postgre
s95
tutorial
# inspired from the Postgre
SQL
tutorial
# adapted to Python 1995 by Pascal ANDRE
print
"__________________________________________________________________"
...
...
src/man/cluster.l
View file @
3674ccdf
.\" This is -*-nroff-*-
.\" XXX standard disclaimer belongs here....
.\" $Header: /cvsroot/pgsql/src/man/Attic/cluster.l,v 1.
4 1998/01/11 22:17:10
momjian Exp $
.\" $Header: /cvsroot/pgsql/src/man/Attic/cluster.l,v 1.
5 1998/03/14 21:57:56
momjian Exp $
.TH CLUSTER SQL 01/23/93 PostgreSQL PostgreSQL
.SH NAME
cluster - give storage clustering advice to Postgres
...
...
@@ -17,14 +17,42 @@ The index must already have been defined on
.IR classname.
.PP
When a class is clustered, it is physically reordered based on the index
information. The clustering is static. In other words,
if
the class is
updated,
it may become unclustere
d. No attempt is made to keep new
information. The clustering is static. In other words,
as
the class is
updated,
the changes are not cluster
d. No attempt is made to keep new
instances or updated tuples clustered. If desired, the user can
recluster manually by issuing the command again.
.PP
The table is actually copied to temporary table in index order,
then renamed back to the original name. For this reason, all
grant permissions and other indexes are lost when cluster is performed.
The table is actually copied to temporary table in index order, then
renamed back to the original name. For this reason, all grant
permissions and other indexes are lost when cluster is performed.
.PP
In cases where you are accessing single rows randomly within a table,
the actual order of the data in the heap table unimportant. However, if
you tend to access some data more than others, and there is an index
that groups them together, you will benefit from using the CLUSTER
command.
.PP
Another place CLUSTER is good is in cases where you use an index to pull
out several rows from a table. If you are requesting a range of indexed
values from a table, or a single indexed value that has multiple rows
that match, CLUSTER will help because once the index identifies the heap
page for the first row that matches, all other rows that match are
probably already on the same heap page, saving disk accesses and speeding up
the query.
.PP
There are two ways to cluster data. The first is with the CLUSTER
command, which reoreders the original table with the ordering of the
index you specify. This can be slow on large tables because the rows
are fetched from the heap in index order, and if the heap table is
unordered, the entries are on random pages, so there is one disk page
retrieved for every row moved. PostgreSQL has a cache, but the majority
of a big table will not fit in the cache.
.PP
Another way is to use SELECT ... INTO TABLE temp FROM ... This uses the
PostgreSQL sorting code, and is much faster for unordered data. You
then drop the old table, use ALTER TABLE RENAME to rename 'temp' to the
old name, and recreate the indexes. From then on, CLUSTER should be
fast because most of the heap data is ordered.
.SH EXAMPLE
.nf
/*
...
...
@@ -34,4 +62,3 @@ create index emp_ind on emp using btree (salary int4_ops);
cluster emp_ind on emp
.fi
src/test/regress/sql/create_index.sql
View file @
3674ccdf
...
...
@@ -49,7 +49,7 @@ CREATE INDEX bt_f8_index ON bt_f8_heap USING btree (seqno float8_ops);
--
-- BTREE partial indices
-- partial indices are not supported in
postgres95
-- partial indices are not supported in
PostgreSQL
--
--CREATE INDEX onek2_u1_prtl ON onek2 USING btree(unique1 int4_ops)
-- where onek2.unique1 < 20 or onek2.unique1 > 980;
...
...
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