mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-18 18:44:06 +08:00
aa731ed843
argument as a 'regclass' value instead of a text string. The frontend conversion of text string to pg_class OID is now encapsulated as an implicitly-invocable coercion from text to regclass. This provides backwards compatibility to the old behavior when the sequence argument is explicitly typed as 'text'. When the argument is just an unadorned literal string, it will be taken as 'regclass', which means that the stored representation will be an OID. This solves longstanding problems with renaming sequences that are referenced in default expressions, as well as new-in-8.1 problems with renaming such sequences' schemas or moving them to another schema. All per recent discussion. Along the way, fix some rather serious problems in dbmirror's support for mirroring sequence operations (int4 vs int8 confusion for instance).
63 lines
1.5 KiB
PL/PgSQL
63 lines
1.5 KiB
PL/PgSQL
BEGIN;
|
|
|
|
|
|
CREATE FUNCTION "recordchange" () RETURNS trigger AS
|
|
'$libdir/pending', 'recordchange' LANGUAGE 'C';
|
|
|
|
|
|
|
|
CREATE TABLE dbmirror_MirrorHost (
|
|
MirrorHostId serial not null,
|
|
SlaveName varchar NOT NULL,
|
|
PRIMARY KEY(MirrorHostId)
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
CREATE TABLE dbmirror_Pending (
|
|
SeqId serial,
|
|
TableName Name NOT NULL,
|
|
Op character,
|
|
XID int4 NOT NULL,
|
|
PRIMARY KEY (SeqId)
|
|
);
|
|
|
|
CREATE INDEX dbmirror_Pending_XID_Index ON dbmirror_Pending (XID);
|
|
|
|
CREATE TABLE dbmirror_PendingData (
|
|
SeqId int4 NOT NULL,
|
|
IsKey bool NOT NULL,
|
|
Data varchar,
|
|
PRIMARY KEY (SeqId, IsKey) ,
|
|
FOREIGN KEY (SeqId) REFERENCES dbmirror_Pending (SeqId) ON UPDATE CASCADE ON DELETE CASCADE
|
|
);
|
|
|
|
|
|
CREATE TABLE dbmirror_MirroredTransaction (
|
|
XID int4 NOT NULL,
|
|
LastSeqId int4 NOT NULL,
|
|
MirrorHostId int4 NOT NULL,
|
|
PRIMARY KEY (XID,MirrorHostId),
|
|
FOREIGN KEY (MirrorHostId) REFERENCES dbmirror_MirrorHost (MirrorHostId) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
FOREIGN KEY (LastSeqId) REFERENCES dbmirror_Pending (SeqId) ON UPDATE
|
|
CASCADE ON DELETE CASCADE
|
|
);
|
|
|
|
|
|
UPDATE pg_proc SET proname='nextval_pg' WHERE proname='nextval';
|
|
|
|
CREATE FUNCTION pg_catalog.nextval(regclass) RETURNS int8 AS
|
|
'$libdir/pending', 'nextval_mirror' LANGUAGE 'C' STRICT;
|
|
|
|
|
|
UPDATE pg_proc set proname='setval_pg' WHERE proname='setval';
|
|
|
|
CREATE FUNCTION pg_catalog.setval(regclass, int8, boolean) RETURNS int8 AS
|
|
'$libdir/pending', 'setval3_mirror' LANGUAGE 'C' STRICT;
|
|
CREATE FUNCTION pg_catalog.setval(regclass, int8) RETURNS int8 AS
|
|
'$libdir/pending', 'setval_mirror' LANGUAGE 'C' STRICT;
|
|
|
|
COMMIT;
|