]> granicus.if.org Git - postgresql/commitdiff
Added VERBOSE option to vacuum command.
authorBruce Momjian <bruce@momjian.us>
Mon, 13 Jan 1997 03:45:33 +0000 (03:45 +0000)
committerBruce Momjian <bruce@momjian.us>
Mon, 13 Jan 1997 03:45:33 +0000 (03:45 +0000)
src/backend/commands/vacuum.c
src/backend/parser/gram.y
src/backend/parser/keywords.c
src/backend/tcop/utility.c
src/include/commands/vacuum.h
src/include/nodes/parsenodes.h
src/man/vacuum.l

index 62609ad1af116e578dc5c4886fbdd9ae7ef7015a..8fa7afd129564a60bf422efcd4230852514ee7be 100644 (file)
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *    $Header: /cvsroot/pgsql/src/backend/commands/vacuum.c,v 1.13 1997/01/10 09:57:16 vadim Exp $
+ *    $Header: /cvsroot/pgsql/src/backend/commands/vacuum.c,v 1.14 1997/01/13 03:43:59 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
 #endif /* NEED_RUSAGE */
 
 bool VacuumRunning =   false;
-
-#ifdef VACUUM_QUIET
-static int MESSLEV = DEBUG;
-#else
-static int MESSLEV = NOTICE;
-#endif
+static int MESSLEV;    /* message level */
 
 typedef struct {
     FuncIndexInfo      finfo;
@@ -90,10 +85,15 @@ static bool _vc_enough_space (VPageDescr vpd, Size len);
 
 
 void
-vacuum(char *vacrel)
+vacuum(char *vacrel, bool verbose)
 {
     NameData VacRel;
 
+    if (verbose)
+       MESSLEV = NOTICE;
+    else
+       MESSLEV = DEBUG;
+
     /* vacrel gets de-allocated on transaction commit */
        
     /* initialize vacuum cleaner */
index fd5a05f0c4016e154c5ffb6a208abc913a2d70c1..a7809b61ccceb578233d6b7bc54dfa61ee5ae733 100644 (file)
@@ -10,7 +10,7 @@
  *
  *
  * IDENTIFICATION
- *    $Header: /cvsroot/pgsql/src/backend/parser/gram.y,v 1.23 1996/12/20 20:33:12 momjian Exp $
+ *    $Header: /cvsroot/pgsql/src/backend/parser/gram.y,v 1.24 1997/01/13 03:44:18 momjian Exp $
  *
  * HISTORY
  *    AUTHOR           DATE            MAJOR EVENT
@@ -133,7 +133,8 @@ static Node *makeA_Expr(int oper, char *opname, Node *lexpr, Node *rexpr);
        expr_list, attrs, res_target_list, res_target_list2,
        def_list, opt_indirection, group_clause, groupby_list, explain_options
 
-%type <boolean>        opt_inh_star, opt_binary, opt_instead, opt_with_copy, index_opt_unique
+%type <boolean>        opt_inh_star, opt_binary, opt_instead, opt_with_copy,
+               index_opt_unique, opt_verbose
 
 %type <ival>   copy_dirn, archive_type, OptArchiveType, OptArchiveLocation, 
        def_type, opt_direction, remove_type, opt_column, event
@@ -187,7 +188,7 @@ static Node *makeA_Expr(int oper, char *opname, Node *lexpr, Node *rexpr);
         RENAME, REPLACE, RETRIEVE, RETURNS, REVOKE, ROLLBACK, RULE, 
         SELECT, SET, SETOF, STDIN, STDOUT, STORE, 
        TABLE, TO, TRANSACTION, UNIQUE, UPDATE, USING, VACUUM, VALUES
-       VERSION, VIEW, WHERE, WITH, WORK
+       VERBOSE, VERSION, VIEW, WHERE, WITH, WORK
 %token EXECUTE, RECIPE, EXPLAIN, LIKE 
 
 /* Special keywords, not in the query language - see the "lex" file */
@@ -1200,18 +1201,25 @@ ClusterStmt:  CLUSTER index_name ON relation_name
  *
  *****************************************************************************/
 
-VacuumStmt:  VACUUM
+VacuumStmt:  VACUUM opt_verbose
                {
-                   $$ = (Node *)makeNode(VacuumStmt);
+                   VacuumStmt *n = makeNode(VacuumStmt);
+                   n->verbose = $2;
+                   $$ = (Node *)n;
                }
-         | VACUUM relation_name
+         | VACUUM opt_verbose relation_name
                {
                    VacuumStmt *n = makeNode(VacuumStmt);
-                   n->vacrel = $2;
+                   n->verbose = $2;
+                   n->vacrel = $3;
                    $$ = (Node *)n;
                }
        ;
 
+opt_verbose:  VERBOSE                  { $$ = TRUE; }
+       | /* EMPTY */                   { $$ = FALSE; }
+       ;
+       
 /*****************************************************************************
  *
  *     QUERY:
index 8f6ab83bc57691be36db6c968bcee75efe2955f6..80705dee9cedf85d102b122149b245f38b6d451c 100644 (file)
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *    $Header: /cvsroot/pgsql/src/backend/parser/keywords.c,v 1.5 1996/11/30 03:38:07 momjian Exp $
+ *    $Header: /cvsroot/pgsql/src/backend/parser/keywords.c,v 1.6 1997/01/13 03:44:25 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -136,6 +136,7 @@ static ScanKeyword ScanKeywords[] = {
        { "using",              USING           },
        { "vacuum",             VACUUM          },
        { "values",             VALUES          },
+       { "verbose",            VERBOSE         },
        { "version",            VERSION         },
        { "view",               VIEW            },
        { "where",              WHERE           },
index 26bb04d751ec8c26d3ea2ce4080edc1ec682b5fa..0c5756c1e2b969e61314a00fd1b3944783dad138 100644 (file)
@@ -9,7 +9,7 @@
  *
  *
  * IDENTIFICATION
- *    $Header: /cvsroot/pgsql/src/backend/tcop/utility.c,v 1.9 1996/11/13 20:49:50 scrappy Exp $
+ *    $Header: /cvsroot/pgsql/src/backend/tcop/utility.c,v 1.10 1997/01/13 03:44:38 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -580,7 +580,8 @@ ProcessUtility(Node *parsetree,
     case T_VacuumStmt:
        commandTag = "VACUUM";
        CHECK_IF_ABORTED();
-       vacuum(((VacuumStmt *) parsetree)->vacrel);
+       vacuum( ((VacuumStmt *) parsetree)->vacrel,
+               ((VacuumStmt *) parsetree)->verbose);
        break;
 
     case T_ExplainStmt:
index 0a34170dddf85e622e4172688a6ca4286e4fa312..8cf220d9cdd9e09447b66321d81a23e656e4cd04 100644 (file)
@@ -6,7 +6,7 @@
  *
  * Copyright (c) 1994, Regents of the University of California
  *
- * $Id: vacuum.h,v 1.4 1996/11/29 10:29:45 vadim Exp $
+ * $Id: vacuum.h,v 1.5 1997/01/13 03:44:54 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -54,7 +54,7 @@ typedef VRelListData  *VRelList;
 extern bool VacuumRunning;
 
 extern void vc_abort(void);
-extern void vacuum(char *vacrel);
+extern void vacuum(char *vacrel, bool verbose);
 
 
 #endif /* VACUUM_H */
index 9c6500135c9acc0b9db8b76853fbc02621ee4c71..32929b7bb13e73c515b531200186b0248799818c 100644 (file)
@@ -6,7 +6,7 @@
  *
  * Copyright (c) 1994, Regents of the University of California
  *
- * $Id: parsenodes.h,v 1.8 1996/12/17 01:53:43 momjian Exp $
+ * $Id: parsenodes.h,v 1.9 1997/01/13 03:45:02 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -397,6 +397,7 @@ typedef struct ClusterStmt {
  */
 typedef struct VacuumStmt {
     NodeTag            type;
+    bool               verbose;        /* print status info */
     char               *vacrel;        /* table to vacuum */
 } VacuumStmt;
 
index b36f95c30586a468760745b30300c701da00dc95..9137442df9ba8cf180cc977ff69a71b66e3769a9 100644 (file)
@@ -1,12 +1,12 @@
 .\" This is -*-nroff-*-
 .\" XXX standard disclaimer belongs here....
-.\" $Header: /cvsroot/pgsql/src/man/Attic/vacuum.l,v 1.2 1996/12/11 00:28:15 momjian Exp $
+.\" $Header: /cvsroot/pgsql/src/man/Attic/vacuum.l,v 1.3 1997/01/13 03:45:33 momjian Exp $
 .TH VACUUM SQL 11/05/95 PostgreSQL PostgreSQL
 .SH NAME
 vacuum \(em vacuum a database
 .SH SYNOPSIS
 .nf
-\fBvacuum [table]\fP
+\fBvacuum [verbose] [\fPtable\fB]\fP
 .fi
 .SH DESCRIPTION
 .BR Vacuum
@@ -18,6 +18,8 @@ tuples and number of pages stored in all classes.  Running
 .BR vacuum
 periodically will increase Postgres's speed in processing user queries.
 .PP
+\fBverbose\fP prints a detailed vacuum activity report for each table.
+.PP
 The open database is the one that is vacuumed.  
 .PP
 We recommend that production databases be vacuumed nightly, in order