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
2539edc5
Commit
2539edc5
authored
Aug 08, 2004
by
Bruce Momjian
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
This adds a caveat to the inheritance part of the tutorial.
David Fetter
parent
0236b5e0
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
96 additions
and
13 deletions
+96
-13
doc/src/sgml/advanced.sgml
doc/src/sgml/advanced.sgml
+91
-10
doc/src/sgml/query.sgml
doc/src/sgml/query.sgml
+5
-3
No files found.
doc/src/sgml/advanced.sgml
View file @
2539edc5
<!--
<!--
$PostgreSQL: pgsql/doc/src/sgml/advanced.sgml,v 1.4
3 2004/08/07 19:53:48 tgl
Exp $
$PostgreSQL: pgsql/doc/src/sgml/advanced.sgml,v 1.4
4 2004/08/08 01:51:05 momjian
Exp $
-->
-->
<chapter id="tutorial-advanced">
<chapter id="tutorial-advanced">
...
@@ -108,7 +108,7 @@ CREATE TABLE cities (
...
@@ -108,7 +108,7 @@ CREATE TABLE cities (
);
);
CREATE TABLE weather (
CREATE TABLE weather (
city varchar(80) references cities,
city varchar(80) references cities
(city)
,
temp_lo int,
temp_lo int,
temp_hi int,
temp_hi int,
prcp real,
prcp real,
...
@@ -327,16 +327,97 @@ COMMIT;
...
@@ -327,16 +327,97 @@ COMMIT;
</indexterm>
</indexterm>
<para>
<para>
Inheritance is a concept from object-oriented databases. It opens
Inheritance is a concept from object-oriented databases. Although
up interesting new possibilities of database design.
it opens up interesting new possibilities of database design,
this feature is currently unmaintained and known to have serious
gotchas in its foreign key implementation, which you should take
care to avoid. The fixes below are probably version-specific and may
require updates in the future.
</para>
<para>
The example below illustrates the gotcha.
</para>
<para>
<programlisting>
BEGIN;
CREATE TABLE foo (
foo_id SERIAL PRIMARY KEY
);
CREATE TABLE parent (
parent_id SERIAL PRIMARY KEY
, foo_id INTEGER NOT NULL REFERENCES foo(foo_id) ON DELETE CASCADE
, parent_1_text TEXT NOT NULL
);
CREATE TABLE child_1 (
child_1_text TEXT NOT NULL
) INHERITS(parent);
CREATE TABLE child_2 (
child_2_text TEXT NOT NULL
) INHERITS(parent);
INSERT INTO foo VALUES(DEFAULT);
INSERT INTO child_1 (foo_id, parent_1_text, child_1_text)
VALUES (currval('public.foo_foo_id_seq'), 'parent text 1', 'child_1 text 1');
INSERT INTO foo VALUES(DEFAULT);
INSERT INTO child_1 (foo_id, parent_1_text, child_1_text)
VALUES (currval('public.foo_foo_id_seq'), 'parent text 2', 'child_1 text 2');
INSERT INTO foo VALUES(DEFAULT);
INSERT INTO child_2 (foo_id, parent_1_text, child_2_text)
VALUES (currval('foo_foo_id_seq'), 'parent text 3', 'child_2 text 1');
DELETE FROM foo WHERE foo_id = 1;
SELECT * FROM parent;
parent_id | foo_id | parent_1_text
-----------+--------+---------------
1 | 1 | parent text 1
2 | 2 | parent text 2
3 | 3 | parent text 3
(3 rows)
SELECT * FROM child_1;
parent_id | foo_id | parent_1_text | child_1_text
-----------+--------+---------------+----------------
1 | 1 | parent text 1 | child_1 text 1
2 | 2 | parent text 2 | child_1 text 2
(2 rows)
ROLLBACK;
</programlisting>
</para>
<para>
Oops!! None of parent, child or foo should have any rows with
foo_id = 1 in them. Here is a way to fix the above tables.
</para>
<para>
To fix the gotcha, you must put foreign key constraints on each of
the child tables, as they will not be automatically inherited as
you might expect.
</para>
<para>
<programlisting>
ALTER TABLE child_1 ADD CONSTRAINT cascade_foo
FOREIGN KEY (foo_id) REFERENCES foo(foo_id) ON DELETE CASCADE;
ALTER TABLE child_2 ADD CONSTRAINT cascade_foo
FOREIGN KEY (foo_id) REFERENCES foo(foo_id) ON DELETE CASCADE;
</programlisting>
</para>
</para>
<para>
<para>
Let's create two tables: A table <classname>cities</classname>
That caveat out of the way, let's create two tables: A table
and a table <classname>capitals</classname>. Naturally, capitals
<classname>cities</classname> and a table
are also cities, so you want some way to show the capitals
<classname>capitals</classname>. Naturally, capitals are also cities,
implicitly when you list all cities. If you're really clever you
so you want some way to show the capitals implicitly when you list all
might invent some scheme like this:
cities. If you're really clever you might invent some scheme like
this:
<programlisting>
<programlisting>
CREATE TABLE capitals (
CREATE TABLE capitals (
...
@@ -359,7 +440,7 @@ CREATE VIEW cities AS
...
@@ -359,7 +440,7 @@ CREATE VIEW cities AS
</programlisting>
</programlisting>
This works OK as far as querying goes, but it gets ugly when you
This works OK as far as querying goes, but it gets ugly when you
need to update several rows,
to name
one thing.
need to update several rows,
for
one thing.
</para>
</para>
<para>
<para>
...
...
doc/src/sgml/query.sgml
View file @
2539edc5
<!--
<!--
$PostgreSQL: pgsql/doc/src/sgml/query.sgml,v 1.3
5 2003/11/29 19:51:37 pgsql
Exp $
$PostgreSQL: pgsql/doc/src/sgml/query.sgml,v 1.3
6 2004/08/08 01:51:05 momjian
Exp $
-->
-->
<chapter id="tutorial-sql">
<chapter id="tutorial-sql">
...
@@ -284,8 +284,10 @@ COPY weather FROM '/home/user/weather.txt';
...
@@ -284,8 +284,10 @@ COPY weather FROM '/home/user/weather.txt';
<programlisting>
<programlisting>
SELECT * FROM weather;
SELECT * FROM weather;
</programlisting>
</programlisting>
(here <literal>*</literal> means <quote>all columns</quote>) and
(here <literal>*</literal> means <quote>all columns</quote>.
the output should be:
Note: While <literal>SELECT *</literal> is useful for off-the-cuff
queries, it is considered bad style in production code for
maintenance reasons) and the output should be:
<screen>
<screen>
city | temp_lo | temp_hi | prcp | date
city | temp_lo | temp_hi | prcp | date
---------------+---------+---------+------+------------
---------------+---------+---------+------+------------
...
...
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