1. 22 Mar, 2003 6 commits
  2. 21 Mar, 2003 12 commits
  3. 20 Mar, 2003 22 commits
    • Bruce Momjian's avatar
      Fix multiline C comments in psql. · 5ae42452
      Bruce Momjian authored
      5ae42452
    • Bruce Momjian's avatar
      Update for new serial functionality. · e5f5e73f
      Bruce Momjian authored
      e5f5e73f
    • Bruce Momjian's avatar
      This is not the only place in the system catalogs where NULL is · b2e09fcd
      Bruce Momjian authored
      effectively used to mean a default value that could also be spelled
      out explicitly.  (ACLs behave that way, and useconfig/datconfig
      do too IIRC.)
      
      It's a bit of a hack, but it saves table space and backend code ---
      without this convention the default would have to be inserted "manually"
      since we have no mechanism to supply defaults when C code is forming a
      new catalog tuple.
      
      I'm inclined to leave the code alone.  But Alvaro is right that it'd be
      good to point out the 'infinity' option in the CREATE USER and ALTER
      USER man pages.  (Doc patch please?)
      
      Alvaro Herrera
      b2e09fcd
    • Bruce Momjian's avatar
      The documentation for SELECT is incorrect in a sense: the syntax for a · 0fe77d72
      Bruce Momjian authored
      join is defined as:
      
      from_item [ NATURAL ] join_type from_item
          [ ON join_condition | USING ( join_column_list ) ]
      
      However, if the join_type is an INNER or OUTER join, an ON, USING, or
      NATURAL clause *must* be specified (it's not optional, as that segment
      of the docs suggest).
      
      I'm not exactly sure what the best way to fix this is, so I've attached
      a patch adding a FIXME comment to the relevant section of the SGML. If
      anyone has any ideas on the proper way to outline join syntax, please
      speak up.
      
      Neil Conway <neilc@samurai.com> || PGP Key ID: DB3C29FC
      0fe77d72
    • Bruce Momjian's avatar
      please apply attached patch to current CVS. · e0d043b9
      Bruce Momjian authored
      btree_gist now supports int2 !
      Thanks Janko Richter for contribution.
      e0d043b9
    • Bruce Momjian's avatar
      This patch creates a function named pg_get_triggerdef that takes the oid of · 3be6367b
      Bruce Momjian authored
      a trigger as its parameter.  It is basically copied from the pg_dump
      code.
      
      Christopher Kings-Lynne
      3be6367b
    • Bruce Momjian's avatar
      Now that the CLUSTER ALL machinery is in place, the clusterdb script can · 88192135
      Bruce Momjian authored
      be simplified (I'd thought that it can even be removed).  This patch
      does that.
      
      Alvaro Herrera
      88192135
    • Bruce Momjian's avatar
      Add ALTER TABLE <tablename> CLUSTER ON <indexname> · 432b9b0f
      Bruce Momjian authored
      Alvaro Herrera
      432b9b0f
    • Bruce Momjian's avatar
      It would also be handy if users could see their own pg_stat_activity · db5d7cca
      Bruce Momjian authored
      queries while the rest remain blank.
      
      Kevin Brown
      db5d7cca
    • Bruce Momjian's avatar
      I have updated my pg_autovacuum program (formerly pg_avd, the name · bd18c50b
      Bruce Momjian authored
      changed as per discussion on the patches list).
      
      This version should be a good bit better.  It addresses all the issues
      pointed out by Neil Conway. Vacuum and Analyze are now handled
      separately.  It now monitors for xid wraparound.  The number of database
      connections and queries has been significantly reduced compared the
      previous version.  I have moved it from bin to contrib.  More detail on
      the changes are in the TODO file.
      
      I have not tested the xid wraparound code as I have to let my AthlonXP
      1600 run select 1 in a tight loop for approx. two days in order to
      perform the required 500,000,000 xacts.
      
      Matthew T. O'Connor
      bd18c50b
    • Bruce Momjian's avatar
      Fix typo in SGML tags. · 41d17389
      Bruce Momjian authored
      41d17389
    • Bruce Momjian's avatar
      Re-add type conversion examples. · da1534d9
      Bruce Momjian authored
      da1534d9
    • Michael Meskes's avatar
      Started adding date and timestamp. · 2e6f9756
      Michael Meskes authored
      2e6f9756
    • Bruce Momjian's avatar
      26a6378e
    • Bruce Momjian's avatar
      Remove compile warning. · 4422fe60
      Bruce Momjian authored
      4422fe60
    • Bruce Momjian's avatar
      At present, dates are put into a dump in the format specified by the · cf4cee1b
      Bruce Momjian authored
      default datestyle.  This is not portable between installations.
      
      This patch sets DATESTYLE to ISO at the start of a pg_dump, so that the
      dates written into the dump will be restorable onto any database,
      regardless of how its default datestyle is set.
      
      Oliver Elphick
      cf4cee1b
    • Bruce Momjian's avatar
      Todo items: · 5f65225f
      Bruce Momjian authored
      Add ALTER SEQUENCE to modify min/max/increment/cache/cycle values
      
      Also updated create sequence docs to mention NO MINVALUE, & NO MAXVALUE.
      
      New Files:
      doc/src/sgml/ref/alter_sequence.sgml
      src/test/regress/expected/sequence.out
      src/test/regress/sql/sequence.sql
      
      
      ALTER SEQUENCE is NOT transactional.  It behaves similarly to setval().
      It matches the proposed SQL200N spec, as well as Oracle in most ways --
      Oracle lacks RESTART WITH for some strange reason.
      
      --
      Rod Taylor <rbt@rbt.ca>
      5f65225f
    • Bruce Momjian's avatar
      Done: · 46bce088
      Bruce Momjian authored
      > 	o -Add ALTER SEQUENCE to modify min/max/increment/cache/cycle values
      46bce088
    • Bruce Momjian's avatar
      Attached is an update to contrib/tablefunc. It implements a new hashed · 64d0b8b0
      Bruce Momjian authored
      version of crosstab. This fixes a major deficiency in real-world use of
      the original version. Easiest to undestand with an illustration:
      
      Data:
      -------------------------------------------------------------------
      select * from cth;
        id | rowid |        rowdt        |   attribute    |      val
      ----+-------+---------------------+----------------+---------------
         1 | test1 | 2003-03-01 00:00:00 | temperature    | 42
         2 | test1 | 2003-03-01 00:00:00 | test_result    | PASS
         3 | test1 | 2003-03-01 00:00:00 | volts          | 2.6987
         4 | test2 | 2003-03-02 00:00:00 | temperature    | 53
         5 | test2 | 2003-03-02 00:00:00 | test_result    | FAIL
         6 | test2 | 2003-03-02 00:00:00 | test_startdate | 01 March 2003
         7 | test2 | 2003-03-02 00:00:00 | volts          | 3.1234
      (7 rows)
      
      Original crosstab:
      -------------------------------------------------------------------
      SELECT * FROM crosstab(
         'SELECT rowid, attribute, val FROM cth ORDER BY 1,2',4)
      AS c(rowid text, temperature text, test_result text, test_startdate
      text, volts text);
        rowid | temperature | test_result | test_startdate | volts
      -------+-------------+-------------+----------------+--------
        test1 | 42          | PASS        | 2.6987         |
        test2 | 53          | FAIL        | 01 March 2003  | 3.1234
      (2 rows)
      
      Hashed crosstab:
      -------------------------------------------------------------------
      SELECT * FROM crosstab(
         'SELECT rowid, attribute, val FROM cth ORDER BY 1',
         'SELECT DISTINCT attribute FROM cth ORDER BY 1')
      AS c(rowid text, temperature int4, test_result text, test_startdate
      timestamp, volts float8);
        rowid | temperature | test_result |   test_startdate    | volts
      -------+-------------+-------------+---------------------+--------
        test1 |          42 | PASS        |                     | 2.6987
        test2 |          53 | FAIL        | 2003-03-01 00:00:00 | 3.1234
      (2 rows)
      
      Notice that the original crosstab slides data over to the left in the
      result tuple when it encounters missing data. In order to work around
      this you have to be make your source sql do all sorts of contortions
      (cartesian join of distinct rowid with distinct attribute; left join
      that back to the real source data). The new version avoids this by
      building a hash table using a second distinct attribute query.
      
      The new version also allows for "extra" columns (see the README) and
      allows the result columns to be coerced into differing datatypes if they
      are suitable (as shown above).
      
      In testing a "real-world" data set (69 distinct rowid's, 27 distinct
      categories/attributes, multiple missing data points) I saw about a
      5-fold improvement in execution time (from about 2200 ms old, to 440 ms
      new).
      
      I left the original version intact because: 1) BC, 2) it is probably
      slightly faster if you know that you have no missing attributes.
      
      README and regression test adjustments included. If there are no
      objections, please apply.
      
      Joe Conway
      64d0b8b0
    • Bruce Momjian's avatar
      I'm continuing to work on cleaning up code in psql. As things appear · add932ee
      Bruce Momjian authored
      now, my changes seem to work.  Some possible minor bugs got squished
      on the way but I can't be sure without more feedback from people who
      really put the code to the test.
      
      The new patch mostly simplifies variable handling and reduces code
      duplication.  Changes in the command parser eliminate some redundant
      variables (boolean state + depth counter), replaces some
      "else if" constructs with switches, and so on.  It is meant to be
      applied together with my previous patch, although I hope they don't
      conflict; I went back to the CVS version for this one.
      
      One more thing I thought should perhaps be changed: an IGNOREEOF
      value of n will ignore only n-1 EOFs.  I didn't want to touch this
      for fear of breaking existing applications, but it does seem a tad
      illogical.
      
      Jeroen T. Vermeulen
      add932ee
    • Bruce Momjian's avatar
      It has been tested only against CVS backend, however. Some checking of the · 1b3d4cef
      Bruce Momjian authored
      changes to the SQL to retrieve attributes for older versions of Postgres is
      probably wise.  Also, please make sure that I have mapped the storage types
      to the correct storage names, as this is relatively poorly documented.
      
      I think that this patch might need to be considered for back-porting to
      7.3.3 since at the moment, people will be losing valuable information after
      upgrades.
      
      Will dump:
      
      CREATE TABLE test (
          a text,
          b text,
          c text,
          d text
      );
      ALTER TABLE ONLY test ALTER COLUMN a SET STATISTICS 55;
      ALTER TABLE ONLY test ALTER COLUMN a SET STORAGE PLAIN;
      ALTER TABLE ONLY test ALTER COLUMN b SET STATISTICS 1000;
      ALTER TABLE ONLY test ALTER COLUMN c SET STORAGE EXTERNAL;
      ALTER TABLE ONLY test ALTER COLUMN d SET STORAGE MAIN;
      
      Christopher Kings-Lynne
      1b3d4cef
    • Bruce Momjian's avatar
      PGRES_POLLING_ACTIVE is unused, keep for backward compatibility. · 44aba280
      Bruce Momjian authored
      Lennert Buytenhek
      44aba280