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
69789bf3
Commit
69789bf3
authored
Jan 05, 2000
by
Thomas G. Lockhart
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update format to add uniform headers on files.
Update output to new psql conventions.
parent
9c1b2981
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
333 additions
and
279 deletions
+333
-279
src/test/regress/output/constraints.source
src/test/regress/output/constraints.source
+260
-221
src/test/regress/output/copy.source
src/test/regress/output/copy.source
+33
-21
src/test/regress/output/create_function_1.source
src/test/regress/output/create_function_1.source
+21
-24
src/test/regress/output/create_function_2.source
src/test/regress/output/create_function_2.source
+19
-13
No files found.
src/test/regress/output/constraints.source
View file @
69789bf3
QUERY: CREATE TABLE DEFAULT_TBL (i int DEFAULT 100,
--
-- CONSTRAINTS
-- Constraints can be specified with:
-- - DEFAULT clause
-- - CHECK clauses
-- - PRIMARY KEY clauses
-- - UNIQUE clauses
--
--
-- DEFAULT syntax
--
CREATE TABLE DEFAULT_TBL (i int DEFAULT 100,
x text DEFAULT 'vadim', f float8 DEFAULT 123.456);
QUERY:
INSERT INTO DEFAULT_TBL VALUES (1, 'thomas', 57.0613);
QUERY:
INSERT INTO DEFAULT_TBL VALUES (1, 'bruce');
QUERY:
INSERT INTO DEFAULT_TBL (i, f) VALUES (2, 987.654);
QUERY:
INSERT INTO DEFAULT_TBL (x) VALUES ('marc');
QUERY:
INSERT INTO DEFAULT_TBL VALUES (3, null, 1.0);
QUERY:
SELECT '' AS five, * FROM DEFAULT_TBL;
five| i|x | f
----
+---+------+
-------
| 1|thomas|
57.0613
| 1|bruce |
123.456
| 2|vadim |
987.654
|100|marc |
123.456
| 3| |
1
INSERT INTO DEFAULT_TBL VALUES (1, 'thomas', 57.0613);
INSERT INTO DEFAULT_TBL VALUES (1, 'bruce');
INSERT INTO DEFAULT_TBL (i, f) VALUES (2, 987.654);
INSERT INTO DEFAULT_TBL (x) VALUES ('marc');
INSERT INTO DEFAULT_TBL VALUES (3, null, 1.0);
SELECT '' AS five, * FROM DEFAULT_TBL;
five | i | x | f
----
--+-----+--------+--
-------
| 1 | thomas |
57.0613
| 1 | bruce |
123.456
| 2 | vadim |
987.654
| 100 | marc |
123.456
| 3 | |
1
(5 rows)
QUERY:
CREATE SEQUENCE DEFAULT_SEQ;
QUERY:
CREATE TABLE DEFAULTEXPR_TBL (i1 int DEFAULT 100 + (200-199) * 2,
CREATE SEQUENCE DEFAULT_SEQ;
CREATE TABLE DEFAULTEXPR_TBL (i1 int DEFAULT 100 + (200-199) * 2,
i2 int DEFAULT nextval('default_seq'));
QUERY:
INSERT INTO DEFAULTEXPR_TBL VALUES (-1, -2);
QUERY:
INSERT INTO DEFAULTEXPR_TBL (i1) VALUES (-3);
QUERY:
INSERT INTO DEFAULTEXPR_TBL (i2) VALUES (-4);
QUERY:
INSERT INTO DEFAULTEXPR_TBL (i2) VALUES (NULL);
QUERY:
SELECT '' AS four, * FROM DEFAULTEXPR_TBL;
four| i1|i2
----
+---+
--
| -1|
-2
| -3|
1
|102|
-4
|102|
INSERT INTO DEFAULTEXPR_TBL VALUES (-1, -2);
INSERT INTO DEFAULTEXPR_TBL (i1) VALUES (-3);
INSERT INTO DEFAULTEXPR_TBL (i2) VALUES (-4);
INSERT INTO DEFAULTEXPR_TBL (i2) VALUES (NULL);
SELECT '' AS four, * FROM DEFAULTEXPR_TBL;
four | i1 | i2
----
--+-----+--
--
| -1 |
-2
| -3 |
1
| 102 |
-4
| 102 |
(4 rows)
QUERY: CREATE TABLE error_tbl (i int DEFAULT (100, ));
-- syntax errors
-- test for extraneous comma
CREATE TABLE error_tbl (i int DEFAULT (100, ));
ERROR: parser: parse error at or near ","
QUERY: CREATE TABLE error_tbl (b1 bool DEFAULT 1 IN (1, 2));
-- this will fail because gram.y uses b_expr not a_expr for defaults,
-- to avoid a shift/reduce conflict that arises from NOT NULL being
-- part of the column definition syntax:
CREATE TABLE error_tbl (b1 bool DEFAULT 1 IN (1, 2));
ERROR: parser: parse error at or near "in"
QUERY: CREATE TABLE error_tbl (b1 bool DEFAULT (1 IN (1, 2)));
QUERY: DROP TABLE error_tbl;
QUERY: CREATE TABLE CHECK_TBL (x int,
-- this should work, however:
CREATE TABLE error_tbl (b1 bool DEFAULT (1 IN (1, 2)));
DROP TABLE error_tbl;
--
-- CHECK syntax
--
CREATE TABLE CHECK_TBL (x int,
CONSTRAINT CHECK_CON CHECK (x > 3));
QUERY:
INSERT INTO CHECK_TBL VALUES (5);
QUERY:
INSERT INTO CHECK_TBL VALUES (4);
QUERY:
INSERT INTO CHECK_TBL VALUES (3);
INSERT INTO CHECK_TBL VALUES (5);
INSERT INTO CHECK_TBL VALUES (4);
INSERT INTO CHECK_TBL VALUES (3);
ERROR: ExecAppend: rejected due to CHECK constraint check_con
QUERY:
INSERT INTO CHECK_TBL VALUES (2);
INSERT INTO CHECK_TBL VALUES (2);
ERROR: ExecAppend: rejected due to CHECK constraint check_con
QUERY:
INSERT INTO CHECK_TBL VALUES (6);
QUERY:
INSERT INTO CHECK_TBL VALUES (1);
INSERT INTO CHECK_TBL VALUES (6);
INSERT INTO CHECK_TBL VALUES (1);
ERROR: ExecAppend: rejected due to CHECK constraint check_con
QUERY:
SELECT '' AS three, * FROM CHECK_TBL;
three|x
-----
+
-
|
5
|
4
|
6
SELECT '' AS three, * FROM CHECK_TBL;
three | x
-----
--+--
-
|
5
|
4
|
6
(3 rows)
QUERY:
CREATE SEQUENCE CHECK_SEQ;
QUERY:
CREATE TABLE CHECK2_TBL (x int, y text, z int,
CREATE SEQUENCE CHECK_SEQ;
CREATE TABLE CHECK2_TBL (x int, y text, z int,
CONSTRAINT SEQUENCE_CON
CHECK (x > 3 and y <> 'check failed' and z < 8));
QUERY:
INSERT INTO CHECK2_TBL VALUES (4, 'check ok', -2);
QUERY:
INSERT INTO CHECK2_TBL VALUES (1, 'x check failed', -2);
INSERT INTO CHECK2_TBL VALUES (4, 'check ok', -2);
INSERT INTO CHECK2_TBL VALUES (1, 'x check failed', -2);
ERROR: ExecAppend: rejected due to CHECK constraint sequence_con
QUERY:
INSERT INTO CHECK2_TBL VALUES (5, 'z check failed', 10);
INSERT INTO CHECK2_TBL VALUES (5, 'z check failed', 10);
ERROR: ExecAppend: rejected due to CHECK constraint sequence_con
QUERY:
INSERT INTO CHECK2_TBL VALUES (0, 'check failed', -2);
INSERT INTO CHECK2_TBL VALUES (0, 'check failed', -2);
ERROR: ExecAppend: rejected due to CHECK constraint sequence_con
QUERY:
INSERT INTO CHECK2_TBL VALUES (6, 'check failed', 11);
INSERT INTO CHECK2_TBL VALUES (6, 'check failed', 11);
ERROR: ExecAppend: rejected due to CHECK constraint sequence_con
QUERY:
INSERT INTO CHECK2_TBL VALUES (7, 'check ok', 7);
QUERY:
SELECT '' AS two, * from CHECK2_TBL;
two|x|y | z
---
+-+--------+
--
|4|check ok|
-2
|7|check ok|
7
INSERT INTO CHECK2_TBL VALUES (7, 'check ok', 7);
SELECT '' AS two, * from CHECK2_TBL;
two | x | y | z
---
--+---+----------+--
--
| 4 | check ok |
-2
| 7 | check ok |
7
(2 rows)
QUERY: CREATE SEQUENCE INSERT_SEQ;
QUERY: CREATE TABLE INSERT_TBL (x INT DEFAULT nextval('insert_seq'),
--
-- Check constraints on INSERT
--
CREATE SEQUENCE INSERT_SEQ;
CREATE TABLE INSERT_TBL (x INT DEFAULT nextval('insert_seq'),
y TEXT DEFAULT '-NULL-', z INT DEFAULT -1 * currval('insert_seq'),
CONSTRAINT INSERT_CON CHECK (x >= 3 AND y <> 'check failed' AND x < 8),
CHECK (x + z = 0));
QUERY:
INSERT INTO INSERT_TBL VALUES (null, null, null);
INSERT INTO INSERT_TBL VALUES (null, null, null);
ERROR: ExecAppend: rejected due to CHECK constraint $2
QUERY:
INSERT INTO INSERT_TBL(x,z) VALUES (2, -2);
INSERT INTO INSERT_TBL(x,z) VALUES (2, -2);
ERROR: ExecAppend: rejected due to CHECK constraint insert_con
QUERY:
SELECT '' AS zero, * FROM INSERT_TBL;
zero|x|y|z
----
+-+-+
-
SELECT '' AS zero, * FROM INSERT_TBL;
zero | x | y | z
----
--+---+---+--
-
(0 rows)
QUERY:
SELECT 'one' AS one, nextval('insert_seq');
one|nextval
---
+
-------
one|
1
SELECT 'one' AS one, nextval('insert_seq');
one | nextval
---
--+--
-------
one |
1
(1 row)
QUERY:
INSERT INTO INSERT_TBL(y) VALUES ('Y');
INSERT INTO INSERT_TBL(y) VALUES ('Y');
ERROR: ExecAppend: rejected due to CHECK constraint insert_con
QUERY:
INSERT INTO INSERT_TBL(y) VALUES ('Y');
QUERY:
INSERT INTO INSERT_TBL(x,z) VALUES (1, -2);
INSERT INTO INSERT_TBL(y) VALUES ('Y');
INSERT INTO INSERT_TBL(x,z) VALUES (1, -2);
ERROR: ExecAppend: rejected due to CHECK constraint $2
QUERY:
INSERT INTO INSERT_TBL(z,x) VALUES (-7, 7);
QUERY:
INSERT INTO INSERT_TBL VALUES (5, 'check failed', -5);
INSERT INTO INSERT_TBL(z,x) VALUES (-7, 7);
INSERT INTO INSERT_TBL VALUES (5, 'check failed', -5);
ERROR: ExecAppend: rejected due to CHECK constraint insert_con
QUERY:
INSERT INTO INSERT_TBL VALUES (7, '!check failed', -7);
QUERY:
INSERT INTO INSERT_TBL(y) VALUES ('-!NULL-');
QUERY:
SELECT '' AS four, * FROM INSERT_TBL;
four|x|y | z
----
+-+-------------+
--
|3|Y |
-3
|7|-NULL- |
-7
|7|!check failed|
-7
|4|-!NULL- |
-4
INSERT INTO INSERT_TBL VALUES (7, '!check failed', -7);
INSERT INTO INSERT_TBL(y) VALUES ('-!NULL-');
SELECT '' AS four, * FROM INSERT_TBL;
four | x | y | z
----
--+---+---------------+--
--
| 3 | Y |
-3
| 7 | -NULL- |
-7
| 7 | !check failed |
-7
| 4 | -!NULL- |
-4
(4 rows)
QUERY:
INSERT INTO INSERT_TBL(y,z) VALUES ('check failed', 4);
INSERT INTO INSERT_TBL(y,z) VALUES ('check failed', 4);
ERROR: ExecAppend: rejected due to CHECK constraint $2
QUERY:
INSERT INTO INSERT_TBL(x,y) VALUES (5, 'check failed');
INSERT INTO INSERT_TBL(x,y) VALUES (5, 'check failed');
ERROR: ExecAppend: rejected due to CHECK constraint insert_con
QUERY:
INSERT INTO INSERT_TBL(x,y) VALUES (5, '!check failed');
QUERY:
INSERT INTO INSERT_TBL(y) VALUES ('-!NULL-');
QUERY:
SELECT '' AS six, * FROM INSERT_TBL;
six|x|y | z
---
+-+-------------+
--
|3|Y |
-3
|7|-NULL- |
-7
|7|!check failed|
-7
|4|-!NULL- |
-4
|5|!check failed|
-5
|6|-!NULL- |
-6
INSERT INTO INSERT_TBL(x,y) VALUES (5, '!check failed');
INSERT INTO INSERT_TBL(y) VALUES ('-!NULL-');
SELECT '' AS six, * FROM INSERT_TBL;
six | x | y | z
---
--+---+---------------+--
--
| 3 | Y |
-3
| 7 | -NULL- |
-7
| 7 | !check failed |
-7
| 4 | -!NULL- |
-4
| 5 | !check failed |
-5
| 6 | -!NULL- |
-6
(6 rows)
QUERY:
SELECT 'seven' AS one, nextval('insert_seq');
one |nextval
-----
+
-------
seven|
7
SELECT 'seven' AS one, nextval('insert_seq');
one | nextval
-----
--+--
-------
seven |
7
(1 row)
QUERY:
INSERT INTO INSERT_TBL(y) VALUES ('Y');
INSERT INTO INSERT_TBL(y) VALUES ('Y');
ERROR: ExecAppend: rejected due to CHECK constraint insert_con
QUERY:
SELECT 'eight' AS one, currval('insert_seq');
one |currval
-----
+
-------
eight|
8
SELECT 'eight' AS one, currval('insert_seq');
one | currval
-----
--+--
-------
eight |
8
(1 row)
QUERY: DELETE FROM INSERT_TBL;
QUERY: DROP SEQUENCE INSERT_SEQ;
QUERY: CREATE SEQUENCE INSERT_SEQ START 4;
QUERY: CREATE TABLE tmp (xd INT, yd TEXT, zd INT);
QUERY: INSERT INTO tmp VALUES (null, 'Y', null);
QUERY: INSERT INTO tmp VALUES (5, '!check failed', null);
QUERY: INSERT INTO tmp VALUES (null, 'try again', null);
QUERY: INSERT INTO INSERT_TBL(y) select yd from tmp;
--
-- Check constraints on INSERT INTO
--
DELETE FROM INSERT_TBL;
DROP SEQUENCE INSERT_SEQ;
CREATE SEQUENCE INSERT_SEQ START 4;
CREATE TABLE tmp (xd INT, yd TEXT, zd INT);
INSERT INTO tmp VALUES (null, 'Y', null);
INSERT INTO tmp VALUES (5, '!check failed', null);
INSERT INTO tmp VALUES (null, 'try again', null);
NOTICE: insert_seq.nextval: sequence was re-created
QUERY: SELECT '' AS three, * FROM INSERT_TBL;
three|x|y | z
-----+-+-------------+--
|4|Y |-4
|5|!check failed|-5
|6|try again |-6
INSERT INTO INSERT_TBL(y) select yd from tmp;
SELECT '' AS three, * FROM INSERT_TBL;
three | x | y | z
-------+---+---------------+----
| 4 | Y | -4
| 5 | !check failed | -5
| 6 | try again | -6
(3 rows)
QUERY:
INSERT INTO INSERT_TBL SELECT * FROM tmp WHERE yd = 'try again';
INSERT INTO INSERT_TBL SELECT * FROM tmp WHERE yd = 'try again';
ERROR: ExecAppend: rejected due to CHECK constraint $2
QUERY:
INSERT INTO INSERT_TBL(y,z) SELECT yd, -7 FROM tmp WHERE yd = 'try again';
QUERY:
INSERT INTO INSERT_TBL(y,z) SELECT yd, -8 FROM tmp WHERE yd = 'try again';
INSERT INTO INSERT_TBL(y,z) SELECT yd, -7 FROM tmp WHERE yd = 'try again';
INSERT INTO INSERT_TBL(y,z) SELECT yd, -8 FROM tmp WHERE yd = 'try again';
ERROR: ExecAppend: rejected due to CHECK constraint insert_con
QUERY:
SELECT '' AS four, * FROM INSERT_TBL;
four|x|y | z
----
+-+-------------+
--
|4|Y |
-4
|5|!check failed|
-5
|6|try again |
-6
|7|try again |
-7
SELECT '' AS four, * FROM INSERT_TBL;
four | x | y | z
----
--+---+---------------+--
--
| 4 | Y |
-4
| 5 | !check failed |
-5
| 6 | try again |
-6
| 7 | try again |
-7
(4 rows)
QUERY: DROP TABLE tmp;
QUERY: UPDATE INSERT_TBL SET x = NULL WHERE x = 6;
DROP TABLE tmp;
--
-- Check constraints on UPDATE
--
UPDATE INSERT_TBL SET x = NULL WHERE x = 6;
ERROR: ExecReplace: rejected due to CHECK constraint $2
QUERY:
UPDATE INSERT_TBL SET x = 6 WHERE x = 6;
QUERY:
UPDATE INSERT_TBL SET x = -z, z = -x;
QUERY:
UPDATE INSERT_TBL SET x = z, z = x;
UPDATE INSERT_TBL SET x = 6 WHERE x = 6;
UPDATE INSERT_TBL SET x = -z, z = -x;
UPDATE INSERT_TBL SET x = z, z = x;
ERROR: ExecReplace: rejected due to CHECK constraint insert_con
QUERY:
SELECT * FROM INSERT_TBL;
x|y | z
-
+-------------+
--
4|Y |
-4
5|!check failed|
-5
7|try again |
-7
6|try again |
-6
SELECT * FROM INSERT_TBL;
x | y | z
-
--+---------------+--
--
4 | Y |
-4
5 | !check failed |
-5
7 | try again |
-7
6 | try again |
-6
(4 rows)
QUERY: CREATE TABLE COPY_TBL (x INT, y TEXT, z INT,
-- DROP TABLE INSERT_TBL;
--
-- Check constraints on COPY FROM
--
CREATE TABLE COPY_TBL (x INT, y TEXT, z INT,
CONSTRAINT COPY_CON
CHECK (x > 3 AND y <> 'check failed' AND x < 7 ));
QUERY:
COPY COPY_TBL FROM '_OBJWD_/data/constro.data';
QUERY:
SELECT '' AS two, * FROM COPY_TBL;
two|x|y |z
---
+-+-------------+
-
|4|!check failed|
5
|6|OK |
4
COPY COPY_TBL FROM '_OBJWD_/data/constro.data';
SELECT '' AS two, * FROM COPY_TBL;
two | x | y | z
---
--+---+---------------+--
-
| 4 | !check failed |
5
| 6 | OK |
4
(2 rows)
QUERY:
COPY COPY_TBL FROM '_OBJWD_/data/constrf.data';
COPY COPY_TBL FROM '_OBJWD_/data/constrf.data';
ERROR: CopyFrom: rejected due to CHECK constraint copy_con
QUERY:
SELECT * FROM COPY_TBL;
x|y |z
-
+-------------+
-
4|!check failed|
5
6|OK |
4
SELECT * FROM COPY_TBL;
x | y | z
-
--+---------------+--
-
4 | !check failed |
5
6 | OK |
4
(2 rows)
QUERY: CREATE TABLE PRIMARY_TBL (i int PRIMARY KEY, t text);
--
-- Primary keys
--
NOTICE: CREATE TABLE/PRIMARY KEY will create implicit index 'primary_tbl_pkey' for table 'primary_tbl'
QUERY: INSERT INTO PRIMARY_TBL VALUES (1, 'one');
QUERY: INSERT INTO PRIMARY_TBL VALUES (2, 'two');
QUERY: INSERT INTO PRIMARY_TBL VALUES (1, 'three');
CREATE TABLE PRIMARY_TBL (i int PRIMARY KEY, t text);
INSERT INTO PRIMARY_TBL VALUES (1, 'one');
INSERT INTO PRIMARY_TBL VALUES (2, 'two');
INSERT INTO PRIMARY_TBL VALUES (1, 'three');
ERROR: Cannot insert a duplicate key into unique index primary_tbl_pkey
QUERY:
INSERT INTO PRIMARY_TBL VALUES (4, 'three');
QUERY:
INSERT INTO PRIMARY_TBL VALUES (5, 'one');
QUERY:
INSERT INTO PRIMARY_TBL (t) VALUES ('six');
INSERT INTO PRIMARY_TBL VALUES (4, 'three');
INSERT INTO PRIMARY_TBL VALUES (5, 'one');
INSERT INTO PRIMARY_TBL (t) VALUES ('six');
ERROR: ExecAppend: Fail to add null value in not null attribute i
QUERY:
SELECT '' AS four, * FROM PRIMARY_TBL;
four|i|t
----
+-+
-----
|1|one
|2|two
|4|
three
|5|one
SELECT '' AS four, * FROM PRIMARY_TBL;
four | i | t
----
--+---+--
-----
| 1 | one
| 2 | two
| 4 |
three
| 5 | one
(4 rows)
QUERY: DROP TABLE PRIMARY_TBL;
QUERY: CREATE TABLE PRIMARY_TBL (i int, t text,
PRIMARY KEY(i,t));
DROP TABLE PRIMARY_TBL;
CREATE TABLE PRIMARY_TBL (i int, t text,
NOTICE: CREATE TABLE/PRIMARY KEY will create implicit index 'primary_tbl_pkey' for table 'primary_tbl'
QUERY: INSERT INTO PRIMARY_TBL VALUES (1, 'one');
QUERY: INSERT INTO PRIMARY_TBL VALUES (2, 'two');
QUERY: INSERT INTO PRIMARY_TBL VALUES (1, 'three');
QUERY: INSERT INTO PRIMARY_TBL VALUES (4, 'three');
QUERY: INSERT INTO PRIMARY_TBL VALUES (5, 'one');
QUERY: INSERT INTO PRIMARY_TBL (t) VALUES ('six');
PRIMARY KEY(i,t));
INSERT INTO PRIMARY_TBL VALUES (1, 'one');
INSERT INTO PRIMARY_TBL VALUES (2, 'two');
INSERT INTO PRIMARY_TBL VALUES (1, 'three');
INSERT INTO PRIMARY_TBL VALUES (4, 'three');
INSERT INTO PRIMARY_TBL VALUES (5, 'one');
INSERT INTO PRIMARY_TBL (t) VALUES ('six');
ERROR: ExecAppend: Fail to add null value in not null attribute i
QUERY:
SELECT '' AS three, * FROM PRIMARY_TBL;
three|i|t
-----
+-+
-----
|1|one
|2|two
|1|
three
|4|
three
|5|one
SELECT '' AS three, * FROM PRIMARY_TBL;
three | i | t
-----
--+---+--
-----
| 1 | one
| 2 | two
| 1 |
three
| 4 |
three
| 5 | one
(5 rows)
QUERY: DROP TABLE PRIMARY_TBL;
QUERY: CREATE TABLE UNIQUE_TBL (i int UNIQUE, t text);
DROP TABLE PRIMARY_TBL;
--
-- Unique keys
--
NOTICE: CREATE TABLE/UNIQUE will create implicit index 'unique_tbl_i_key' for table 'unique_tbl'
QUERY: INSERT INTO UNIQUE_TBL VALUES (1, 'one');
QUERY: INSERT INTO UNIQUE_TBL VALUES (2, 'two');
QUERY: INSERT INTO UNIQUE_TBL VALUES (1, 'three');
CREATE TABLE UNIQUE_TBL (i int UNIQUE, t text);
INSERT INTO UNIQUE_TBL VALUES (1, 'one');
INSERT INTO UNIQUE_TBL VALUES (2, 'two');
INSERT INTO UNIQUE_TBL VALUES (1, 'three');
ERROR: Cannot insert a duplicate key into unique index unique_tbl_i_key
QUERY:
INSERT INTO UNIQUE_TBL VALUES (4, 'four');
QUERY:
INSERT INTO UNIQUE_TBL VALUES (5, 'one');
QUERY:
INSERT INTO UNIQUE_TBL (t) VALUES ('six');
QUERY:
INSERT INTO UNIQUE_TBL (t) VALUES ('seven');
QUERY:
SELECT '' AS five, * FROM UNIQUE_TBL;
five|i|t
----
+-+
-----
|1|one
|2|two
|4|four
|5|one
| |six
| |
seven
INSERT INTO UNIQUE_TBL VALUES (4, 'four');
INSERT INTO UNIQUE_TBL VALUES (5, 'one');
INSERT INTO UNIQUE_TBL (t) VALUES ('six');
INSERT INTO UNIQUE_TBL (t) VALUES ('seven');
SELECT '' AS five, * FROM UNIQUE_TBL;
five | i | t
----
--+---+--
-----
| 1 | one
| 2 | two
| 4 | four
| 5 | one
| | six
| |
seven
(6 rows)
QUERY: DROP TABLE UNIQUE_TBL;
QUERY: CREATE TABLE UNIQUE_TBL (i int, t text,
UNIQUE(i,t));
DROP TABLE UNIQUE_TBL;
CREATE TABLE UNIQUE_TBL (i int, t text,
NOTICE: CREATE TABLE/UNIQUE will create implicit index 'unique_tbl_i_key' for table 'unique_tbl'
QUERY: INSERT INTO UNIQUE_TBL VALUES (1, 'one');
QUERY: INSERT INTO UNIQUE_TBL VALUES (2, 'two');
QUERY: INSERT INTO UNIQUE_TBL VALUES (1, 'three');
QUERY: INSERT INTO UNIQUE_TBL VALUES (1, 'one');
UNIQUE(i,t));
INSERT INTO UNIQUE_TBL VALUES (1, 'one');
INSERT INTO UNIQUE_TBL VALUES (2, 'two');
INSERT INTO UNIQUE_TBL VALUES (1, 'three');
INSERT INTO UNIQUE_TBL VALUES (1, 'one');
ERROR: Cannot insert a duplicate key into unique index unique_tbl_i_key
QUERY:
INSERT INTO UNIQUE_TBL VALUES (5, 'one');
QUERY:
INSERT INTO UNIQUE_TBL (t) VALUES ('six');
QUERY:
SELECT '' AS five, * FROM UNIQUE_TBL;
five|i|t
----
+-+
-----
|1|one
|2|two
|1|
three
|5|one
| |six
INSERT INTO UNIQUE_TBL VALUES (5, 'one');
INSERT INTO UNIQUE_TBL (t) VALUES ('six');
SELECT '' AS five, * FROM UNIQUE_TBL;
five | i | t
----
--+---+--
-----
| 1 | one
| 2 | two
| 1 |
three
| 5 | one
| | six
(5 rows)
QUERY:
DROP TABLE UNIQUE_TBL;
DROP TABLE UNIQUE_TBL;
src/test/regress/output/copy.source
View file @
69789bf3
QUERY: COPY aggtest FROM '_OBJWD_/data/agg.data';
QUERY: COPY onek FROM '_OBJWD_/data/onek.data';
QUERY: COPY onek TO '_OBJWD_/results/onek.data';
QUERY: DELETE FROM onek;
QUERY: COPY onek FROM '_OBJWD_/results/onek.data';
QUERY: COPY tenk1 FROM '_OBJWD_/data/tenk.data';
QUERY: COPY slow_emp4000 FROM '_OBJWD_/data/rect.data';
QUERY: COPY person FROM '_OBJWD_/data/person.data';
QUERY: COPY emp FROM '_OBJWD_/data/emp.data';
QUERY: COPY student FROM '_OBJWD_/data/student.data';
QUERY: COPY stud_emp FROM '_OBJWD_/data/stud_emp.data';
QUERY: COPY road FROM '_OBJWD_/data/streets.data';
QUERY: COPY real_city FROM '_OBJWD_/data/real_city.data';
QUERY: COPY hash_i4_heap FROM '_OBJWD_/data/hash.data';
QUERY: COPY hash_name_heap FROM '_OBJWD_/data/hash.data';
QUERY: COPY hash_txt_heap FROM '_OBJWD_/data/hash.data';
QUERY: COPY hash_f8_heap FROM '_OBJWD_/data/hash.data';
QUERY: COPY bt_i4_heap FROM '_OBJWD_/data/desc.data';
QUERY: COPY bt_name_heap FROM '_OBJWD_/data/hash.data';
QUERY: COPY bt_txt_heap FROM '_OBJWD_/data/desc.data';
QUERY: COPY bt_f8_heap FROM '_OBJWD_/data/hash.data';
--
-- COPY
--
-- CLASS POPULATION
-- (any resemblance to real life is purely coincidental)
--
COPY aggtest FROM '_OBJWD_/data/agg.data';
COPY onek FROM '_OBJWD_/data/onek.data';
COPY onek TO '_OBJWD_/results/onek.data';
DELETE FROM onek;
COPY onek FROM '_OBJWD_/results/onek.data';
COPY tenk1 FROM '_OBJWD_/data/tenk.data';
COPY slow_emp4000 FROM '_OBJWD_/data/rect.data';
COPY person FROM '_OBJWD_/data/person.data';
COPY emp FROM '_OBJWD_/data/emp.data';
COPY student FROM '_OBJWD_/data/student.data';
COPY stud_emp FROM '_OBJWD_/data/stud_emp.data';
COPY road FROM '_OBJWD_/data/streets.data';
COPY real_city FROM '_OBJWD_/data/real_city.data';
COPY hash_i4_heap FROM '_OBJWD_/data/hash.data';
COPY hash_name_heap FROM '_OBJWD_/data/hash.data';
COPY hash_txt_heap FROM '_OBJWD_/data/hash.data';
COPY hash_f8_heap FROM '_OBJWD_/data/hash.data';
-- the data in this file has a lot of duplicates in the index key
-- fields, leading to long bucket chains and lots of table expansion.
-- this is therefore a stress test of the bucket overflow code (unlike
-- the data in hash.data, which has unique index keys).
--
-- COPY hash_ovfl_heap FROM '_OBJWD_/data/hashovfl.data';
COPY bt_i4_heap FROM '_OBJWD_/data/desc.data';
COPY bt_name_heap FROM '_OBJWD_/data/hash.data';
COPY bt_txt_heap FROM '_OBJWD_/data/desc.data';
COPY bt_f8_heap FROM '_OBJWD_/data/hash.data';
src/test/regress/output/create_function_1.source
View file @
69789bf3
QUERY: CREATE FUNCTION widget_in(opaque)
--
-- CREATE_FUNCTION_1
--
CREATE FUNCTION widget_in(opaque)
RETURNS widget
AS '_OBJWD_/regress_DLSUFFIX_'
LANGUAGE 'c';
NOTICE: ProcedureCreate: type 'widget' is not yet defined
QUERY: CREATE FUNCTION widget_out(opaque)
LANGUAGE 'c';
CREATE FUNCTION widget_out(opaque)
RETURNS opaque
AS '_OBJWD_/regress_DLSUFFIX_'
LANGUAGE 'c';
QUERY:
CREATE FUNCTION check_primary_key ()
CREATE FUNCTION check_primary_key ()
RETURNS opaque
AS '_OBJWD_/../../../contrib/spi/refint_DLSUFFIX_'
LANGUAGE 'c'
;
QUERY: CREATE FUNCTION check_foreign_key ()
AS '_OBJWD_/../../../contrib/spi/refint.so'
LANGUAGE 'c';
CREATE FUNCTION check_foreign_key ()
RETURNS opaque
AS '_OBJWD_/../../../contrib/spi/refint_DLSUFFIX_'
LANGUAGE 'c'
;
QUERY: CREATE FUNCTION autoinc ()
AS '_OBJWD_/../../../contrib/spi/refint.so'
LANGUAGE 'c';
CREATE FUNCTION autoinc ()
RETURNS opaque
AS '_OBJWD_/../../../contrib/spi/autoinc_DLSUFFIX_'
LANGUAGE 'c'
;
QUERY: CREATE FUNCTION funny_dup17 ()
AS '_OBJWD_/../../../contrib/spi/autoinc.so'
LANGUAGE 'c';
CREATE FUNCTION funny_dup17 ()
RETURNS opaque
AS '_OBJWD_/regress_DLSUFFIX_'
LANGUAGE 'c'
;
QUERY: CREATE FUNCTION ttdummy ()
LANGUAGE 'c';
CREATE FUNCTION ttdummy ()
RETURNS opaque
AS '_OBJWD_/regress_DLSUFFIX_'
LANGUAGE 'c'
;
QUERY: CREATE FUNCTION set_ttdummy (int4)
LANGUAGE 'c';
CREATE FUNCTION set_ttdummy (int4)
RETURNS int4
AS '_OBJWD_/regress_DLSUFFIX_'
LANGUAGE 'c'
;
LANGUAGE 'c';
src/test/regress/output/create_function_2.source
View file @
69789bf3
QUERY: CREATE FUNCTION hobbies(person)
--
-- CREATE_FUNCTION_2
--
CREATE FUNCTION hobbies(person)
RETURNS setof hobbies_r
AS 'select * from hobbies_r where person = $1.name'
LANGUAGE 'sql';
QUERY:
CREATE FUNCTION hobby_construct(text, text)
CREATE FUNCTION hobby_construct(text, text)
RETURNS hobbies_r
AS 'select $1 as name, $2 as hobby'
LANGUAGE 'sql';
QUERY:
CREATE FUNCTION equipment(hobbies_r)
CREATE FUNCTION equipment(hobbies_r)
RETURNS setof equipment_r
AS 'select * from equipment_r where hobby = $1.name'
LANGUAGE 'sql';
QUERY:
CREATE FUNCTION user_relns()
CREATE FUNCTION user_relns()
RETURNS setof name
AS 'select relname
from pg_class
where relname !~ ''pg_.*'' and
relkind <> ''i'' '
LANGUAGE 'sql';
QUERY:
CREATE FUNCTION pt_in_widget(point, widget)
CREATE FUNCTION pt_in_widget(point, widget)
RETURNS int4
AS '_OBJWD_/regress_DLSUFFIX_'
LANGUAGE 'c';
QUERY:
CREATE FUNCTION overpaid(emp)
CREATE FUNCTION overpaid(emp)
RETURNS bool
AS '_OBJWD_/regress_DLSUFFIX_'
LANGUAGE 'c';
QUERY:
CREATE FUNCTION boxarea(box)
CREATE FUNCTION boxarea(box)
RETURNS int4
AS '_OBJWD_/regress_DLSUFFIX_'
LANGUAGE 'c';
QUERY:
CREATE FUNCTION interpt_pp(path, path)
CREATE FUNCTION interpt_pp(path, path)
RETURNS point
AS '_OBJWD_/regress_DLSUFFIX_'
LANGUAGE 'c';
QUERY:
CREATE FUNCTION reverse_name(name)
CREATE FUNCTION reverse_name(name)
RETURNS name
AS '_OBJWD_/regress_DLSUFFIX_'
LANGUAGE 'c';
QUERY: LOAD '_OBJWD_/regress_DLSUFFIX_';
--
-- Function dynamic loading
--
LOAD '/opt/postgres/current/src/test/regress/input/../regress.so';
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