Sponsor Banner Advertisment PostgreSQL Banner PostgreSQL Banner Project Banner Advertisment
  Download · Mirrors · Lists · Users · Developers · Docs · Search
Search this document set:

A.33. Postgres95 Release 0.03

Release date: 1995-07-21

A.33.1. Changes

Incompatible changes:
  * BETA-0.3 IS INCOMPATIBLE WITH DATABASES CREATED WITH PREVIOUS VERSIONS
    (due to system catalog changes and indexing structure changes).
  * double-quote (") is deprecated as a quoting character for string literals;
    you need to convert them to single quotes ('). 
  * name of aggregates (eg. int4sum) are renamed in accordance with the
    SQL standard (eg. sum).
  * CHANGE ACL syntax is replaced by GRANT/REVOKE syntax.
  * float literals (eg. 3.14) are now of type float4 (instead of float8 in
    previous releases); you might have to do typecasting if you depend on it
    being of type float8.  If you neglect to do the typecasting and you assign
    a float literal to a field of type float8, you may get incorrect values
    stored!
  * LIBPQ has been totally revamped so that frontend applications
    can connect to multiple backends
  * the usesysid field in pg_user has been changed from int2 to int4 to
    allow wider range of Unix user ids.
  * the netbsd/freebsd/bsd o/s ports have been consolidated into a
    single BSD44_derived port.  (thanks to Alistair Crooks)
 
 SQL standard-compliance (the following details changes that makes postgres95
 more compliant to the SQL-92 standard):
  * the following SQL types are now built-in: smallint, int(eger), float, real,
    char(N), varchar(N), date and time.
 
    The following are aliases to existing postgres types:
 smallint -> int2
 integer, int -> int4
 float, real  -> float4
    char(N) and varchar(N) are implemented as truncated text types. In
    addition, char(N) does blank-padding. 
  * single-quote (') is used for quoting string literals; '' (in addition to
    \') is supported as means of inserting a single quote in a string
  * SQL standard aggregate names (MAX, MIN, AVG, SUM, COUNT) are used
    (Also, aggregates can now be overloaded, i.e. you can define your
    own MAX aggregate to take in a user-defined type.)
  * CHANGE ACL removed. GRANT/REVOKE syntax added.  
    - Privileges can be given to a group using the "GROUP" keyword.
 For example:
 GRANT SELECT ON foobar TO GROUP my_group;
 The keyword 'PUBLIC' is also supported to mean all users.
 
 Privileges can only be granted or revoked to one user or group
 at a time.  
 
 "WITH GRANT OPTION" is not supported.  Only class owners can change
 access control
    - The default access control is to to grant users readonly access.
      You must explicitly grant insert/update access to users.  To change
      this, modify the line in 
 src/backend/utils/acl.h 
      that defines ACL_WORLD_DEFAULT 
 
 Bug fixes:
  * the bug where aggregates of empty tables were not run has been fixed. Now,
    aggregates run on empty tables will return the initial conditions of the
    aggregates. Thus, COUNT of an emptytable will now properly return 0.
    MAX/MIN of an empty table will return a tuple of value NULL. 
  * allow the use of \; inside the monitor
  * the LISTEN/NOTIFY asynchronous notification mechanism now work
  * NOTIFY in rule action bodies now work
  * hash indexes work, and access methods in general should perform better.
    creation of large btree indexes should be much faster.  (thanks to Paul
    Aoki)
 
 Other changes and enhancements:
  * addition of an EXPLAIN statement used for explaining the query execution
    plan (eg. "EXPLAIN SELECT * FROM EMP" prints out the execution plan for
    the query).
  * WARN and NOTICE messages no longer have timestamps on them. To turn on
    timestamps of error messages, uncomment the line in
    src/backend/utils/elog.h:
 /* define ELOG_TIMESTAMPS */ 
  * On an access control violation, the message
 "Either no such class or insufficient privilege"
    will be given.  This is the same message that is returned when
    a class is not found.  This dissuades non-privileged users from
    guessing the existence of privileged classes.
  * some additional system catalog changes have been made that are not
    visible to the user.
 
 libpgtcl changes:
  * The -oid option has been added to the "pg_result" tcl command.
    pg_result -oid returns oid of the last tuple inserted.   If the
    last command was not an INSERT, then pg_result -oid returns "".
  * the large object interface is available as pg_lo* tcl commands:
    pg_lo_open, pg_lo_close, pg_lo_creat, etc.
 
 Portability enhancements and New Ports:
  * flex/lex problems have been cleared up.  Now, you should be able to use
    flex instead of lex on any platforms.  We no longer make assumptions of
    what lexer you use based on the platform you use. 
  * The Linux-ELF port is now supported.  Various configuration have been 
    tested:  The following configuration is known to work:
 kernel 1.2.10, gcc 2.6.3, libc 4.7.2, flex 2.5.2, bison 1.24
    with everything in ELF format,
 
 New utilities:
  * ipcclean added to the distribution
    ipcclean usually does not need to be run, but if your backend crashes
    and leaves shared memory segments hanging around, ipcclean will
    clean them up for you.
 
 New documentation:
  * the user manual has been revised and libpq documentation added.

 Top Download · Mirrors · Mailing Lists · User's Lounge · Developer's Corner · Docs · Search · Store