Commit f85f43df authored by Tom Lane's avatar Tom Lane

Backend support for autocommit removed, per recent discussions. The

only remnant of this failed experiment is that the server will take
SET AUTOCOMMIT TO ON.  Still TODO: provide some client-side autocommit
logic in libpq.
parent d9b679c1
#!/usr/bin/perl #!/usr/bin/perl
# $Id: adddepend,v 1.3 2002/12/02 00:28:29 tgl Exp $ # $Id: adddepend,v 1.4 2003/05/14 03:25:55 tgl Exp $
# Project exists to assist PostgreSQL users with their structural upgrade # Project exists to assist PostgreSQL users with their structural upgrade
# from 7.2 (or prior) to 7.3 (possibly later). Must be run against a 7.3 # from 7.2 (or prior) to 7.3 (possibly later). Must be run against a 7.3
...@@ -125,20 +125,13 @@ my $dbh = DBI->connect($dsn, $dbuser, $dbpass); ...@@ -125,20 +125,13 @@ my $dbh = DBI->connect($dsn, $dbuser, $dbpass);
# We want to control commits # We want to control commits
$dbh->{'AutoCommit'} = 0; $dbh->{'AutoCommit'} = 0;
# turn on autocommit # control where things get created
my $sql = qq{ my $sql = qq{
SET search_path = public; SET search_path = public;
}; };
my $sth = $dbh->prepare($sql); my $sth = $dbh->prepare($sql);
$sth->execute(); $sth->execute();
# turn on autocommit
my $sql2 = qq{
SET autocommit TO 'on';
};
my $sth2 = $dbh->prepare($sql2);
$sth2->execute();
END { END {
$dbh->disconnect() if $dbh; $dbh->disconnect() if $dbh;
} }
......
...@@ -6,8 +6,6 @@ ...@@ -6,8 +6,6 @@
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION array_texteq(_text, text) CREATE OR REPLACE FUNCTION array_texteq(_text, text)
RETURNS bool RETURNS bool
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
-- create type of int2 key -- create type of int2 key
CREATE FUNCTION int2key_in(cstring) CREATE FUNCTION int2key_in(cstring)
RETURNS int2key RETURNS int2key
......
...@@ -3,18 +3,18 @@ ...@@ -3,18 +3,18 @@
-- does not depend on contents of btree_gist.sql. -- does not depend on contents of btree_gist.sql.
-- --
\set ECHO none \set ECHO none
psql:btree_gist.sql:10: NOTICE: ProcedureCreate: type int2key is not yet defined psql:btree_gist.sql:8: NOTICE: ProcedureCreate: type int2key is not yet defined
psql:btree_gist.sql:15: NOTICE: Argument type "int2key" is only a shell psql:btree_gist.sql:13: NOTICE: Argument type "int2key" is only a shell
psql:btree_gist.sql:27: NOTICE: ProcedureCreate: type int4key is not yet defined psql:btree_gist.sql:25: NOTICE: ProcedureCreate: type int4key is not yet defined
psql:btree_gist.sql:32: NOTICE: Argument type "int4key" is only a shell psql:btree_gist.sql:30: NOTICE: Argument type "int4key" is only a shell
psql:btree_gist.sql:44: NOTICE: ProcedureCreate: type int8key is not yet defined psql:btree_gist.sql:42: NOTICE: ProcedureCreate: type int8key is not yet defined
psql:btree_gist.sql:49: NOTICE: Argument type "int8key" is only a shell psql:btree_gist.sql:47: NOTICE: Argument type "int8key" is only a shell
psql:btree_gist.sql:61: NOTICE: ProcedureCreate: type float4key is not yet defined psql:btree_gist.sql:59: NOTICE: ProcedureCreate: type float4key is not yet defined
psql:btree_gist.sql:66: NOTICE: Argument type "float4key" is only a shell psql:btree_gist.sql:64: NOTICE: Argument type "float4key" is only a shell
psql:btree_gist.sql:79: NOTICE: ProcedureCreate: type float8key is not yet defined psql:btree_gist.sql:77: NOTICE: ProcedureCreate: type float8key is not yet defined
psql:btree_gist.sql:84: NOTICE: Argument type "float8key" is only a shell psql:btree_gist.sql:82: NOTICE: Argument type "float8key" is only a shell
psql:btree_gist.sql:394: NOTICE: ProcedureCreate: type tskey is not yet defined psql:btree_gist.sql:392: NOTICE: ProcedureCreate: type tskey is not yet defined
psql:btree_gist.sql:399: NOTICE: Argument type "tskey" is only a shell psql:btree_gist.sql:397: NOTICE: Argument type "tskey" is only a shell
CREATE TABLE int4tmp (b int4); CREATE TABLE int4tmp (b int4);
\copy int4tmp from 'data/test_btree.data' \copy int4tmp from 'data/test_btree.data'
CREATE TABLE int8tmp (b int8); CREATE TABLE int8tmp (b int8);
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
-- darcy@druid.net -- darcy@druid.net
-- http://www.druid.net/darcy/ -- http://www.druid.net/darcy/
-- --
-- $Header: /cvsroot/pgsql/contrib/chkpass/chkpass.sql.in,v 1.3 2002/10/18 18:41:19 momjian Exp $ -- $Header: /cvsroot/pgsql/contrib/chkpass/chkpass.sql.in,v 1.4 2003/05/14 03:25:55 tgl Exp $
-- --
-- best viewed with tabs set to 4 -- best viewed with tabs set to 4
-- --
...@@ -16,8 +16,6 @@ ...@@ -16,8 +16,6 @@
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE FUNCTION chkpass_in(cstring) CREATE FUNCTION chkpass_in(cstring)
RETURNS chkpass RETURNS chkpass
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
...@@ -4,8 +4,6 @@ ...@@ -4,8 +4,6 @@
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION cube_in(cstring) CREATE OR REPLACE FUNCTION cube_in(cstring)
RETURNS cube RETURNS cube
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
...@@ -6,8 +6,8 @@ ...@@ -6,8 +6,8 @@
-- does not depend on contents of cube.sql. -- does not depend on contents of cube.sql.
-- --
\set ECHO none \set ECHO none
psql:cube.sql:12: NOTICE: ProcedureCreate: type cube is not yet defined psql:cube.sql:10: NOTICE: ProcedureCreate: type cube is not yet defined
psql:cube.sql:17: NOTICE: Argument type "cube" is only a shell psql:cube.sql:15: NOTICE: Argument type "cube" is only a shell
-- --
-- testing the input and output functions -- testing the input and output functions
-- --
......
...@@ -861,8 +861,6 @@ main(int argc, char **argv) ...@@ -861,8 +861,6 @@ main(int argc, char **argv)
PQexec(conn, "SET search_path = public"); PQexec(conn, "SET search_path = public");
PQexec(conn, "SET autocommit TO 'on'");
/* Substitute field names */ /* Substitute field names */
do_substitute(subarg, dbh); do_substitute(subarg, dbh);
......
...@@ -190,7 +190,7 @@ WHERE t.a > 7; ...@@ -190,7 +190,7 @@ WHERE t.a > 7;
ERROR: dblink: no connection available ERROR: dblink: no connection available
-- put more data into our slave table, first using arbitrary connection syntax -- put more data into our slave table, first using arbitrary connection syntax
-- but truncate the actual return value so we can use diff to check for success -- but truncate the actual return value so we can use diff to check for success
SELECT substr(dblink_exec('dbname=regression','SET autocommit TO ''on'';INSERT INTO foo VALUES(10,''k'',''{"a10","b10","c10"}'')'),1,6); SELECT substr(dblink_exec('dbname=regression','INSERT INTO foo VALUES(10,''k'',''{"a10","b10","c10"}'')'),1,6);
substr substr
-------- --------
INSERT INSERT
...@@ -205,7 +205,7 @@ SELECT dblink_connect('dbname=regression'); ...@@ -205,7 +205,7 @@ SELECT dblink_connect('dbname=regression');
-- put more data into our slave table, using persistent connection syntax -- put more data into our slave table, using persistent connection syntax
-- but truncate the actual return value so we can use diff to check for success -- but truncate the actual return value so we can use diff to check for success
SELECT substr(dblink_exec('SET autocommit TO ''on'';INSERT INTO foo VALUES(11,''l'',''{"a11","b11","c11"}'')'),1,6); SELECT substr(dblink_exec('INSERT INTO foo VALUES(11,''l'',''{"a11","b11","c11"}'')'),1,6);
substr substr
-------- --------
INSERT INSERT
...@@ -231,7 +231,7 @@ FROM dblink('SELECT * FROM foo') AS t(a int, b text, c text[]); ...@@ -231,7 +231,7 @@ FROM dblink('SELECT * FROM foo') AS t(a int, b text, c text[]);
(12 rows) (12 rows)
-- change some data -- change some data
SELECT dblink_exec('SET autocommit TO ''on'';UPDATE foo SET f3[2] = ''b99'' WHERE f1 = 11'); SELECT dblink_exec('UPDATE foo SET f3[2] = ''b99'' WHERE f1 = 11');
dblink_exec dblink_exec
------------- -------------
UPDATE 1 UPDATE 1
...@@ -247,7 +247,7 @@ WHERE a = 11; ...@@ -247,7 +247,7 @@ WHERE a = 11;
(1 row) (1 row)
-- delete some data -- delete some data
SELECT dblink_exec('SET autocommit TO ''on'';DELETE FROM foo WHERE f1 = 11'); SELECT dblink_exec('DELETE FROM foo WHERE f1 = 11');
dblink_exec dblink_exec
------------- -------------
DELETE 1 DELETE 1
......
...@@ -8,7 +8,6 @@ SET search_path = public; ...@@ -8,7 +8,6 @@ SET search_path = public;
-- Turn off echoing so that expected file does not depend on -- Turn off echoing so that expected file does not depend on
-- contents of dblink.sql. -- contents of dblink.sql.
\set ECHO none \set ECHO none
SET autocommit TO 'on';
\i dblink.sql \i dblink.sql
\set ECHO all \set ECHO all
...@@ -113,21 +112,21 @@ WHERE t.a > 7; ...@@ -113,21 +112,21 @@ WHERE t.a > 7;
-- put more data into our slave table, first using arbitrary connection syntax -- put more data into our slave table, first using arbitrary connection syntax
-- but truncate the actual return value so we can use diff to check for success -- but truncate the actual return value so we can use diff to check for success
SELECT substr(dblink_exec('dbname=regression','SET autocommit TO ''on'';INSERT INTO foo VALUES(10,''k'',''{"a10","b10","c10"}'')'),1,6); SELECT substr(dblink_exec('dbname=regression','INSERT INTO foo VALUES(10,''k'',''{"a10","b10","c10"}'')'),1,6);
-- create a persistent connection -- create a persistent connection
SELECT dblink_connect('dbname=regression'); SELECT dblink_connect('dbname=regression');
-- put more data into our slave table, using persistent connection syntax -- put more data into our slave table, using persistent connection syntax
-- but truncate the actual return value so we can use diff to check for success -- but truncate the actual return value so we can use diff to check for success
SELECT substr(dblink_exec('SET autocommit TO ''on'';INSERT INTO foo VALUES(11,''l'',''{"a11","b11","c11"}'')'),1,6); SELECT substr(dblink_exec('INSERT INTO foo VALUES(11,''l'',''{"a11","b11","c11"}'')'),1,6);
-- let's see it -- let's see it
SELECT * SELECT *
FROM dblink('SELECT * FROM foo') AS t(a int, b text, c text[]); FROM dblink('SELECT * FROM foo') AS t(a int, b text, c text[]);
-- change some data -- change some data
SELECT dblink_exec('SET autocommit TO ''on'';UPDATE foo SET f3[2] = ''b99'' WHERE f1 = 11'); SELECT dblink_exec('UPDATE foo SET f3[2] = ''b99'' WHERE f1 = 11');
-- let's see it -- let's see it
SELECT * SELECT *
...@@ -135,7 +134,7 @@ FROM dblink('SELECT * FROM foo') AS t(a int, b text, c text[]) ...@@ -135,7 +134,7 @@ FROM dblink('SELECT * FROM foo') AS t(a int, b text, c text[])
WHERE a = 11; WHERE a = 11;
-- delete some data -- delete some data
SELECT dblink_exec('SET autocommit TO ''on'';DELETE FROM foo WHERE f1 = 11'); SELECT dblink_exec('DELETE FROM foo WHERE f1 = 11');
-- let's see it -- let's see it
SELECT * SELECT *
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE TRIGGER "MyTableName_Trig" CREATE TRIGGER "MyTableName_Trig"
AFTER INSERT OR DELETE OR UPDATE ON "MyTableName" AFTER INSERT OR DELETE OR UPDATE ON "MyTableName"
FOR EACH ROW EXECUTE PROCEDURE "recordchange" (); FOR EACH ROW EXECUTE PROCEDURE "recordchange" ();
......
...@@ -33,7 +33,7 @@ ...@@ -33,7 +33,7 @@
# #
# #
############################################################################## ##############################################################################
# $Id: DBMirror.pl,v 1.5 2002/12/05 21:03:51 momjian Exp $ # $Id: DBMirror.pl,v 1.6 2003/05/14 03:25:55 tgl Exp $
# #
############################################################################## ##############################################################################
...@@ -135,15 +135,6 @@ sub Main() { ...@@ -135,15 +135,6 @@ sub Main() {
die; die;
} }
my $setQuery2;
$setQuery2 = "SET autocommit TO 'on'";
my $setResult2 = $masterConn->exec($setQuery2);
if($setResult2->resultStatus!=PGRES_COMMAND_OK) {
logErrorMessage($masterConn->errorMessage . "\n" .
$setQuery2);
die;
}
my $firstTime = 1; my $firstTime = 1;
while(1) { while(1) {
if($firstTime == 0) { if($firstTime == 0) {
...@@ -158,7 +149,6 @@ sub Main() { ...@@ -158,7 +149,6 @@ sub Main() {
sendQueryToSlaves(undef,"SET autocommit TO 'on'");
sendQueryToSlaves(undef,"SET TRANSACTION ISOLATION LEVEL SERIALIZABLE"); sendQueryToSlaves(undef,"SET TRANSACTION ISOLATION LEVEL SERIALIZABLE");
sendQueryToSlaves(undef,"SET CONSTRAINTS ALL DEFERRED"); sendQueryToSlaves(undef,"SET CONSTRAINTS ALL DEFERRED");
......
SET autocommit TO 'on';
CREATE FUNCTION "recordchange" () RETURNS trigger AS CREATE FUNCTION "recordchange" () RETURNS trigger AS
'/usr/local/pgsql/lib/pending.so', 'recordchange' LANGUAGE 'C'; '/usr/local/pgsql/lib/pending.so', 'recordchange' LANGUAGE 'C';
......
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
# GNU General Public License for more details. # GNU General Public License for more details.
# #
############################################################################## ##############################################################################
# $Id: clean_pending.pl,v 1.2 2002/10/18 18:41:19 momjian Exp $ # $Id: clean_pending.pl,v 1.3 2003/05/14 03:25:55 tgl Exp $
############################################################################## ##############################################################################
...@@ -69,10 +69,6 @@ unless($dbConn->status == PGRES_CONNECTION_OK) { ...@@ -69,10 +69,6 @@ unless($dbConn->status == PGRES_CONNECTION_OK) {
printf("Can't connect to database\n"); printf("Can't connect to database\n");
die; die;
} }
my $setresult = $dbConn->exec("SET autocommit TO 'on'");
unless($setresult->resultStatus == PGRES_COMMAND_OK) {
die $dbConn->errorMessage;
}
my $result = $dbConn->exec("BEGIN"); my $result = $dbConn->exec("BEGIN");
unless($result->resultStatus == PGRES_COMMAND_OK) { unless($result->resultStatus == PGRES_COMMAND_OK) {
die $dbConn->errorMessage; die $dbConn->errorMessage;
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
-- The earth functions rely on contrib/cube having been installed and loaded. -- The earth functions rely on contrib/cube having been installed and loaded.
-- earth() returns the radius of the earth in meters. This is the only -- earth() returns the radius of the earth in meters. This is the only
......
...@@ -6,8 +6,8 @@ ...@@ -6,8 +6,8 @@
-- does not depend on contents of earthdistance.sql or cube.sql. -- does not depend on contents of earthdistance.sql or cube.sql.
-- --
\set ECHO none \set ECHO none
psql:../cube/cube.sql:12: NOTICE: ProcedureCreate: type cube is not yet defined psql:../cube/cube.sql:10: NOTICE: ProcedureCreate: type cube is not yet defined
psql:../cube/cube.sql:17: NOTICE: Argument type "cube" is only a shell psql:../cube/cube.sql:15: NOTICE: Argument type "cube" is only a shell
-- --
-- The radius of the Earth we are using. -- The radius of the Earth we are using.
-- --
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
* *
* Copyright 2002 by PostgreSQL Global Development Group * Copyright 2002 by PostgreSQL Global Development Group
* *
* $Header: /cvsroot/pgsql/contrib/findoidjoins/Attic/findoidjoins.c,v 1.19 2002/10/18 18:41:20 momjian Exp $ * $Header: /cvsroot/pgsql/contrib/findoidjoins/Attic/findoidjoins.c,v 1.20 2003/05/14 03:25:56 tgl Exp $
*/ */
#include "postgres_fe.h" #include "postgres_fe.h"
...@@ -49,7 +49,6 @@ main(int argc, char **argv) ...@@ -49,7 +49,6 @@ main(int argc, char **argv)
appendPQExpBuffer(&sql, "%s", appendPQExpBuffer(&sql, "%s",
"SET search_path = public;" "SET search_path = public;"
"SET autocommit TO 'on';"
"SELECT c.relname, (SELECT nspname FROM " "SELECT c.relname, (SELECT nspname FROM "
"pg_catalog.pg_namespace n WHERE n.oid = c.relnamespace) AS nspname " "pg_catalog.pg_namespace n WHERE n.oid = c.relnamespace) AS nspname "
"FROM pg_catalog.pg_class c " "FROM pg_catalog.pg_class c "
......
...@@ -167,7 +167,6 @@ sub main { ...@@ -167,7 +167,6 @@ sub main {
} }
PQexec($PG_CONN, "SET search_path = public"); PQexec($PG_CONN, "SET search_path = public");
PQexec($PG_CONN, "SET autocommit TO 'on'");
PQexec($PG_CONN, "begin"); PQexec($PG_CONN, "begin");
$query = "declare C cursor for select (\""; $query = "declare C cursor for select (\"";
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION fti() RETURNS trigger AS CREATE OR REPLACE FUNCTION fti() RETURNS trigger AS
'MODULE_PATHNAME', 'fti' 'MODULE_PATHNAME', 'fti'
LANGUAGE 'C' VOLATILE CALLED ON NULL INPUT; LANGUAGE 'C' VOLATILE CALLED ON NULL INPUT;
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
DROP FUNCTION fti() CASCADE; DROP FUNCTION fti() CASCADE;
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE FUNCTION levenshtein (text,text) CREATE FUNCTION levenshtein (text,text)
RETURNS int RETURNS int
AS 'MODULE_PATHNAME','levenshtein' AS 'MODULE_PATHNAME','levenshtein'
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
-- Internal function for the aggregate -- Internal function for the aggregate
-- Is called for each item in an aggregation -- Is called for each item in an aggregation
CREATE OR REPLACE FUNCTION int_agg_state (int4, int4) CREATE OR REPLACE FUNCTION int_agg_state (int4, int4)
......
...@@ -6,8 +6,6 @@ ...@@ -6,8 +6,6 @@
-- opclasses get created. -- opclasses get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
-- Query type -- Query type
CREATE FUNCTION bqarr_in(cstring) CREATE FUNCTION bqarr_in(cstring)
RETURNS query_int RETURNS query_int
......
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
-- does not depend on contents of seg.sql. -- does not depend on contents of seg.sql.
-- --
\set ECHO none \set ECHO none
psql:_int.sql:15: NOTICE: ProcedureCreate: type query_int is not yet defined psql:_int.sql:13: NOTICE: ProcedureCreate: type query_int is not yet defined
psql:_int.sql:20: NOTICE: Argument type "query_int" is only a shell psql:_int.sql:18: NOTICE: Argument type "query_int" is only a shell
SELECT intset(1234); SELECT intset(1234);
intset intset
-------- --------
......
-- --
-- PostgreSQL code for ISSNs. -- PostgreSQL code for ISSNs.
-- --
-- $Id: isbn_issn.sql.in,v 1.7 2002/10/18 18:41:20 momjian Exp $ -- $Id: isbn_issn.sql.in,v 1.8 2003/05/14 03:25:56 tgl Exp $
-- --
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
-- --
-- Input and output functions and the type itself: -- Input and output functions and the type itself:
-- --
...@@ -124,7 +122,7 @@ CREATE OPERATOR <> ( ...@@ -124,7 +122,7 @@ CREATE OPERATOR <> (
-- --
-- PostgreSQL code for ISBNs. -- PostgreSQL code for ISBNs.
-- --
-- $Id: isbn_issn.sql.in,v 1.7 2002/10/18 18:41:20 momjian Exp $ -- $Id: isbn_issn.sql.in,v 1.8 2003/05/14 03:25:56 tgl Exp $
-- --
-- --
-- Input and output functions and the type itself: -- Input and output functions and the type itself:
......
-- --
-- PostgreSQL code for LargeObjects -- PostgreSQL code for LargeObjects
-- --
-- $Id: lo.sql.in,v 1.9 2002/12/31 10:22:03 inoue Exp $ -- $Id: lo.sql.in,v 1.10 2003/05/14 03:25:56 tgl Exp $
-- --
-- --
-- Create the data type -- Create the data type
...@@ -12,8 +12,6 @@ ...@@ -12,8 +12,6 @@
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE FUNCTION lo_in(cstring) CREATE FUNCTION lo_in(cstring)
RETURNS lo RETURNS lo
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
...@@ -6,8 +6,6 @@ ...@@ -6,8 +6,6 @@
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
-- remove our test table -- remove our test table
DROP TABLE a; DROP TABLE a;
......
\set ECHO none \set ECHO none
psql:ltree.sql:9: NOTICE: ProcedureCreate: type ltree is not yet defined psql:ltree.sql:7: NOTICE: ProcedureCreate: type ltree is not yet defined
psql:ltree.sql:14: NOTICE: Argument type "ltree" is only a shell psql:ltree.sql:12: NOTICE: Argument type "ltree" is only a shell
psql:ltree.sql:301: NOTICE: ProcedureCreate: type lquery is not yet defined psql:ltree.sql:299: NOTICE: ProcedureCreate: type lquery is not yet defined
psql:ltree.sql:306: NOTICE: Argument type "lquery" is only a shell psql:ltree.sql:304: NOTICE: Argument type "lquery" is only a shell
psql:ltree.sql:412: NOTICE: ProcedureCreate: type ltxtquery is not yet defined psql:ltree.sql:410: NOTICE: ProcedureCreate: type ltxtquery is not yet defined
psql:ltree.sql:417: NOTICE: Argument type "ltxtquery" is only a shell psql:ltree.sql:415: NOTICE: Argument type "ltxtquery" is only a shell
psql:ltree.sql:479: NOTICE: ProcedureCreate: type ltree_gist is not yet defined psql:ltree.sql:477: NOTICE: ProcedureCreate: type ltree_gist is not yet defined
psql:ltree.sql:484: NOTICE: Argument type "ltree_gist" is only a shell psql:ltree.sql:482: NOTICE: Argument type "ltree_gist" is only a shell
SELECT ''::ltree; SELECT ''::ltree;
ltree ltree
------- -------
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE FUNCTION ltree_in(cstring) CREATE FUNCTION ltree_in(cstring)
RETURNS ltree RETURNS ltree
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
...@@ -13,8 +13,6 @@ ...@@ -13,8 +13,6 @@
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION backend_pid() CREATE OR REPLACE FUNCTION backend_pid()
RETURNS int4 RETURNS int4
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION noup () CREATE OR REPLACE FUNCTION noup ()
RETURNS trigger RETURNS trigger
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
...@@ -247,8 +247,6 @@ sql_conn(const char *dbName, struct options * my_opts) ...@@ -247,8 +247,6 @@ sql_conn(const char *dbName, struct options * my_opts)
sql_exec(conn, "SET search_path = public;", 0); sql_exec(conn, "SET search_path = public;", 0);
sql_exec(conn, "SET autocommit TO 'on';", 0);
/* return the conn if good */ /* return the conn if good */
return conn; return conn;
} }
......
/* ------------------------------------------------------------------------- /* -------------------------------------------------------------------------
* pg_dumplo * pg_dumplo
* *
* $Header: /cvsroot/pgsql/contrib/pg_dumplo/Attic/main.c,v 1.15 2003/01/09 18:27:39 tgl Exp $ * $Header: /cvsroot/pgsql/contrib/pg_dumplo/Attic/main.c,v 1.16 2003/05/14 03:25:56 tgl Exp $
* *
* Karel Zak 1999-2000 * Karel Zak 1999-2000
* ------------------------------------------------------------------------- * -------------------------------------------------------------------------
...@@ -191,8 +191,6 @@ main(int argc, char **argv) ...@@ -191,8 +191,6 @@ main(int argc, char **argv)
PQexec(pgLO->conn, "SET search_path = public"); PQexec(pgLO->conn, "SET search_path = public");
PQexec(pgLO->conn, "SET autocommit TO 'on'");
PQexec(pgLO->conn, "BEGIN"); PQexec(pgLO->conn, "BEGIN");
switch (pgLO->action) switch (pgLO->action)
......
/* /*
* $Header: /cvsroot/pgsql/contrib/pgbench/pgbench.c,v 1.22 2002/10/20 19:38:10 tgl Exp $ * $Header: /cvsroot/pgsql/contrib/pgbench/pgbench.c,v 1.23 2003/05/14 03:25:56 tgl Exp $
* *
* pgbench: a simple TPC-B like benchmark program for PostgreSQL * pgbench: a simple TPC-B like benchmark program for PostgreSQL
* written by Tatsuo Ishii * written by Tatsuo Ishii
...@@ -147,13 +147,6 @@ doConnect() ...@@ -147,13 +147,6 @@ doConnect()
exit(1); exit(1);
} }
PQclear(res); PQclear(res);
res = PQexec(con, "SET autocommit TO 'on'");
if (PQresultStatus(res) != PGRES_COMMAND_OK)
{
fprintf(stderr, "%s", PQerrorMessage(con));
exit(1);
}
PQclear(res);
return (con); return (con);
} }
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION digest(text, text) CREATE OR REPLACE FUNCTION digest(text, text)
RETURNS bytea RETURNS bytea
AS 'MODULE_PATHNAME', 'pg_digest' AS 'MODULE_PATHNAME', 'pg_digest'
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
DROP TYPE pgstattuple_type CASCADE; DROP TYPE pgstattuple_type CASCADE;
CREATE TYPE pgstattuple_type AS ( CREATE TYPE pgstattuple_type AS (
table_len BIGINT, -- physical table length in bytes table_len BIGINT, -- physical table length in bytes
......
#!/bin/sh #!/bin/sh
# -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=- # # -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=- #
# Package : reindexdb Version : $Revision: 1.3 $ # Package : reindexdb Version : $Revision: 1.4 $
# Date : 05/08/2002 Author : Shaun Thomas # Date : 05/08/2002 Author : Shaun Thomas
# Req : psql, sh, perl, sed Type : Utility # Req : psql, sh, perl, sed Type : Utility
# #
...@@ -193,11 +193,11 @@ fi ...@@ -193,11 +193,11 @@ fi
# If index was set, reindex that index. # If index was set, reindex that index.
if [ "$index" ]; then if [ "$index" ]; then
$PSQL $PSQLOPT $ECHOOPT -c "SET autocommit TO 'on';REINDEX INDEX $index" -d $dbname $PSQL $PSQLOPT $ECHOOPT -c "REINDEX INDEX $index" -d $dbname
# Ok, no index. Is there a specific table to reindex? # Ok, no index. Is there a specific table to reindex?
elif [ "$table" ]; then elif [ "$table" ]; then
$PSQL $PSQLOPT $ECHOOPT -c "SET autocommit TO 'on';REINDEX TABLE \"$table\"" -d $dbname $PSQL $PSQLOPT $ECHOOPT -c "REINDEX TABLE \"$table\"" -d $dbname
# No specific table, no specific index, either we have a specific database, # No specific table, no specific index, either we have a specific database,
# or were told to do all databases. Do it! # or were told to do all databases. Do it!
...@@ -213,9 +213,9 @@ else ...@@ -213,9 +213,9 @@ else
# Ok, reindex every table in the database. Use the same method # Ok, reindex every table in the database. Use the same method
# we used to get a list of databases, and get a list of tables in this # we used to get a list of databases, and get a list of tables in this
# database that we may reindex. # database that we may reindex.
tables=`$PSQL $PSQLOPT -q -t -A -d $db -c "SET autocommit TO 'on';$sql"` tables=`$PSQL $PSQLOPT -q -t -A -d $db -c "$sql"`
for tab in $tables; do for tab in $tables; do
$PSQL $PSQLOPT $ECHOOPT -c "SET autocommit TO 'on';REINDEX TABLE \"$tab\"" -d $db $PSQL $PSQLOPT $ECHOOPT -c "REINDEX TABLE \"$tab\"" -d $db
done done
done done
......
...@@ -32,13 +32,6 @@ my $setsql = qq{ ...@@ -32,13 +32,6 @@ my $setsql = qq{
my $sth = $dbi->prepare($setsql); my $sth = $dbi->prepare($setsql);
$sth->execute(); $sth->execute();
my $setsql2 = qq{
SET autocommit TO 'on';
};
my $sth2 = $dbi->prepare($setsql2);
$sth2->execute();
my $sql; my $sql;
my $notice; my $notice;
my $sss = '(3000,3000,2990,2990)'; my $sss = '(3000,3000,2990,2990)';
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
-- --
-- --
-- --
......
...@@ -6,8 +6,8 @@ ...@@ -6,8 +6,8 @@
-- does not depend on contents of seg.sql. -- does not depend on contents of seg.sql.
-- --
\set ECHO none \set ECHO none
psql:seg.sql:12: NOTICE: ProcedureCreate: type seg is not yet defined psql:seg.sql:10: NOTICE: ProcedureCreate: type seg is not yet defined
psql:seg.sql:17: NOTICE: Argument type "seg" is only a shell psql:seg.sql:15: NOTICE: Argument type "seg" is only a shell
-- --
-- testing the input and output functions -- testing the input and output functions
-- --
...@@ -395,25 +395,25 @@ SELECT '100(+-)1'::seg AS seg; ...@@ -395,25 +395,25 @@ SELECT '100(+-)1'::seg AS seg;
SELECT ''::seg AS seg; SELECT ''::seg AS seg;
ERROR: seg_in: can't parse an empty string ERROR: seg_in: can't parse an empty string
SELECT 'ABC'::seg AS seg; SELECT 'ABC'::seg AS seg;
ERROR: parse error at or near position 1, character ('A', \101), input: 'ABC' ERROR: syntax error at or near position 1, character ('A', \101), input: 'ABC'
SELECT '1ABC'::seg AS seg; SELECT '1ABC'::seg AS seg;
ERROR: parse error at or near position 2, character ('A', \101), input: '1ABC' ERROR: syntax error at or near position 2, character ('A', \101), input: '1ABC'
SELECT '1.'::seg AS seg; SELECT '1.'::seg AS seg;
ERROR: parse error at or near position 2, character ('.', \056), input: '1.' ERROR: syntax error at or near position 2, character ('.', \056), input: '1.'
SELECT '1.....'::seg AS seg; SELECT '1.....'::seg AS seg;
ERROR: parse error at or near position 6, character ('.', \056), input: '1.....' ERROR: syntax error at or near position 6, character ('.', \056), input: '1.....'
SELECT '.1'::seg AS seg; SELECT '.1'::seg AS seg;
ERROR: parse error at or near position 2, character ('1', \061), input: '.1' ERROR: syntax error at or near position 2, character ('1', \061), input: '.1'
SELECT '1..2.'::seg AS seg; SELECT '1..2.'::seg AS seg;
ERROR: parse error at or near position 5, character ('.', \056), input: '1..2.' ERROR: syntax error at or near position 5, character ('.', \056), input: '1..2.'
SELECT '1 e7'::seg AS seg; SELECT '1 e7'::seg AS seg;
ERROR: parse error at or near position 3, character ('e', \145), input: '1 e7' ERROR: syntax error at or near position 3, character ('e', \145), input: '1 e7'
SELECT '1e700'::seg AS seg; SELECT '1e700'::seg AS seg;
ERROR: numeric value 1e700 unrepresentable ERROR: numeric value 1e700 unrepresentable
......
...@@ -4,8 +4,6 @@ ...@@ -4,8 +4,6 @@
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE FUNCTION seg_in(cstring) CREATE FUNCTION seg_in(cstring)
RETURNS seg RETURNS seg
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION autoinc() CREATE OR REPLACE FUNCTION autoinc()
RETURNS trigger RETURNS trigger
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION insert_username() CREATE OR REPLACE FUNCTION insert_username()
RETURNS trigger RETURNS trigger
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION moddatetime() CREATE OR REPLACE FUNCTION moddatetime()
RETURNS trigger RETURNS trigger
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION check_primary_key() CREATE OR REPLACE FUNCTION check_primary_key()
RETURNS trigger RETURNS trigger
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION timetravel() CREATE OR REPLACE FUNCTION timetravel()
RETURNS trigger RETURNS trigger
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION normal_rand(int4, float8, float8, int4) CREATE OR REPLACE FUNCTION normal_rand(int4, float8, float8, int4)
RETURNS setof float8 RETURNS setof float8
AS 'MODULE_PATHNAME','normal_rand' AS 'MODULE_PATHNAME','normal_rand'
......
...@@ -3,14 +3,14 @@ ...@@ -3,14 +3,14 @@
-- does not depend on contents of seg.sql. -- does not depend on contents of seg.sql.
-- --
\set ECHO none \set ECHO none
psql:tsearch.sql:11: NOTICE: ProcedureCreate: type txtidx is not yet defined psql:tsearch.sql:9: NOTICE: ProcedureCreate: type txtidx is not yet defined
psql:tsearch.sql:16: NOTICE: Argument type "txtidx" is only a shell psql:tsearch.sql:14: NOTICE: Argument type "txtidx" is only a shell
psql:tsearch.sql:40: NOTICE: ProcedureCreate: type query_txt is not yet defined psql:tsearch.sql:38: NOTICE: ProcedureCreate: type query_txt is not yet defined
psql:tsearch.sql:45: NOTICE: Argument type "query_txt" is only a shell psql:tsearch.sql:43: NOTICE: Argument type "query_txt" is only a shell
psql:tsearch.sql:57: NOTICE: ProcedureCreate: type mquery_txt is not yet defined psql:tsearch.sql:55: NOTICE: ProcedureCreate: type mquery_txt is not yet defined
psql:tsearch.sql:63: NOTICE: Argument type "mquery_txt" is only a shell psql:tsearch.sql:61: NOTICE: Argument type "mquery_txt" is only a shell
psql:tsearch.sql:158: NOTICE: ProcedureCreate: type gtxtidx is not yet defined psql:tsearch.sql:156: NOTICE: ProcedureCreate: type gtxtidx is not yet defined
psql:tsearch.sql:163: NOTICE: Argument type "gtxtidx" is only a shell psql:tsearch.sql:161: NOTICE: Argument type "gtxtidx" is only a shell
--txtidx --txtidx
SELECT '1'::txtidx; SELECT '1'::txtidx;
txtidx txtidx
......
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
-- TXTIDX type -- TXTIDX type
CREATE FUNCTION txtidx_in(cstring) CREATE FUNCTION txtidx_in(cstring)
......
...@@ -12,8 +12,6 @@ ...@@ -12,8 +12,6 @@
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path = public; SET search_path = public;
SET autocommit TO 'on';
CREATE OR REPLACE FUNCTION user_lock(int4,int4,int4) CREATE OR REPLACE FUNCTION user_lock(int4,int4,int4)
RETURNS int4 RETURNS int4
AS 'MODULE_PATHNAME' AS 'MODULE_PATHNAME'
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/contrib/vacuumlo/vacuumlo.c,v 1.19 2002/12/10 01:57:16 momjian Exp $ * $Header: /cvsroot/pgsql/contrib/vacuumlo/vacuumlo.c,v 1.20 2003/05/14 03:25:57 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -218,17 +218,6 @@ vacuumlo(char *database, struct _param * param) ...@@ -218,17 +218,6 @@ vacuumlo(char *database, struct _param * param)
} }
PQclear(res); PQclear(res);
res = PQexec(conn, "SET autocommit TO 'on'");
if (PQresultStatus(res) != PGRES_COMMAND_OK)
{
fprintf(stderr, "Failed to set autocommit on:\n");
fprintf(stderr, "%s", PQerrorMessage(conn));
PQclear(res);
PQfinish(conn);
return -1;
}
PQclear(res);
/* /*
* First we create and populate the LO temp table * First we create and populate the LO temp table
*/ */
......
...@@ -3,8 +3,6 @@ ...@@ -3,8 +3,6 @@
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path TO public; SET search_path TO public;
SET autocommit TO on;
CREATE OR REPLACE FUNCTION pgxml_parse(text) RETURNS boolean CREATE OR REPLACE FUNCTION pgxml_parse(text) RETURNS boolean
AS 'MODULE_PATHNAME' LANGUAGE c STRICT; AS 'MODULE_PATHNAME' LANGUAGE c STRICT;
......
...@@ -3,8 +3,6 @@ ...@@ -3,8 +3,6 @@
-- Adjust this setting to control where the objects get created. -- Adjust this setting to control where the objects get created.
SET search_path TO public; SET search_path TO public;
SET autocommit TO on;
CREATE OR REPLACE FUNCTION pgxml_parse(text) RETURNS boolean CREATE OR REPLACE FUNCTION pgxml_parse(text) RETURNS boolean
AS 'MODULE_PATHNAME' LANGUAGE c STRICT; AS 'MODULE_PATHNAME' LANGUAGE c STRICT;
......
<!-- <!--
$Header: /cvsroot/pgsql/doc/src/sgml/libpq.sgml,v 1.122 2003/04/28 19:30:49 tgl Exp $ $Header: /cvsroot/pgsql/doc/src/sgml/libpq.sgml,v 1.123 2003/05/14 03:25:58 tgl Exp $
--> -->
<chapter id="libpq"> <chapter id="libpq">
...@@ -866,8 +866,13 @@ returned by the server. ...@@ -866,8 +866,13 @@ returned by the server.
maintain the <structname>PGresult</structname> abstraction. Use the accessor functions below to get maintain the <structname>PGresult</structname> abstraction. Use the accessor functions below to get
at the contents of <structname>PGresult</structname>. Avoid directly referencing the fields of the at the contents of <structname>PGresult</structname>. Avoid directly referencing the fields of the
<structname>PGresult</structname> structure because they are subject to change in the future. <structname>PGresult</structname> structure because they are subject to change in the future.
If <quote>autocommit</quote> is on, multiple queries sent in a single </para>
function call are processed in a single transaction.
<para>
Multiple queries sent in a single
function call are processed in a single transaction, unless there are explicit
BEGIN/COMMIT commands included in the query string to divide it into multiple
transactions.
</para> </para>
<variablelist> <variablelist>
......
<!-- <!--
$Header: /cvsroot/pgsql/doc/src/sgml/ref/begin.sgml,v 1.23 2003/04/15 13:25:08 petere Exp $ $Header: /cvsroot/pgsql/doc/src/sgml/ref/begin.sgml,v 1.24 2003/05/14 03:26:00 tgl Exp $
PostgreSQL documentation PostgreSQL documentation
--> -->
...@@ -98,12 +98,6 @@ BEGIN [ WORK | TRANSACTION ] ...@@ -98,12 +98,6 @@ BEGIN [ WORK | TRANSACTION ]
<xref linkend="SQL-ROLLBACK" endterm="SQL-ROLLBACK-TITLE"> <xref linkend="SQL-ROLLBACK" endterm="SQL-ROLLBACK-TITLE">
to terminate a transaction. to terminate a transaction.
</para> </para>
<para>
If you turn the configuration parameter <varname>autocommit</> off,
then <command>BEGIN</> is not required: any SQL command
automatically starts a transaction.
</para>
</refsect1> </refsect1>
<refsect1> <refsect1>
......
<!-- <!--
$Header: /cvsroot/pgsql/doc/src/sgml/ref/psql-ref.sgml,v 1.88 2003/03/25 16:15:43 petere Exp $ $Header: /cvsroot/pgsql/doc/src/sgml/ref/psql-ref.sgml,v 1.89 2003/05/14 03:26:00 tgl Exp $
PostgreSQL documentation PostgreSQL documentation
--> -->
...@@ -88,9 +88,11 @@ PostgreSQL documentation ...@@ -88,9 +88,11 @@ PostgreSQL documentation
select * from foo;" | psql</literal>. select * from foo;" | psql</literal>.
</para> </para>
<para> <para>
If <quote>autocommit</quote> is on, multiple queries in a single If the command string contains multiple SQL commands, they are
string are processed in a single transaction. processed in a single transaction, unless there are explicit
BEGIN/COMMIT commands included in the string to divide it into
multiple transactions. This is different from the behavior when
the same string is fed to psql's standard input.
</para> </para>
</listitem> </listitem>
</varlistentry> </varlistentry>
......
<!-- <!--
$Header: /cvsroot/pgsql/doc/src/sgml/ref/set.sgml,v 1.75 2003/05/04 02:23:16 petere Exp $ $Header: /cvsroot/pgsql/doc/src/sgml/ref/set.sgml,v 1.76 2003/05/14 03:26:00 tgl Exp $
PostgreSQL documentation PostgreSQL documentation
--> -->
...@@ -55,12 +55,6 @@ SET [ SESSION | LOCAL ] TIME ZONE { <replaceable class="PARAMETER">timezone</rep ...@@ -55,12 +55,6 @@ SET [ SESSION | LOCAL ] TIME ZONE { <replaceable class="PARAMETER">timezone</rep
seen until the end of the transaction, but afterwards (if the transaction seen until the end of the transaction, but afterwards (if the transaction
is committed) the <command>SET</command> value will take effect. is committed) the <command>SET</command> value will take effect.
</para> </para>
<para>
Even with <varname>autocommit</> set to <literal>off</>, <command>SET</>
does not start a new transaction block. See the
<varname>autocommit</> section in <xref linkend="runtime-config"> for details.
</para>
</refsect1> </refsect1>
<refsect1> <refsect1>
......
<!-- <!--
$Header: /cvsroot/pgsql/doc/src/sgml/ref/show.sgml,v 1.26 2003/05/04 02:23:16 petere Exp $ $Header: /cvsroot/pgsql/doc/src/sgml/ref/show.sgml,v 1.27 2003/05/14 03:26:00 tgl Exp $
PostgreSQL documentation PostgreSQL documentation
--> -->
...@@ -37,12 +37,6 @@ SHOW ALL ...@@ -37,12 +37,6 @@ SHOW ALL
<command>postmaster</command>. See <xref <command>postmaster</command>. See <xref
linkend="runtime-config"> for details. linkend="runtime-config"> for details.
</para> </para>
<para>
Even with <varname>autocommit</> set to <literal>off</>, <command>SHOW</>
does not start a new transaction block. See the
<varname>autocommit</> section in <xref linkend="runtime-config"> for details.
</para>
</refsect1> </refsect1>
<refsect1> <refsect1>
......
<!-- <!--
$Header: /cvsroot/pgsql/doc/src/sgml/release.sgml,v 1.186 2003/03/21 01:58:04 tgl Exp $ $Header: /cvsroot/pgsql/doc/src/sgml/release.sgml,v 1.187 2003/05/14 03:25:59 tgl Exp $
--> -->
<appendix id="release"> <appendix id="release">
...@@ -24,6 +24,8 @@ CDATA means the content is "SGML-free", so you can write without ...@@ -24,6 +24,8 @@ CDATA means the content is "SGML-free", so you can write without
worries about funny characters. worries about funny characters.
--> -->
<literallayout><![CDATA[ <literallayout><![CDATA[
New frontend/backend protocol supports many long-requested features
SET AUTOCOMMIT TO OFF is no longer supported
Reimplementation of NUMERIC datatype for more speed Reimplementation of NUMERIC datatype for more speed
New regular expression package, many more regexp features (most of Perl5) New regular expression package, many more regexp features (most of Perl5)
Can now do EXPLAIN ... EXECUTE to see plan used for a prepared query Can now do EXPLAIN ... EXECUTE to see plan used for a prepared query
......
<!-- <!--
$Header: /cvsroot/pgsql/doc/src/sgml/runtime.sgml,v 1.178 2003/05/04 02:23:16 petere Exp $ $Header: /cvsroot/pgsql/doc/src/sgml/runtime.sgml,v 1.179 2003/05/14 03:26:00 tgl Exp $
--> -->
<Chapter Id="runtime"> <Chapter Id="runtime">
...@@ -1289,56 +1289,6 @@ SET ENABLE_SEQSCAN TO OFF; ...@@ -1289,56 +1289,6 @@ SET ENABLE_SEQSCAN TO OFF;
<title>General Operation</title> <title>General Operation</title>
<variablelist> <variablelist>
<varlistentry>
<term><varname>AUTOCOMMIT</varname> (<type>boolean</type>)</term>
<indexterm><primary>autocommit</></>
<listitem>
<para>
If set to true, <productname>PostgreSQL</productname> will
automatically do a <command>COMMIT</> after each successful command
that is not inside an explicit transaction block (that is, unless a
<command>BEGIN</> with no matching <command>COMMIT</> has been
given).
If set to false, <productname>PostgreSQL</productname> will
commit only upon receiving an explicit
<command>COMMIT</> command. This mode can also be thought of as
implicitly issuing <command>BEGIN</> whenever a command is
received that is not already inside a transaction block. The
default is true, for compatibility with historical
<productname>PostgreSQL</productname> behavior. However, for
maximum compatibility with the SQL specification, set it to
false.
</para>
<note>
<para>
Even with <varname>autocommit</> set to false, <command>SET</>,
<command>SHOW</>, and <command>RESET</> do not start new
transaction blocks. They are run in their own transactions.
Once another command is issued, a transaction block
begins and any <command>SET</>, <command>SHOW</>, or
<command>RESET</> commands are considered to be part of the
transaction, i.e., they are committed or rolled back depending
on the completion status of the transaction. To execute a
<command>SET</>, <command>SHOW</>, or <command>RESET</>
command at the start of a transaction block, use <command>BEGIN</>
first.
</para>
</note>
<note>
<para>
As of <productname>PostgreSQL</productname> 7.3, setting
<varname>autocommit</> to false is not well-supported.
This is a new feature and is not yet handled by all client
libraries and applications. Before making it the default
setting in your installation, test carefully.
</para>
</note>
</listitem>
</varlistentry>
<varlistentry> <varlistentry>
<term><varname>AUSTRALIAN_TIMEZONES</varname> (<type>boolean</type>)</term> <term><varname>AUSTRALIAN_TIMEZONES</varname> (<type>boolean</type>)</term>
<indexterm><primary>Australian time zones</></> <indexterm><primary>Australian time zones</></>
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/access/transam/xact.c,v 1.147 2003/05/02 20:54:33 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/access/transam/xact.c,v 1.148 2003/05/14 03:26:00 tgl Exp $
* *
* NOTES * NOTES
* Transaction aborts can now occur two ways: * Transaction aborts can now occur two ways:
...@@ -212,15 +212,11 @@ int XactIsoLevel; ...@@ -212,15 +212,11 @@ int XactIsoLevel;
bool DefaultXactReadOnly = false; bool DefaultXactReadOnly = false;
bool XactReadOnly; bool XactReadOnly;
bool autocommit = true;
int CommitDelay = 0; /* precommit delay in microseconds */ int CommitDelay = 0; /* precommit delay in microseconds */
int CommitSiblings = 5; /* number of concurrent xacts needed to int CommitSiblings = 5; /* number of concurrent xacts needed to
* sleep */ * sleep */
static bool suppressChain = false;
static void (*_RollbackFunc) (void *) = NULL; static void (*_RollbackFunc) (void *) = NULL;
static void *_RollbackData = NULL; static void *_RollbackData = NULL;
...@@ -1125,23 +1121,12 @@ CleanupTransaction(void) ...@@ -1125,23 +1121,12 @@ CleanupTransaction(void)
/* /*
* StartTransactionCommand * StartTransactionCommand
*
* preventChain, if true, forces autocommit behavior at the next
* CommitTransactionCommand call.
*/ */
void void
StartTransactionCommand(bool preventChain) StartTransactionCommand(void)
{ {
TransactionState s = CurrentTransactionState; TransactionState s = CurrentTransactionState;
/*
* Remember if caller wants to prevent autocommit-off chaining. This
* is only allowed if not already in a transaction block.
*/
suppressChain = preventChain;
if (preventChain && s->blockState != TBLOCK_DEFAULT)
elog(ERROR, "StartTransactionCommand: can't prevent chain");
switch (s->blockState) switch (s->blockState)
{ {
/* /*
...@@ -1217,44 +1202,20 @@ StartTransactionCommand(bool preventChain) ...@@ -1217,44 +1202,20 @@ StartTransactionCommand(bool preventChain)
/* /*
* CommitTransactionCommand * CommitTransactionCommand
*
* forceCommit = true forces autocommit behavior even when autocommit is off.
*/ */
void void
CommitTransactionCommand(bool forceCommit) CommitTransactionCommand(void)
{ {
TransactionState s = CurrentTransactionState; TransactionState s = CurrentTransactionState;
switch (s->blockState) switch (s->blockState)
{ {
/* /*
* If we aren't in a transaction block, and we are doing * If we aren't in a transaction block, just do our usual
* autocommit, just do our usual transaction commit. But if * transaction commit.
* we aren't doing autocommit, start a transaction block
* automatically by switching to INPROGRESS state. (We handle
* this choice here, and not earlier, so that an explicit
* BEGIN issued in autocommit-off mode won't issue strange
* warnings.)
*
* Autocommit mode is forced by either a true forceCommit
* parameter to me, or a true preventChain parameter to the
* preceding StartTransactionCommand call, or a
* PreventTransactionChain call during the transaction.
* (The parameters could be omitted, but it turns out most
* callers of StartTransactionCommand/CommitTransactionCommand
* want to force autocommit, so making them all call
* PreventTransactionChain would just be extra notation.)
*/ */
case TBLOCK_DEFAULT: case TBLOCK_DEFAULT:
if (autocommit || forceCommit || suppressChain) CommitTransaction();
CommitTransaction();
else
{
BeginTransactionBlock();
Assert(s->blockState == TBLOCK_INPROGRESS);
/* This code must match the TBLOCK_INPROGRESS case below: */
CommandCounterIncrement();
}
break; break;
/* /*
...@@ -1323,10 +1284,7 @@ AbortCurrentTransaction(void) ...@@ -1323,10 +1284,7 @@ AbortCurrentTransaction(void)
*/ */
case TBLOCK_DEFAULT: case TBLOCK_DEFAULT:
AbortTransaction(); AbortTransaction();
if (autocommit || suppressChain) CleanupTransaction();
CleanupTransaction();
else
s->blockState = TBLOCK_ABORT;
break; break;
/* /*
...@@ -1396,9 +1354,7 @@ AbortCurrentTransaction(void) ...@@ -1396,9 +1354,7 @@ AbortCurrentTransaction(void)
* If we have already started a transaction block, issue an error; also issue * If we have already started a transaction block, issue an error; also issue
* an error if we appear to be running inside a user-defined function (which * an error if we appear to be running inside a user-defined function (which
* could issue more commands and possibly cause a failure after the statement * could issue more commands and possibly cause a failure after the statement
* completes). In autocommit-off mode, we allow the statement if a block is * completes).
* not already started, and force the statement to be autocommitted despite
* the mode.
* *
* stmtNode: pointer to parameter block for statement; this is used in * stmtNode: pointer to parameter block for statement; this is used in
* a very klugy way to determine whether we are inside a function. * a very klugy way to determine whether we are inside a function.
...@@ -1428,14 +1384,7 @@ PreventTransactionChain(void *stmtNode, const char *stmtType) ...@@ -1428,14 +1384,7 @@ PreventTransactionChain(void *stmtNode, const char *stmtType)
/* If we got past IsTransactionBlock test, should be in default state */ /* If we got past IsTransactionBlock test, should be in default state */
if (CurrentTransactionState->blockState != TBLOCK_DEFAULT) if (CurrentTransactionState->blockState != TBLOCK_DEFAULT)
elog(ERROR, "PreventTransactionChain: can't prevent chain"); elog(ERROR, "PreventTransactionChain: can't prevent chain");
/* okay to set the flag */ /* all okay */
suppressChain = true;
/* If we're in autocommit-off node, generate a notice */
if (!autocommit)
{
/* translator: %s represents an SQL statement name */
elog(NOTICE, "%s will be committed automatically", stmtType);
}
} }
/* /*
...@@ -1470,12 +1419,6 @@ RequireTransactionChain(void *stmtNode, const char *stmtType) ...@@ -1470,12 +1419,6 @@ RequireTransactionChain(void *stmtNode, const char *stmtType)
*/ */
if (!MemoryContextContains(QueryContext, stmtNode)) if (!MemoryContextContains(QueryContext, stmtNode))
return; return;
/*
* If we are in autocommit-off mode then it's okay, because this
* statement will itself start a transaction block.
*/
if (!autocommit && !suppressChain)
return;
/* translator: %s represents an SQL statement name */ /* translator: %s represents an SQL statement name */
elog(ERROR, "%s may only be used in begin/end transaction blocks", elog(ERROR, "%s may only be used in begin/end transaction blocks",
stmtType); stmtType);
...@@ -1507,10 +1450,7 @@ BeginTransactionBlock(void) ...@@ -1507,10 +1450,7 @@ BeginTransactionBlock(void)
s->blockState = TBLOCK_BEGIN; s->blockState = TBLOCK_BEGIN;
/* /*
* do begin processing. NOTE: if you put anything here, check that it * do begin processing here. Nothing to do at present.
* behaves properly in both autocommit-on and autocommit-off modes. In
* the latter case we will already have done some work in the new
* transaction.
*/ */
/* /*
......
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/bootstrap/bootparse.y,v 1.55 2002/11/11 22:19:21 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/bootstrap/bootparse.y,v 1.56 2003/05/14 03:26:00 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -55,7 +55,7 @@ ...@@ -55,7 +55,7 @@
static void static void
do_start() do_start()
{ {
StartTransactionCommand(true); StartTransactionCommand();
elog(DEBUG3, "start transaction"); elog(DEBUG3, "start transaction");
} }
...@@ -63,7 +63,7 @@ do_start() ...@@ -63,7 +63,7 @@ do_start()
static void static void
do_end() do_end()
{ {
CommitTransactionCommand(true); CommitTransactionCommand();
elog(DEBUG3, "commit transaction"); elog(DEBUG3, "commit transaction");
if (isatty(0)) if (isatty(0))
{ {
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/bootstrap/bootstrap.c,v 1.156 2003/05/08 14:49:03 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/bootstrap/bootstrap.c,v 1.157 2003/05/14 03:26:00 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -479,7 +479,7 @@ BootstrapMain(int argc, char *argv[]) ...@@ -479,7 +479,7 @@ BootstrapMain(int argc, char *argv[])
SetProcessingMode(BootstrapProcessing); SetProcessingMode(BootstrapProcessing);
/* clean up processing */ /* clean up processing */
StartTransactionCommand(true); StartTransactionCommand();
cleanup(); cleanup();
/* not reached, here to make compiler happy */ /* not reached, here to make compiler happy */
...@@ -851,7 +851,7 @@ cleanup() ...@@ -851,7 +851,7 @@ cleanup()
} }
if (boot_reldesc != NULL) if (boot_reldesc != NULL)
closerel(NULL); closerel(NULL);
CommitTransactionCommand(true); CommitTransactionCommand();
proc_exit(Warnings); proc_exit(Warnings);
} }
......
...@@ -13,7 +13,7 @@ ...@@ -13,7 +13,7 @@
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/catalog/namespace.c,v 1.50 2003/04/24 21:16:42 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/catalog/namespace.c,v 1.51 2003/05/14 03:26:01 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -1711,11 +1711,11 @@ RemoveTempRelationsCallback(void) ...@@ -1711,11 +1711,11 @@ RemoveTempRelationsCallback(void)
{ {
/* Need to ensure we have a usable transaction. */ /* Need to ensure we have a usable transaction. */
AbortOutOfAnyTransaction(); AbortOutOfAnyTransaction();
StartTransactionCommand(true); StartTransactionCommand();
RemoveTempRelations(myTempNamespace); RemoveTempRelations(myTempNamespace);
CommitTransactionCommand(true); CommitTransactionCommand();
} }
} }
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/commands/async.c,v 1.93 2003/04/22 00:08:06 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/commands/async.c,v 1.94 2003/05/14 03:26:01 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -399,9 +399,9 @@ Async_UnlistenOnExit(void) ...@@ -399,9 +399,9 @@ Async_UnlistenOnExit(void)
*/ */
AbortOutOfAnyTransaction(); AbortOutOfAnyTransaction();
/* Now we can do the unlisten */ /* Now we can do the unlisten */
StartTransactionCommand(true); StartTransactionCommand();
Async_UnlistenAll(); Async_UnlistenAll();
CommitTransactionCommand(true); CommitTransactionCommand();
} }
/* /*
...@@ -769,7 +769,7 @@ ProcessIncomingNotify(void) ...@@ -769,7 +769,7 @@ ProcessIncomingNotify(void)
notifyInterruptOccurred = 0; notifyInterruptOccurred = 0;
StartTransactionCommand(true); StartTransactionCommand();
lRel = heap_openr(ListenerRelationName, AccessExclusiveLock); lRel = heap_openr(ListenerRelationName, AccessExclusiveLock);
tdesc = RelationGetDescr(lRel); tdesc = RelationGetDescr(lRel);
...@@ -823,7 +823,7 @@ ProcessIncomingNotify(void) ...@@ -823,7 +823,7 @@ ProcessIncomingNotify(void)
*/ */
heap_close(lRel, NoLock); heap_close(lRel, NoLock);
CommitTransactionCommand(true); CommitTransactionCommand();
/* /*
* Must flush the notify messages to ensure frontend gets them * Must flush the notify messages to ensure frontend gets them
......
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/commands/cluster.c,v 1.108 2003/05/02 20:54:33 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/commands/cluster.c,v 1.109 2003/05/14 03:26:01 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -205,7 +205,7 @@ cluster(ClusterStmt *stmt) ...@@ -205,7 +205,7 @@ cluster(ClusterStmt *stmt)
rvs = get_tables_to_cluster(cluster_context); rvs = get_tables_to_cluster(cluster_context);
/* Commit to get out of starting transaction */ /* Commit to get out of starting transaction */
CommitTransactionCommand(true); CommitTransactionCommand();
/* Ok, now that we've got them all, cluster them one by one */ /* Ok, now that we've got them all, cluster them one by one */
foreach (rv, rvs) foreach (rv, rvs)
...@@ -213,14 +213,14 @@ cluster(ClusterStmt *stmt) ...@@ -213,14 +213,14 @@ cluster(ClusterStmt *stmt)
RelToCluster *rvtc = (RelToCluster *) lfirst(rv); RelToCluster *rvtc = (RelToCluster *) lfirst(rv);
/* Start a new transaction for each relation. */ /* Start a new transaction for each relation. */
StartTransactionCommand(true); StartTransactionCommand();
SetQuerySnapshot(); /* might be needed for functional index */ SetQuerySnapshot(); /* might be needed for functional index */
cluster_rel(rvtc, true); cluster_rel(rvtc, true);
CommitTransactionCommand(true); CommitTransactionCommand();
} }
/* Start a new transaction for the cleanup work. */ /* Start a new transaction for the cleanup work. */
StartTransactionCommand(true); StartTransactionCommand();
/* Clean up working storage */ /* Clean up working storage */
MemoryContextDelete(cluster_context); MemoryContextDelete(cluster_context);
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/commands/indexcmds.c,v 1.98 2003/05/02 20:54:33 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/commands/indexcmds.c,v 1.99 2003/05/14 03:26:01 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -769,17 +769,16 @@ ReindexDatabase(const char *dbname, bool force, bool all) ...@@ -769,17 +769,16 @@ ReindexDatabase(const char *dbname, bool force, bool all)
heap_close(relationRelation, AccessShareLock); heap_close(relationRelation, AccessShareLock);
/* Now reindex each rel in a separate transaction */ /* Now reindex each rel in a separate transaction */
CommitTransactionCommand(true); CommitTransactionCommand();
for (i = 0; i < relcnt; i++) for (i = 0; i < relcnt; i++)
{ {
StartTransactionCommand(true); StartTransactionCommand();
SetQuerySnapshot(); /* might be needed for functional index */ SetQuerySnapshot(); /* might be needed for functional index */
if (reindex_relation(relids[i], force)) if (reindex_relation(relids[i], force))
elog(NOTICE, "relation %u was reindexed", relids[i]); elog(NOTICE, "relation %u was reindexed", relids[i]);
CommitTransactionCommand(true); CommitTransactionCommand();
} }
/* Tell xact.c not to chain the upcoming commit */ StartTransactionCommand();
StartTransactionCommand(true);
MemoryContextDelete(private_context); MemoryContextDelete(private_context);
} }
...@@ -13,7 +13,7 @@ ...@@ -13,7 +13,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/commands/vacuum.c,v 1.252 2003/05/02 20:54:33 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/commands/vacuum.c,v 1.253 2003/05/14 03:26:01 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -275,7 +275,7 @@ vacuum(VacuumStmt *vacstmt) ...@@ -275,7 +275,7 @@ vacuum(VacuumStmt *vacstmt)
} }
/* matches the StartTransaction in PostgresMain() */ /* matches the StartTransaction in PostgresMain() */
CommitTransactionCommand(true); CommitTransactionCommand();
} }
/* /*
...@@ -303,7 +303,7 @@ vacuum(VacuumStmt *vacstmt) ...@@ -303,7 +303,7 @@ vacuum(VacuumStmt *vacstmt)
*/ */
if (vacstmt->vacuum) if (vacstmt->vacuum)
{ {
StartTransactionCommand(true); StartTransactionCommand();
SetQuerySnapshot(); /* might be needed for functional index */ SetQuerySnapshot(); /* might be needed for functional index */
} }
else else
...@@ -312,7 +312,7 @@ vacuum(VacuumStmt *vacstmt) ...@@ -312,7 +312,7 @@ vacuum(VacuumStmt *vacstmt)
analyze_rel(relid, vacstmt); analyze_rel(relid, vacstmt);
if (vacstmt->vacuum) if (vacstmt->vacuum)
CommitTransactionCommand(true); CommitTransactionCommand();
else else
{ {
MemoryContextSwitchTo(old_context); MemoryContextSwitchTo(old_context);
...@@ -330,11 +330,9 @@ vacuum(VacuumStmt *vacstmt) ...@@ -330,11 +330,9 @@ vacuum(VacuumStmt *vacstmt)
/* /*
* This matches the CommitTransaction waiting for us in * This matches the CommitTransaction waiting for us in
* PostgresMain(). We tell xact.c not to chain the upcoming * PostgresMain().
* commit, so that a VACUUM doesn't start a transaction block,
* even when autocommit is off.
*/ */
StartTransactionCommand(true); StartTransactionCommand();
/* /*
* If it was a database-wide VACUUM, print FSM usage statistics * If it was a database-wide VACUUM, print FSM usage statistics
...@@ -729,7 +727,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind) ...@@ -729,7 +727,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind)
bool result; bool result;
/* Begin a transaction for vacuuming this relation */ /* Begin a transaction for vacuuming this relation */
StartTransactionCommand(true); StartTransactionCommand();
SetQuerySnapshot(); /* might be needed for functional index */ SetQuerySnapshot(); /* might be needed for functional index */
/* /*
...@@ -746,7 +744,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind) ...@@ -746,7 +744,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind)
ObjectIdGetDatum(relid), ObjectIdGetDatum(relid),
0, 0, 0)) 0, 0, 0))
{ {
CommitTransactionCommand(true); CommitTransactionCommand();
return true; /* okay 'cause no data there */ return true; /* okay 'cause no data there */
} }
...@@ -778,7 +776,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind) ...@@ -778,7 +776,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind)
elog(WARNING, "Skipping \"%s\" --- only table or database owner can VACUUM it", elog(WARNING, "Skipping \"%s\" --- only table or database owner can VACUUM it",
RelationGetRelationName(onerel)); RelationGetRelationName(onerel));
relation_close(onerel, lmode); relation_close(onerel, lmode);
CommitTransactionCommand(true); CommitTransactionCommand();
return false; return false;
} }
...@@ -791,7 +789,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind) ...@@ -791,7 +789,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind)
elog(WARNING, "Skipping \"%s\" --- can not process indexes, views or special system tables", elog(WARNING, "Skipping \"%s\" --- can not process indexes, views or special system tables",
RelationGetRelationName(onerel)); RelationGetRelationName(onerel));
relation_close(onerel, lmode); relation_close(onerel, lmode);
CommitTransactionCommand(true); CommitTransactionCommand();
return false; return false;
} }
...@@ -805,7 +803,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind) ...@@ -805,7 +803,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind)
if (isOtherTempNamespace(RelationGetNamespace(onerel))) if (isOtherTempNamespace(RelationGetNamespace(onerel)))
{ {
relation_close(onerel, lmode); relation_close(onerel, lmode);
CommitTransactionCommand(true); CommitTransactionCommand();
return true; /* assume no long-lived data in temp tables */ return true; /* assume no long-lived data in temp tables */
} }
...@@ -843,7 +841,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind) ...@@ -843,7 +841,7 @@ vacuum_rel(Oid relid, VacuumStmt *vacstmt, char expected_relkind)
/* /*
* Complete the transaction and free all temporary memory used. * Complete the transaction and free all temporary memory used.
*/ */
CommitTransactionCommand(true); CommitTransactionCommand();
/* /*
* If the relation has a secondary toast rel, vacuum that too while we * If the relation has a secondary toast rel, vacuum that too while we
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/tcop/postgres.c,v 1.343 2003/05/12 16:48:17 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/tcop/postgres.c,v 1.344 2003/05/14 03:26:01 tgl Exp $
* *
* NOTES * NOTES
* this is the "main" module of the postgres backend and * this is the "main" module of the postgres backend and
...@@ -85,8 +85,6 @@ sigjmp_buf Warn_restart; ...@@ -85,8 +85,6 @@ sigjmp_buf Warn_restart;
bool Warn_restart_ready = false; bool Warn_restart_ready = false;
bool InError = false; bool InError = false;
extern bool autocommit;
/* /*
* Flags for expensive function optimization -- JMH 3/9/92 * Flags for expensive function optimization -- JMH 3/9/92
*/ */
...@@ -148,7 +146,7 @@ static int InteractiveBackend(StringInfo inBuf); ...@@ -148,7 +146,7 @@ static int InteractiveBackend(StringInfo inBuf);
static int SocketBackend(StringInfo inBuf); static int SocketBackend(StringInfo inBuf);
static int ReadCommand(StringInfo inBuf); static int ReadCommand(StringInfo inBuf);
static void start_xact_command(void); static void start_xact_command(void);
static void finish_xact_command(bool forceCommit); static void finish_xact_command(void);
static void SigHupHandler(SIGNAL_ARGS); static void SigHupHandler(SIGNAL_ARGS);
static void FloatExceptionHandler(SIGNAL_ARGS); static void FloatExceptionHandler(SIGNAL_ARGS);
...@@ -861,20 +859,15 @@ exec_simple_query(const char *query_string) ...@@ -861,20 +859,15 @@ exec_simple_query(const char *query_string)
PortalDrop(portal, false); PortalDrop(portal, false);
if (IsA(parsetree, TransactionStmt))
if (IsA(parsetree, TransactionStmt) ||
IsA(parsetree, VariableSetStmt) ||
IsA(parsetree, VariableShowStmt) ||
IsA(parsetree, VariableResetStmt))
{ {
/* /*
* If this was a transaction control statement or a variable * If this was a transaction control statement, commit it.
* set/show/reset statement, commit it. We will start a * We will start a new xact command for the next command (if any).
* new xact command for the next command (if any).
*/ */
finish_xact_command(true); finish_xact_command();
} }
else if (lnext(parsetree_item) == NIL || !autocommit) else if (lnext(parsetree_item) == NIL)
{ {
/* /*
* If this is the last parsetree of the query string, close down * If this is the last parsetree of the query string, close down
...@@ -886,7 +879,7 @@ exec_simple_query(const char *query_string) ...@@ -886,7 +879,7 @@ exec_simple_query(const char *query_string)
* historical Postgres behavior, we do not force a transaction * historical Postgres behavior, we do not force a transaction
* boundary between queries appearing in a single query string. * boundary between queries appearing in a single query string.
*/ */
finish_xact_command(false); finish_xact_command();
} }
else else
{ {
...@@ -907,6 +900,11 @@ exec_simple_query(const char *query_string) ...@@ -907,6 +900,11 @@ exec_simple_query(const char *query_string)
EndCommand(completionTag, dest); EndCommand(completionTag, dest);
} /* end loop over parsetrees */ } /* end loop over parsetrees */
/*
* Close down transaction statement, if one is open.
*/
finish_xact_command();
/* /*
* If there were no parsetrees, return EmptyQueryResponse message. * If there were no parsetrees, return EmptyQueryResponse message.
*/ */
...@@ -915,11 +913,6 @@ exec_simple_query(const char *query_string) ...@@ -915,11 +913,6 @@ exec_simple_query(const char *query_string)
QueryContext = NULL; QueryContext = NULL;
/*
* Close down transaction statement, if one is open.
*/
finish_xact_command(false);
/* /*
* Finish up monitoring. * Finish up monitoring.
*/ */
...@@ -1531,7 +1524,7 @@ exec_execute_message(const char *portal_name, long max_rows) ...@@ -1531,7 +1524,7 @@ exec_execute_message(const char *portal_name, long max_rows)
* If this was a transaction control statement, commit it. We will * If this was a transaction control statement, commit it. We will
* start a new xact command for the next command (if any). * start a new xact command for the next command (if any).
*/ */
finish_xact_command(true); finish_xact_command();
} }
else else
{ {
...@@ -1657,7 +1650,7 @@ start_xact_command(void) ...@@ -1657,7 +1650,7 @@ start_xact_command(void)
if (!xact_started) if (!xact_started)
{ {
elog(DEBUG2, "StartTransactionCommand"); elog(DEBUG2, "StartTransactionCommand");
StartTransactionCommand(false); StartTransactionCommand();
/* Set statement timeout running, if any */ /* Set statement timeout running, if any */
if (StatementTimeout > 0) if (StatementTimeout > 0)
...@@ -1668,7 +1661,7 @@ start_xact_command(void) ...@@ -1668,7 +1661,7 @@ start_xact_command(void)
} }
static void static void
finish_xact_command(bool forceCommit) finish_xact_command(void)
{ {
if (xact_started) if (xact_started)
{ {
...@@ -1681,7 +1674,7 @@ finish_xact_command(bool forceCommit) ...@@ -1681,7 +1674,7 @@ finish_xact_command(bool forceCommit)
/* Now commit the command */ /* Now commit the command */
elog(DEBUG2, "CommitTransactionCommand"); elog(DEBUG2, "CommitTransactionCommand");
CommitTransactionCommand(forceCommit); CommitTransactionCommand();
#ifdef SHOW_MEMORY_STATS #ifdef SHOW_MEMORY_STATS
/* Print mem stats at each commit for leak tracking */ /* Print mem stats at each commit for leak tracking */
...@@ -2532,7 +2525,7 @@ PostgresMain(int argc, char *argv[], const char *username) ...@@ -2532,7 +2525,7 @@ PostgresMain(int argc, char *argv[], const char *username)
if (!IsUnderPostmaster) if (!IsUnderPostmaster)
{ {
puts("\nPOSTGRES backend interactive interface "); puts("\nPOSTGRES backend interactive interface ");
puts("$Revision: 1.343 $ $Date: 2003/05/12 16:48:17 $\n"); puts("$Revision: 1.344 $ $Date: 2003/05/14 03:26:01 $\n");
} }
/* /*
...@@ -2810,7 +2803,7 @@ PostgresMain(int argc, char *argv[], const char *username) ...@@ -2810,7 +2803,7 @@ PostgresMain(int argc, char *argv[], const char *username)
} }
/* commit the function-invocation transaction */ /* commit the function-invocation transaction */
finish_xact_command(false); finish_xact_command();
send_rfq = true; send_rfq = true;
break; break;
...@@ -2894,7 +2887,7 @@ PostgresMain(int argc, char *argv[], const char *username) ...@@ -2894,7 +2887,7 @@ PostgresMain(int argc, char *argv[], const char *username)
case 'S': /* sync */ case 'S': /* sync */
pq_getmsgend(input_message); pq_getmsgend(input_message);
finish_xact_command(false); finish_xact_command();
send_rfq = true; send_rfq = true;
break; break;
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/utils/init/postinit.c,v 1.120 2003/04/25 19:45:08 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/utils/init/postinit.c,v 1.121 2003/05/14 03:26:02 tgl Exp $
* *
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
...@@ -334,7 +334,7 @@ InitPostgres(const char *dbname, const char *username) ...@@ -334,7 +334,7 @@ InitPostgres(const char *dbname, const char *username)
/* start a new transaction here before access to db */ /* start a new transaction here before access to db */
if (!bootstrap) if (!bootstrap)
StartTransactionCommand(true); StartTransactionCommand();
/* /*
* It's now possible to do real access to the system catalogs. * It's now possible to do real access to the system catalogs.
...@@ -420,7 +420,7 @@ InitPostgres(const char *dbname, const char *username) ...@@ -420,7 +420,7 @@ InitPostgres(const char *dbname, const char *username)
/* close the transaction we started above */ /* close the transaction we started above */
if (!bootstrap) if (!bootstrap)
CommitTransactionCommand(true); CommitTransactionCommand();
} }
/* /*
......
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
* Written by Peter Eisentraut <peter_e@gmx.net>. * Written by Peter Eisentraut <peter_e@gmx.net>.
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/utils/misc/guc.c,v 1.123 2003/05/06 20:26:27 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/utils/misc/guc.c,v 1.124 2003/05/14 03:26:02 tgl Exp $
* *
*-------------------------------------------------------------------- *--------------------------------------------------------------------
*/ */
...@@ -69,7 +69,6 @@ extern bool Log_connections; ...@@ -69,7 +69,6 @@ extern bool Log_connections;
extern int PreAuthDelay; extern int PreAuthDelay;
extern int AuthenticationTimeout; extern int AuthenticationTimeout;
extern int CheckPointTimeout; extern int CheckPointTimeout;
extern bool autocommit;
extern int CommitDelay; extern int CommitDelay;
extern int CommitSiblings; extern int CommitSiblings;
extern char *preload_libraries_string; extern char *preload_libraries_string;
...@@ -92,6 +91,7 @@ static const char *assign_min_error_statement(const char *newval, bool doit, ...@@ -92,6 +91,7 @@ static const char *assign_min_error_statement(const char *newval, bool doit,
bool interactive); bool interactive);
static const char *assign_msglvl(int *var, const char *newval, static const char *assign_msglvl(int *var, const char *newval,
bool doit, bool interactive); bool doit, bool interactive);
static bool assign_phony_autocommit(bool newval, bool doit, bool interactive);
/* /*
...@@ -134,6 +134,7 @@ int client_min_messages = NOTICE; ...@@ -134,6 +134,7 @@ int client_min_messages = NOTICE;
static char *log_min_error_statement_str; static char *log_min_error_statement_str;
static char *log_min_messages_str; static char *log_min_messages_str;
static char *client_min_messages_str; static char *client_min_messages_str;
static bool phony_autocommit;
static double phony_random_seed; static double phony_random_seed;
static char *client_encoding_string; static char *client_encoding_string;
static char *datestyle_string; static char *datestyle_string;
...@@ -526,8 +527,12 @@ static struct config_bool ...@@ -526,8 +527,12 @@ static struct config_bool
false, NULL, NULL false, NULL, NULL
}, },
{ {
{"autocommit", PGC_USERSET}, &autocommit, /*
true, NULL, NULL * This var doesn't do anything; it's just here so that we won't
* choke on SET AUTOCOMMIT TO ON from 7.3-vintage clients.
*/
{"autocommit", PGC_USERSET, GUC_NO_SHOW_ALL}, &phony_autocommit,
true, assign_phony_autocommit, NULL
}, },
{ {
{"default_transaction_read_only", PGC_USERSET}, &DefaultXactReadOnly, {"default_transaction_read_only", PGC_USERSET}, &DefaultXactReadOnly,
...@@ -3429,6 +3434,18 @@ assign_msglvl(int *var, const char *newval, bool doit, bool interactive) ...@@ -3429,6 +3434,18 @@ assign_msglvl(int *var, const char *newval, bool doit, bool interactive)
return newval; /* OK */ return newval; /* OK */
} }
static bool
assign_phony_autocommit(bool newval, bool doit, bool interactive)
{
if (!newval)
{
if (doit && interactive)
elog(ERROR, "SET AUTOCOMMIT TO OFF is no longer supported");
return false;
}
return true;
}
#include "guc-file.c" #include "guc-file.c"
...@@ -198,7 +198,6 @@ ...@@ -198,7 +198,6 @@
# #
# Misc # Misc
# #
#autocommit = true
#dynamic_library_path = '$libdir' #dynamic_library_path = '$libdir'
#search_path = '$user,public' # schema names #search_path = '$user,public' # schema names
#datestyle = 'iso, us' #datestyle = 'iso, us'
......
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_archiver.c,v 1.71 2003/05/03 22:18:59 tgl Exp $ * $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_archiver.c,v 1.72 2003/05/14 03:26:02 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -206,7 +206,6 @@ RestoreArchive(Archive *AHX, RestoreOptions *ropt) ...@@ -206,7 +206,6 @@ RestoreArchive(Archive *AHX, RestoreOptions *ropt)
sav = SetOutput(AH, ropt->filename, ropt->compression); sav = SetOutput(AH, ropt->filename, ropt->compression);
ahprintf(AH, "--\n-- PostgreSQL database dump\n--\n\n"); ahprintf(AH, "--\n-- PostgreSQL database dump\n--\n\n");
ahprintf(AH, "SET autocommit TO 'on';\n\n");
/* /*
* Drop the items at the start, in reverse order * Drop the items at the start, in reverse order
...@@ -2122,7 +2121,6 @@ _reconnectAsUser(ArchiveHandle *AH, const char *dbname, const char *user) ...@@ -2122,7 +2121,6 @@ _reconnectAsUser(ArchiveHandle *AH, const char *dbname, const char *user)
dbname ? fmtId(dbname) : "-"); dbname ? fmtId(dbname) : "-");
appendPQExpBuffer(qry, " %s\n\n", appendPQExpBuffer(qry, " %s\n\n",
fmtId(user)); fmtId(user));
appendPQExpBuffer(qry, "SET autocommit TO 'on';\n\n");
ahprintf(AH, qry->data); ahprintf(AH, qry->data);
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* Implements the basic DB functions used by the archiver. * Implements the basic DB functions used by the archiver.
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_db.c,v 1.46 2003/02/14 19:40:42 momjian Exp $ * $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_db.c,v 1.47 2003/05/14 03:26:02 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -61,12 +61,7 @@ _check_database_version(ArchiveHandle *AH, bool ignoreVersion) ...@@ -61,12 +61,7 @@ _check_database_version(ArchiveHandle *AH, bool ignoreVersion)
myversion = _parse_version(AH, PG_VERSION); myversion = _parse_version(AH, PG_VERSION);
/* res = PQexec(conn, "SELECT version();");
* Autocommit could be off. We turn it on later but we have to check
* the database version first.
*/
res = PQexec(conn, "BEGIN;SELECT version();");
if (!res || if (!res ||
PQresultStatus(res) != PGRES_TUPLES_OK || PQresultStatus(res) != PGRES_TUPLES_OK ||
PQntuples(res) != 1) PQntuples(res) != 1)
...@@ -77,12 +72,6 @@ _check_database_version(ArchiveHandle *AH, bool ignoreVersion) ...@@ -77,12 +72,6 @@ _check_database_version(ArchiveHandle *AH, bool ignoreVersion)
PQclear(res); PQclear(res);
res = PQexec(conn, "COMMIT;");
if (!res ||
PQresultStatus(res) != PGRES_COMMAND_OK)
die_horribly(AH, modulename, "could not get version from server: %s", PQerrorMessage(conn));
PQclear(res);
AH->public.remoteVersion = remoteversion; AH->public.remoteVersion = remoteversion;
if (myversion != remoteversion if (myversion != remoteversion
...@@ -216,18 +205,6 @@ _connectDB(ArchiveHandle *AH, const char *reqdb, const char *requser) ...@@ -216,18 +205,6 @@ _connectDB(ArchiveHandle *AH, const char *reqdb, const char *requser)
/* check for version mismatch */ /* check for version mismatch */
_check_database_version(AH, true); _check_database_version(AH, true);
/* Turn autocommit on */
if (AH->public.remoteVersion >= 70300)
{
PGresult *res;
res = PQexec(AH->connection, "SET autocommit TO 'on'");
if (!res || PQresultStatus(res) != PGRES_COMMAND_OK)
die_horribly(AH, NULL, "SET autocommit TO 'on' failed: %s",
PQerrorMessage(AH->connection));
PQclear(res);
}
PQsetNoticeProcessor(newConn, notice_processor, NULL); PQsetNoticeProcessor(newConn, notice_processor, NULL);
return newConn; return newConn;
...@@ -301,18 +278,6 @@ ConnectDatabase(Archive *AHX, ...@@ -301,18 +278,6 @@ ConnectDatabase(Archive *AHX,
/* check for version mismatch */ /* check for version mismatch */
_check_database_version(AH, ignoreVersion); _check_database_version(AH, ignoreVersion);
/* Turn autocommit on */
if (AH->public.remoteVersion >= 70300)
{
PGresult *res;
res = PQexec(AH->connection, "SET autocommit TO 'on'");
if (!res || PQresultStatus(res) != PGRES_COMMAND_OK)
die_horribly(AH, NULL, "SET autocommit TO 'on' failed: %s",
PQerrorMessage(AH->connection));
PQclear(res);
}
PQsetNoticeProcessor(AH->connection, notice_processor, NULL); PQsetNoticeProcessor(AH->connection, notice_processor, NULL);
return AH->connection; return AH->connection;
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* *
* $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_dumpall.c,v 1.17 2003/04/04 20:42:12 momjian Exp $ * $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_dumpall.c,v 1.18 2003/05/14 03:26:02 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -188,7 +188,6 @@ main(int argc, char *argv[]) ...@@ -188,7 +188,6 @@ main(int argc, char *argv[])
printf("-- PostgreSQL database cluster dump\n"); printf("-- PostgreSQL database cluster dump\n");
printf("--\n\n"); printf("--\n\n");
printf("\\connect \"template1\"\n\n"); printf("\\connect \"template1\"\n\n");
printf("SET autocommit TO 'on';\n\n");
dumpUsers(conn); dumpUsers(conn);
dumpGroups(conn); dumpGroups(conn);
...@@ -550,8 +549,7 @@ dumpDatabases(PGconn *conn) ...@@ -550,8 +549,7 @@ dumpDatabases(PGconn *conn)
if (verbose) if (verbose)
fprintf(stderr, _("%s: dumping database \"%s\"...\n"), progname, dbname); fprintf(stderr, _("%s: dumping database \"%s\"...\n"), progname, dbname);
printf("\\connect %s\n", fmtId(dbname)); printf("\\connect %s\n\n", fmtId(dbname));
printf("SET autocommit TO 'on';\n\n");
ret = runPgDump(dbname); ret = runPgDump(dbname);
if (ret != 0) if (ret != 0)
{ {
...@@ -677,14 +675,6 @@ connectDatabase(const char *dbname, const char *pghost, const char *pgport, ...@@ -677,14 +675,6 @@ connectDatabase(const char *dbname, const char *pghost, const char *pgport,
} }
PQclear(res); PQclear(res);
if (server_version >= 70300)
{
PGresult *res;
res = executeQuery(conn, "SET autocommit TO 'on';SELECT 1;");
PQclear(res);
}
return conn; return conn;
} }
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
* *
* Copyright 2000-2002 by PostgreSQL Global Development Group * Copyright 2000-2002 by PostgreSQL Global Development Group
* *
* $Header: /cvsroot/pgsql/src/bin/psql/command.c,v 1.95 2003/04/04 20:40:45 momjian Exp $ * $Header: /cvsroot/pgsql/src/bin/psql/command.c,v 1.96 2003/05/14 03:26:02 tgl Exp $
*/ */
#include "postgres_fe.h" #include "postgres_fe.h"
#include "command.h" #include "command.h"
...@@ -1460,12 +1460,8 @@ test_superuser(const char *username) ...@@ -1460,12 +1460,8 @@ test_superuser(const char *username)
if (!username) if (!username)
return false; return false;
/*
* Use begin/commit to avoid starting a transaction block if server
* has autocommit off by default.
*/
initPQExpBuffer(&buf); initPQExpBuffer(&buf);
printfPQExpBuffer(&buf, "BEGIN; SELECT usesuper FROM pg_catalog.pg_user WHERE usename = '%s'; COMMIT", username); printfPQExpBuffer(&buf, "SELECT usesuper FROM pg_catalog.pg_user WHERE usename = '%s'", username);
res = PSQLexec(buf.data, true); res = PSQLexec(buf.data, true);
termPQExpBuffer(&buf); termPQExpBuffer(&buf);
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
* *
* Copyright 2000-2002 by PostgreSQL Global Development Group * Copyright 2000-2002 by PostgreSQL Global Development Group
* *
* $Header: /cvsroot/pgsql/src/bin/psql/tab-complete.c,v 1.76 2003/04/03 20:18:16 tgl Exp $ * $Header: /cvsroot/pgsql/src/bin/psql/tab-complete.c,v 1.77 2003/05/14 03:26:02 tgl Exp $
*/ */
/*---------------------------------------------------------------------- /*----------------------------------------------------------------------
...@@ -493,7 +493,6 @@ psql_completion(char *text, int start, int end) ...@@ -493,7 +493,6 @@ psql_completion(char *text, int start, int end)
* backend/utils/misc/guc.c. * backend/utils/misc/guc.c.
*/ */
"australian_timezones", "australian_timezones",
"autocommit",
"client_encoding", "client_encoding",
"client_min_messages", "client_min_messages",
"commit_delay", "commit_delay",
......
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
# #
# #
# IDENTIFICATION # IDENTIFICATION
# $Header: /cvsroot/pgsql/src/bin/scripts/Attic/clusterdb,v 1.10 2003/03/20 18:53:18 momjian Exp $ # $Header: /cvsroot/pgsql/src/bin/scripts/Attic/clusterdb,v 1.11 2003/05/14 03:26:03 tgl Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -157,10 +157,10 @@ for db in $dbname ...@@ -157,10 +157,10 @@ for db in $dbname
do do
[ "$alldb" ] && echo "Clustering $db" [ "$alldb" ] && echo "Clustering $db"
if [ -z "$table" ]; then if [ -z "$table" ]; then
${PATHNAME}psql $PSQLOPT $ECHOOPT -c "SET autocommit TO 'on';CLUSTER" -d $db ${PATHNAME}psql $PSQLOPT $ECHOOPT -c "CLUSTER" -d $db
[ "$?" -ne 0 ] && exit 1 [ "$?" -ne 0 ] && exit 1
else else
${PATHNAME}psql $PSQLOPT $ECHOOPT -c "SET autocommit TO 'on';CLUSTER $table" -d $db ${PATHNAME}psql $PSQLOPT $ECHOOPT -c "CLUSTER $table" -d $db
[ "$?" -ne 0 ] && exit 1 [ "$?" -ne 0 ] && exit 1
fi fi
done done
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Header: /cvsroot/pgsql/src/bin/scripts/createdb.c,v 1.1 2003/03/18 22:19:46 petere Exp $ * $Header: /cvsroot/pgsql/src/bin/scripts/createdb.c,v 1.2 2003/05/14 03:26:03 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -143,7 +143,7 @@ main(int argc, char *argv[]) ...@@ -143,7 +143,7 @@ main(int argc, char *argv[])
initPQExpBuffer(&sql); initPQExpBuffer(&sql);
appendPQExpBuffer(&sql, "SET autocommit TO on;\nCREATE DATABASE %s", appendPQExpBuffer(&sql, "CREATE DATABASE %s",
fmtId(dbname)); fmtId(dbname));
if (owner) if (owner)
...@@ -181,7 +181,7 @@ main(int argc, char *argv[]) ...@@ -181,7 +181,7 @@ main(int argc, char *argv[])
if (comment) if (comment)
{ {
printfPQExpBuffer(&sql, "SET autocommit TO on;\nCOMMENT ON DATABASE %s IS ", fmtId(dbname)); printfPQExpBuffer(&sql, "COMMENT ON DATABASE %s IS ", fmtId(dbname));
appendStringLiteral(&sql, comment, false); appendStringLiteral(&sql, comment, false);
appendPQExpBuffer(&sql, ";\n"); appendPQExpBuffer(&sql, ";\n");
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Header: /cvsroot/pgsql/src/bin/scripts/createlang.c,v 1.1 2003/03/18 22:19:46 petere Exp $ * $Header: /cvsroot/pgsql/src/bin/scripts/createlang.c,v 1.2 2003/05/14 03:26:03 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -237,7 +237,7 @@ main(int argc, char *argv[]) ...@@ -237,7 +237,7 @@ main(int argc, char *argv[])
/* /*
* Create the call handler and the language * Create the call handler and the language
*/ */
printfPQExpBuffer(&sql, "SET autocommit TO on;\n"); resetPQExpBuffer(&sql);
if (!handlerexists) if (!handlerexists)
appendPQExpBuffer(&sql, appendPQExpBuffer(&sql,
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Header: /cvsroot/pgsql/src/bin/scripts/createuser.c,v 1.1 2003/03/18 22:19:46 petere Exp $ * $Header: /cvsroot/pgsql/src/bin/scripts/createuser.c,v 1.2 2003/05/14 03:26:03 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -185,7 +185,7 @@ main(int argc, char *argv[]) ...@@ -185,7 +185,7 @@ main(int argc, char *argv[])
initPQExpBuffer(&sql); initPQExpBuffer(&sql);
printfPQExpBuffer(&sql, "SET autocommit TO on;\nCREATE USER %s", fmtId(newuser)); printfPQExpBuffer(&sql, "CREATE USER %s", fmtId(newuser));
if (sysid) if (sysid)
appendPQExpBuffer(&sql, " SYSID %s", sysid); appendPQExpBuffer(&sql, " SYSID %s", sysid);
if (encrypted == +1) if (encrypted == +1)
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Header: /cvsroot/pgsql/src/bin/scripts/dropdb.c,v 1.1 2003/03/18 22:19:46 petere Exp $ * $Header: /cvsroot/pgsql/src/bin/scripts/dropdb.c,v 1.2 2003/05/14 03:26:03 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -113,7 +113,7 @@ main(int argc, char *argv[]) ...@@ -113,7 +113,7 @@ main(int argc, char *argv[])
initPQExpBuffer(&sql); initPQExpBuffer(&sql);
appendPQExpBuffer(&sql, "SET autocommit TO on;\nDROP DATABASE %s;\n", appendPQExpBuffer(&sql, "DROP DATABASE %s;\n",
fmtId(dbname)); fmtId(dbname));
conn = connectDatabase("template1", host, port, username, password, progname); conn = connectDatabase("template1", host, port, username, password, progname);
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Header: /cvsroot/pgsql/src/bin/scripts/droplang.c,v 1.1 2003/03/18 22:19:47 petere Exp $ * $Header: /cvsroot/pgsql/src/bin/scripts/droplang.c,v 1.2 2003/05/14 03:26:03 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -215,8 +215,7 @@ main(int argc, char *argv[]) ...@@ -215,8 +215,7 @@ main(int argc, char *argv[])
/* /*
* Drop the language * Drop the language
*/ */
printfPQExpBuffer(&sql, "SET autocommit TO on;\n"); printfPQExpBuffer(&sql, "DROP LANGUAGE \"%s\";\n", langname);
appendPQExpBuffer(&sql, "DROP LANGUAGE \"%s\";\n", langname);
if (!keephandler) if (!keephandler)
appendPQExpBuffer(&sql, "DROP FUNCTION \"%s\" ();\n", handler); appendPQExpBuffer(&sql, "DROP FUNCTION \"%s\" ();\n", handler);
if (echo) if (echo)
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Header: /cvsroot/pgsql/src/bin/scripts/dropuser.c,v 1.1 2003/03/18 22:19:47 petere Exp $ * $Header: /cvsroot/pgsql/src/bin/scripts/dropuser.c,v 1.2 2003/05/14 03:26:03 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -113,7 +113,7 @@ main(int argc, char *argv[]) ...@@ -113,7 +113,7 @@ main(int argc, char *argv[])
} }
initPQExpBuffer(&sql); initPQExpBuffer(&sql);
appendPQExpBuffer(&sql, "SET autocommit TO on;\nDROP USER %s;\n", fmtId(dropuser)); appendPQExpBuffer(&sql, "DROP USER %s;\n", fmtId(dropuser));
conn = connectDatabase("template1", host, port, username, password, progname); conn = connectDatabase("template1", host, port, username, password, progname);
......
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
# #
# #
# IDENTIFICATION # IDENTIFICATION
# $Header: /cvsroot/pgsql/src/bin/scripts/Attic/vacuumdb,v 1.26 2002/10/18 22:05:36 petere Exp $ # $Header: /cvsroot/pgsql/src/bin/scripts/Attic/vacuumdb,v 1.27 2003/05/14 03:26:03 tgl Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -172,7 +172,7 @@ fi ...@@ -172,7 +172,7 @@ fi
for db in $dbname for db in $dbname
do do
[ "$alldb" -a "$quiet" -ne 1 ] && echo "Vacuuming $db" [ "$alldb" -a "$quiet" -ne 1 ] && echo "Vacuuming $db"
${PATHNAME}psql $PSQLOPT $ECHOOPT -c "SET autocommit TO 'on';VACUUM $full $verbose $analyze $table" -d $db ${PATHNAME}psql $PSQLOPT $ECHOOPT -c "VACUUM $full $verbose $analyze $table" -d $db
if [ "$?" -ne 0 ]; then if [ "$?" -ne 0 ]; then
echo "$CMDNAME: vacuum $table $db failed" 1>&2 echo "$CMDNAME: vacuum $table $db failed" 1>&2
exit 1 exit 1
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* Portions Copyright (c) 1996-2002, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2002, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Id: xact.h,v 1.51 2003/05/12 23:08:50 tgl Exp $ * $Id: xact.h,v 1.52 2003/05/14 03:26:03 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -119,8 +119,8 @@ extern AbsoluteTime GetCurrentTransactionStartTimeUsec(int *usec); ...@@ -119,8 +119,8 @@ extern AbsoluteTime GetCurrentTransactionStartTimeUsec(int *usec);
extern bool TransactionIdIsCurrentTransactionId(TransactionId xid); extern bool TransactionIdIsCurrentTransactionId(TransactionId xid);
extern bool CommandIdIsCurrentCommandId(CommandId cid); extern bool CommandIdIsCurrentCommandId(CommandId cid);
extern void CommandCounterIncrement(void); extern void CommandCounterIncrement(void);
extern void StartTransactionCommand(bool preventChain); extern void StartTransactionCommand(void);
extern void CommitTransactionCommand(bool forceCommit); extern void CommitTransactionCommand(void);
extern void AbortCurrentTransaction(void); extern void AbortCurrentTransaction(void);
extern void BeginTransactionBlock(void); extern void BeginTransactionBlock(void);
extern void EndTransactionBlock(void); extern void EndTransactionBlock(void);
......
...@@ -996,7 +996,6 @@ ERROR: Relation "test" has no column "........pg.dropped.1........" ...@@ -996,7 +996,6 @@ ERROR: Relation "test" has no column "........pg.dropped.1........"
copy test from stdin; copy test from stdin;
ERROR: Extra data after last expected column ERROR: Extra data after last expected column
CONTEXT: COPY FROM, line 1 CONTEXT: COPY FROM, line 1
SET autocommit TO 'on';
select * from test; select * from test;
b | c b | c
---+--- ---+---
......
...@@ -46,7 +46,6 @@ CONTEXT: COPY FROM, line 1 ...@@ -46,7 +46,6 @@ CONTEXT: COPY FROM, line 1
COPY x from stdin; COPY x from stdin;
ERROR: Extra data after last expected column ERROR: Extra data after last expected column
CONTEXT: COPY FROM, line 1 CONTEXT: COPY FROM, line 1
SET autocommit TO 'on';
-- various COPY options: delimiters, oids, NULL string -- various COPY options: delimiters, oids, NULL string
COPY x (b, c, d, e) from stdin with oids delimiter ',' null 'x'; COPY x (b, c, d, e) from stdin with oids delimiter ',' null 'x';
-- check results of copy in -- check results of copy in
......
...@@ -41,14 +41,13 @@ INSERT INTO basictest values ('88', 'haha', 'short', '123.1212'); -- Truncate ...@@ -41,14 +41,13 @@ INSERT INTO basictest values ('88', 'haha', 'short', '123.1212'); -- Truncate
COPY basictest (testvarchar) FROM stdin; -- fail COPY basictest (testvarchar) FROM stdin; -- fail
ERROR: value too long for type character varying(5) ERROR: value too long for type character varying(5)
CONTEXT: COPY FROM, line 1 CONTEXT: COPY FROM, line 1
SET autocommit TO 'on';
COPY basictest (testvarchar) FROM stdin; COPY basictest (testvarchar) FROM stdin;
select * from basictest; select * from basictest;
testint4 | testtext | testvarchar | testnumeric testint4 | testtext | testvarchar | testnumeric
----------+----------+-------------+------------- ----------+----------+-------------+-------------
88 | haha | short | 123.12 88 | haha | short | 123.12
88 | haha | short | 123.12 88 | haha | short | 123.12
| | short | | | short |
(3 rows) (3 rows)
-- check that domains inherit operations from base types -- check that domains inherit operations from base types
...@@ -129,7 +128,6 @@ INSERT INTO nulltest values ('a', 'b', 'c', NULL, 'd'); -- Good ...@@ -129,7 +128,6 @@ INSERT INTO nulltest values ('a', 'b', 'c', NULL, 'd'); -- Good
COPY nulltest FROM stdin; --fail COPY nulltest FROM stdin; --fail
ERROR: Domain dcheck does not allow NULL values ERROR: Domain dcheck does not allow NULL values
CONTEXT: COPY FROM, line 1 CONTEXT: COPY FROM, line 1
SET autocommit TO 'on';
-- Last row is bad -- Last row is bad
COPY nulltest FROM stdin; COPY nulltest FROM stdin;
ERROR: CopyFrom: rejected due to CHECK constraint "nulltest_col5" on "nulltest" ERROR: CopyFrom: rejected due to CHECK constraint "nulltest_col5" on "nulltest"
...@@ -185,10 +183,10 @@ COPY defaulttest(col5) FROM stdin; ...@@ -185,10 +183,10 @@ COPY defaulttest(col5) FROM stdin;
select * from defaulttest; select * from defaulttest;
col1 | col2 | col3 | col4 | col5 | col6 | col7 | col8 col1 | col2 | col3 | col4 | col5 | col6 | col7 | col8
------+------+------+------+------+------+------+------- ------+------+------+------+------+------+------+-------
3 | 12 | 5 | 1 | 3 | 88 | 8000 | 12.12 3 | 12 | 5 | 1 | 3 | 88 | 8000 | 12.12
3 | 12 | 5 | 2 | 3 | 88 | 8000 | 12.12 3 | 12 | 5 | 2 | 3 | 88 | 8000 | 12.12
3 | 12 | 5 | 3 | 3 | 88 | 8000 | 12.12 3 | 12 | 5 | 3 | 3 | 88 | 8000 | 12.12
3 | 12 | 5 | 4 | 42 | 88 | 8000 | 12.12 3 | 12 | 5 | 4 | 42 | 88 | 8000 | 12.12
(4 rows) (4 rows)
drop sequence ddef4_seq; drop sequence ddef4_seq;
...@@ -224,7 +222,7 @@ insert into domdeftest default values; ...@@ -224,7 +222,7 @@ insert into domdeftest default values;
select * from domdeftest; select * from domdeftest;
col1 col1
------ ------
3 3
(1 row) (1 row)
alter domain ddef1 set default '42'; alter domain ddef1 set default '42';
...@@ -232,8 +230,8 @@ insert into domdeftest default values; ...@@ -232,8 +230,8 @@ insert into domdeftest default values;
select * from domdeftest; select * from domdeftest;
col1 col1
------ ------
3 3
42 42
(2 rows) (2 rows)
alter domain ddef1 drop default; alter domain ddef1 drop default;
...@@ -241,9 +239,9 @@ insert into domdeftest default values; ...@@ -241,9 +239,9 @@ insert into domdeftest default values;
select * from domdeftest; select * from domdeftest;
col1 col1
------ ------
3 3
42 42
(3 rows) (3 rows)
drop table domdeftest; drop table domdeftest;
...@@ -274,8 +272,8 @@ insert into domtab (col1) values (5); ...@@ -274,8 +272,8 @@ insert into domtab (col1) values (5);
select * from domview; select * from domview;
col1 col1
------ ------
5 5
(2 rows) (2 rows)
alter domain dom set not null; alter domain dom set not null;
...@@ -285,8 +283,8 @@ alter domain dom drop not null; ...@@ -285,8 +283,8 @@ alter domain dom drop not null;
select * from domview; select * from domview;
col1 col1
------ ------
5 5
(2 rows) (2 rows)
alter domain dom add constraint domchkgt6 check(value > 6); alter domain dom add constraint domchkgt6 check(value > 6);
...@@ -296,8 +294,8 @@ alter domain dom drop constraint domchkgt6 restrict; ...@@ -296,8 +294,8 @@ alter domain dom drop constraint domchkgt6 restrict;
select * from domview; select * from domview;
col1 col1
------ ------
5 5
(2 rows) (2 rows)
-- cleanup -- cleanup
......
...@@ -105,6 +105,14 @@ WHERE ambulkdelete != 0 AND ...@@ -105,6 +105,14 @@ WHERE ambulkdelete != 0 AND
------+-------------- ------+--------------
(0 rows) (0 rows)
SELECT ctid, amvacuumcleanup
FROM pg_catalog.pg_am fk
WHERE amvacuumcleanup != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_proc pk WHERE pk.oid = fk.amvacuumcleanup);
ctid | amvacuumcleanup
------+-----------------
(0 rows)
SELECT ctid, amcostestimate SELECT ctid, amcostestimate
FROM pg_catalog.pg_am fk FROM pg_catalog.pg_am fk
WHERE amcostestimate != 0 AND WHERE amcostestimate != 0 AND
...@@ -225,6 +233,22 @@ WHERE reltoastidxid != 0 AND ...@@ -225,6 +233,22 @@ WHERE reltoastidxid != 0 AND
------+--------------- ------+---------------
(0 rows) (0 rows)
SELECT ctid, connamespace
FROM pg_catalog.pg_constraint fk
WHERE connamespace != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_namespace pk WHERE pk.oid = fk.connamespace);
ctid | connamespace
------+--------------
(0 rows)
SELECT ctid, contypid
FROM pg_catalog.pg_constraint fk
WHERE contypid != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_type pk WHERE pk.oid = fk.contypid);
ctid | contypid
------+----------
(0 rows)
SELECT ctid, connamespace SELECT ctid, connamespace
FROM pg_catalog.pg_conversion fk FROM pg_catalog.pg_conversion fk
WHERE connamespace != 0 AND WHERE connamespace != 0 AND
...@@ -553,3 +577,11 @@ WHERE typsend != 0 AND ...@@ -553,3 +577,11 @@ WHERE typsend != 0 AND
------+--------- ------+---------
(0 rows) (0 rows)
SELECT ctid, typbasetype
FROM pg_catalog.pg_type fk
WHERE typbasetype != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_type pk WHERE pk.oid = fk.typbasetype);
ctid | typbasetype
------+-------------
(0 rows)
...@@ -220,7 +220,6 @@ ERROR: atest2: permission denied ...@@ -220,7 +220,6 @@ ERROR: atest2: permission denied
-- privileges on functions, languages -- privileges on functions, languages
-- switch to superuser -- switch to superuser
\c - \c -
SET autocommit TO 'on';
REVOKE ALL PRIVILEGES ON LANGUAGE sql FROM PUBLIC; REVOKE ALL PRIVILEGES ON LANGUAGE sql FROM PUBLIC;
GRANT USAGE ON LANGUAGE sql TO regressuser1; -- ok GRANT USAGE ON LANGUAGE sql TO regressuser1; -- ok
GRANT USAGE ON LANGUAGE c TO PUBLIC; -- fail GRANT USAGE ON LANGUAGE c TO PUBLIC; -- fail
...@@ -271,7 +270,6 @@ SELECT testfunc1(5); -- ok ...@@ -271,7 +270,6 @@ SELECT testfunc1(5); -- ok
DROP FUNCTION testfunc1(int); -- fail DROP FUNCTION testfunc1(int); -- fail
ERROR: testfunc1: must be owner ERROR: testfunc1: must be owner
\c - \c -
SET autocommit TO 'on';
DROP FUNCTION testfunc1(int); -- ok DROP FUNCTION testfunc1(int); -- ok
-- restore to sanity -- restore to sanity
GRANT ALL PRIVILEGES ON LANGUAGE sql TO PUBLIC; GRANT ALL PRIVILEGES ON LANGUAGE sql TO PUBLIC;
...@@ -295,7 +293,6 @@ select has_table_privilege(1,'rule'); ...@@ -295,7 +293,6 @@ select has_table_privilege(1,'rule');
ERROR: pg_class_aclcheck: relation 1 not found ERROR: pg_class_aclcheck: relation 1 not found
-- superuser -- superuser
\c - \c -
SET autocommit TO 'on';
select has_table_privilege(current_user,'pg_shadow','select'); select has_table_privilege(current_user,'pg_shadow','select');
has_table_privilege has_table_privilege
--------------------- ---------------------
...@@ -586,7 +583,6 @@ SELECT has_table_privilege('regressuser1', 'atest4', 'SELECT WITH GRANT OPTION') ...@@ -586,7 +583,6 @@ SELECT has_table_privilege('regressuser1', 'atest4', 'SELECT WITH GRANT OPTION')
-- clean up -- clean up
\c regression \c regression
SET autocommit TO 'on';
DROP FUNCTION testfunc2(int); DROP FUNCTION testfunc2(int);
DROP FUNCTION testfunc4(boolean); DROP FUNCTION testfunc4(boolean);
DROP VIEW atestv1; DROP VIEW atestv1;
......
...@@ -43,7 +43,6 @@ DROP TABLE temptest; ...@@ -43,7 +43,6 @@ DROP TABLE temptest;
-- test temp table deletion -- test temp table deletion
CREATE TEMP TABLE temptest(col int); CREATE TEMP TABLE temptest(col int);
\c regression \c regression
SET autocommit TO 'on';
SELECT * FROM temptest; SELECT * FROM temptest;
ERROR: Relation "temptest" does not exist ERROR: Relation "temptest" does not exist
-- Test ON COMMIT DELETE ROWS -- Test ON COMMIT DELETE ROWS
......
#! /bin/sh #! /bin/sh
# $Header: /cvsroot/pgsql/src/test/regress/Attic/pg_regress.sh,v 1.30 2003/04/28 04:29:12 tgl Exp $ # $Header: /cvsroot/pgsql/src/test/regress/Attic/pg_regress.sh,v 1.31 2003/05/14 03:26:03 tgl Exp $
me=`basename $0` me=`basename $0`
: ${TMPDIR=/tmp} : ${TMPDIR=/tmp}
...@@ -477,7 +477,7 @@ fi ...@@ -477,7 +477,7 @@ fi
# ---------- # ----------
message "dropping regression test user accounts" message "dropping regression test user accounts"
"$bindir/psql" $psql_options -c 'SET autocommit TO on;DROP GROUP regressgroup1; DROP GROUP regressgroup2; DROP USER regressuser1, regressuser2, regressuser3, regressuser4;' $dbname 2>/dev/null "$bindir/psql" $psql_options -c 'DROP GROUP regressgroup1; DROP GROUP regressgroup2; DROP USER regressuser1, regressuser2, regressuser3, regressuser4;' $dbname 2>/dev/null
if [ $? -eq 2 ]; then if [ $? -eq 2 ]; then
echo "$me: could not drop user accounts" echo "$me: could not drop user accounts"
(exit 2); exit (exit 2); exit
...@@ -550,7 +550,6 @@ do ...@@ -550,7 +550,6 @@ do
$ECHO_N "test $formatted ... $ECHO_C" $ECHO_N "test $formatted ... $ECHO_C"
(cat <<EOF (cat <<EOF
SET autocommit TO 'on';
\\set ECHO all \\set ECHO all
EOF EOF
cat "$inputdir/sql/$1.sql") | \ cat "$inputdir/sql/$1.sql") | \
...@@ -561,7 +560,6 @@ EOF ...@@ -561,7 +560,6 @@ EOF
for name do for name do
( (
(cat <<EOF (cat <<EOF
SET autocommit TO 'on';
\\set ECHO all \\set ECHO all
EOF EOF
cat "$inputdir/sql/$name.sql") | \ cat "$inputdir/sql/$name.sql") | \
......
...@@ -717,7 +717,6 @@ copy test("........pg.dropped.1........") to stdout; ...@@ -717,7 +717,6 @@ copy test("........pg.dropped.1........") to stdout;
copy test from stdin; copy test from stdin;
10 11 12 10 11 12
\. \.
SET autocommit TO 'on';
select * from test; select * from test;
copy test from stdin; copy test from stdin;
21 22 21 22
......
...@@ -71,7 +71,6 @@ COPY x from stdin; ...@@ -71,7 +71,6 @@ COPY x from stdin;
2002 232 40 50 60 70 80 2002 232 40 50 60 70 80
\. \.
SET autocommit TO 'on';
-- various COPY options: delimiters, oids, NULL string -- various COPY options: delimiters, oids, NULL string
COPY x (b, c, d, e) from stdin with oids delimiter ',' null 'x'; COPY x (b, c, d, e) from stdin with oids delimiter ',' null 'x';
500000,x,45,80,90 500000,x,45,80,90
......
...@@ -41,8 +41,6 @@ COPY basictest (testvarchar) FROM stdin; -- fail ...@@ -41,8 +41,6 @@ COPY basictest (testvarchar) FROM stdin; -- fail
notsoshorttext notsoshorttext
\. \.
SET autocommit TO 'on';
COPY basictest (testvarchar) FROM stdin; COPY basictest (testvarchar) FROM stdin;
short short
\. \.
...@@ -106,8 +104,6 @@ COPY nulltest FROM stdin; --fail ...@@ -106,8 +104,6 @@ COPY nulltest FROM stdin; --fail
a b \N d \N a b \N d \N
\. \.
SET autocommit TO 'on';
-- Last row is bad -- Last row is bad
COPY nulltest FROM stdin; COPY nulltest FROM stdin;
a b c \N c a b c \N c
......
...@@ -53,6 +53,10 @@ SELECT ctid, ambulkdelete ...@@ -53,6 +53,10 @@ SELECT ctid, ambulkdelete
FROM pg_catalog.pg_am fk FROM pg_catalog.pg_am fk
WHERE ambulkdelete != 0 AND WHERE ambulkdelete != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_proc pk WHERE pk.oid = fk.ambulkdelete); NOT EXISTS(SELECT 1 FROM pg_catalog.pg_proc pk WHERE pk.oid = fk.ambulkdelete);
SELECT ctid, amvacuumcleanup
FROM pg_catalog.pg_am fk
WHERE amvacuumcleanup != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_proc pk WHERE pk.oid = fk.amvacuumcleanup);
SELECT ctid, amcostestimate SELECT ctid, amcostestimate
FROM pg_catalog.pg_am fk FROM pg_catalog.pg_am fk
WHERE amcostestimate != 0 AND WHERE amcostestimate != 0 AND
...@@ -114,6 +118,14 @@ FROM pg_catalog.pg_class fk ...@@ -114,6 +118,14 @@ FROM pg_catalog.pg_class fk
WHERE reltoastidxid != 0 AND WHERE reltoastidxid != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_class pk WHERE pk.oid = fk.reltoastidxid); NOT EXISTS(SELECT 1 FROM pg_catalog.pg_class pk WHERE pk.oid = fk.reltoastidxid);
SELECT ctid, connamespace SELECT ctid, connamespace
FROM pg_catalog.pg_constraint fk
WHERE connamespace != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_namespace pk WHERE pk.oid = fk.connamespace);
SELECT ctid, contypid
FROM pg_catalog.pg_constraint fk
WHERE contypid != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_type pk WHERE pk.oid = fk.contypid);
SELECT ctid, connamespace
FROM pg_catalog.pg_conversion fk FROM pg_catalog.pg_conversion fk
WHERE connamespace != 0 AND WHERE connamespace != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_namespace pk WHERE pk.oid = fk.connamespace); NOT EXISTS(SELECT 1 FROM pg_catalog.pg_namespace pk WHERE pk.oid = fk.connamespace);
...@@ -277,3 +289,7 @@ SELECT ctid, typsend ...@@ -277,3 +289,7 @@ SELECT ctid, typsend
FROM pg_catalog.pg_type fk FROM pg_catalog.pg_type fk
WHERE typsend != 0 AND WHERE typsend != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_proc pk WHERE pk.oid = fk.typsend); NOT EXISTS(SELECT 1 FROM pg_catalog.pg_proc pk WHERE pk.oid = fk.typsend);
SELECT ctid, typbasetype
FROM pg_catalog.pg_type fk
WHERE typbasetype != 0 AND
NOT EXISTS(SELECT 1 FROM pg_catalog.pg_type pk WHERE pk.oid = fk.typbasetype);
...@@ -147,7 +147,6 @@ SELECT * FROM atestv2; -- fail (even though regressuser2 can access underlying a ...@@ -147,7 +147,6 @@ SELECT * FROM atestv2; -- fail (even though regressuser2 can access underlying a
-- switch to superuser -- switch to superuser
\c - \c -
SET autocommit TO 'on';
REVOKE ALL PRIVILEGES ON LANGUAGE sql FROM PUBLIC; REVOKE ALL PRIVILEGES ON LANGUAGE sql FROM PUBLIC;
GRANT USAGE ON LANGUAGE sql TO regressuser1; -- ok GRANT USAGE ON LANGUAGE sql TO regressuser1; -- ok
...@@ -184,7 +183,6 @@ SELECT testfunc1(5); -- ok ...@@ -184,7 +183,6 @@ SELECT testfunc1(5); -- ok
DROP FUNCTION testfunc1(int); -- fail DROP FUNCTION testfunc1(int); -- fail
\c - \c -
SET autocommit TO 'on';
DROP FUNCTION testfunc1(int); -- ok DROP FUNCTION testfunc1(int); -- ok
-- restore to sanity -- restore to sanity
...@@ -203,7 +201,6 @@ select has_table_privilege(1,'rule'); ...@@ -203,7 +201,6 @@ select has_table_privilege(1,'rule');
-- superuser -- superuser
\c - \c -
SET autocommit TO 'on';
select has_table_privilege(current_user,'pg_shadow','select'); select has_table_privilege(current_user,'pg_shadow','select');
select has_table_privilege(current_user,'pg_shadow','insert'); select has_table_privilege(current_user,'pg_shadow','insert');
...@@ -323,7 +320,6 @@ SELECT has_table_privilege('regressuser1', 'atest4', 'SELECT WITH GRANT OPTION') ...@@ -323,7 +320,6 @@ SELECT has_table_privilege('regressuser1', 'atest4', 'SELECT WITH GRANT OPTION')
-- clean up -- clean up
\c regression \c regression
SET autocommit TO 'on';
DROP FUNCTION testfunc2(int); DROP FUNCTION testfunc2(int);
DROP FUNCTION testfunc4(boolean); DROP FUNCTION testfunc4(boolean);
......
...@@ -48,7 +48,6 @@ DROP TABLE temptest; ...@@ -48,7 +48,6 @@ DROP TABLE temptest;
CREATE TEMP TABLE temptest(col int); CREATE TEMP TABLE temptest(col int);
\c regression \c regression
SET autocommit TO 'on';
SELECT * FROM temptest; SELECT * FROM temptest;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment