Slashdot Mirror


PostgreSQL 8.0 Released

Christopher Cashell writes "The PostgreSQL project has released version 8.0 of their well known Object-Relational Database. New features include: Win32 Native Server, Savepoints, Point-In-Time Recovery, Tablespaces, and lots more. Downloads are available via bittorrent for Unix/Linux, and the much anticipated Win32 version, or via ftp (use a mirror!)." (Here's the official announcement.)

45 of 556 comments (clear)

  1. Finally by eugenelim · · Score: 1, Informative

    An adequate replacement for MySQL on Windows. Can anyone say WAPP instead of LAMP?

    1. Re:Finally by fimbulvetr · · Score: 2, Informative

      I also suspect the master data is stored in a different place
      Really, I don't mean to be mean, but of course it is. That's one of the purposes of replication.

      MySQL is perfect for this. I agree, I've had a tremendous amount of success with this type of scenario.

      And the data is not really mission-critical
      So it should be no problem for Jeremy Zawodny to convince Senior Management of this newfound piece of information? I'd have to say he or anyone else would have a really friggen hard time convincing anyone at yahoo (and their finance/my yahoo customers) that the availability of their data is _not_ mission critical.

      Database crash? Just repopulate by querying the various data sources.
      Though that is entirely possible, I highly doubt that is their disaster recovery plan. Besides, even if they were using Oracle or MSSQL, this plan would still work.

  2. Great by Anonymous Coward · · Score: 5, Informative

    Great, but why should I use PostgreSQL when I already have a database, you might ask? Here's why.

    1. Re:Great by ultranova · · Score: 2, Informative

      Not to mention, MySQL is not Open Source.

      From http://www.mysql.com/company/legal/licensing/opens ource-license.html

      Our software is 100% GPL (General Public License); if yours is 100% GPL compliant, then you have no obligation to pay us for the licenses.

      As for the link you provided, it seems to be a complaint about the habit of people to do business with proven, rather than unknown, vendors. It does mention MySQL, and says that it's license pages (not actual licenses, but pages talking about licensing) "suggest" that you should get a commercial license for in-house software involving MySQL. It also implies that the GPL is vulnerable to "radical interpretation", whatever that means, and hints of ominous things that might happen if open source companies are acquired by HP, IBM or Oracle - not to mention the secret desire of RedHat: "To gently push me into a network of interlocking software and hardware components all under the same brand name" - does RedHat even make hardware ?

      In short, genral FUD piece.

      Or, even if it is technically open source, if you use it in any commercial application you have to pay.

      It is open source, on the grounds that the source code is available. It is free open source, on the grounds that the source code is available under an open source license (GPL). As usual, you cannot join GPL'd and proprietary code, unless you manage to get a license that allows this from the copyright holder of the GPL'd code.

      Please explain this technicality you speak of.

      You're even supposed to pay for each copy of MySQL used by developers of commercial applications on their development machines.

      If you redistribute MySQL in-house in a way that violates the GPL, you will need to get a commercial license, since you cannot use the GPL since you just violated it. How is this different from any other product ?

      That's not the kind of Open Source software I'm interested in.

      Fine, don't use it then. But please don't spread FUD about it.

      --

      Forget magic. Any technology distinguishable from divine power is insufficiently advanced.

  3. plperl by michaelhood · · Score: 3, Informative

    One of the most exciting features of 8.0 is plperl, their Perl-based server side language, allowing for triggers and persistent storage. On another note, I wish MySQL would catch up to PgSQL. Even if you don't like MySQL, the competition keeps them innovating. If PgSQL is light years ahead, what's pushing them?

    1. Re:plperl by AhBeeDoi · · Score: 4, Informative
      One of the most exciting features of 8.0 is plperl, their Perl-based server side language

      I'm not convinced. SQL is supposed to a standard, so you can move from one database server to another with not much effort. This is a big step away from that. Much like the features you'd find in Oracle or MS SQL.

      Hardly.

      First of all, SQL is supposed to be a sub-language used by other languages to access an RDMS. PL/Perl is a server side procedural language which allows you to write PgSQL functions in Perl. How standard is PL/SQL for Oracle? It's proprietary. In fact, Oracle and MS SQL are not entirely compliant with SQL 92 as they have their own extensions.

  4. Web Server Difficulties by Reality_X · · Score: 5, Informative

    Hi Folks,

    Please take it easy on 'wwwmaster'.

    'www' fell over a couple of hours ago, and a couple of mirrors are coming online to round-robin the address.

    Can someone please change the the first link ("PostgreSQL project") in the story to point to 'www'?

    Thanks.

  5. I've been waiting for this by wackysootroom · · Score: 4, Informative

    Goodbye Oracle, hello PostgreSQL. Now I can have a mostly SQL92 compliant database with ACID, transactions and now PITR and tablespaces that I can use on the server and on a win32 desktop.

    For those of you wanting a great frontend, try PGAdmin3. It works on Win32 and Linux.

  6. What's New in 8.0 by Pan+T.+Hose · · Score: 5, Informative

    An adequate replacement for MySQL on Windows. Can anyone say WAPP instead of LAMP?

    Not only that. Here's the most important link: What's New in 8.0. (To editors: why there are links to torrents, but no link to features?)

    --
    Sincerely,
    Pan Tarhei Hosé, PhD.
    "Homo sum et cogito ergo odi profanum vulgus et libido."
  7. Re:I didn't read the article... by Mark+Imbriaco · · Score: 2, Informative

    PostgreSQL has had an ODBC driver for quite some time. You could use that in conjunction with SQL Servers DTS tools to copy data from a SQL Server DB to Pg. There might be some pain involved, particular with indices and constraints, but it shouldn't be too awful.

  8. Re:Erm? by Erik+Hensema · · Score: 4, Informative
    In PostgresQL you can make a table inherit parts of another table. This is what's meant by object relational. Example (from the docs):
    CREATE TABLE cities (
    name text,
    population float,
    altitude int -- (in ft)
    );

    CREATE TABLE capitals (
    state char(2)
    ) INHERITS (cities);
    --

    This is your sig. There are thousands more, but this one is yours.

  9. Re:Mac OS X support? by Archibald+Buttle · · Score: 2, Informative

    To answer the first part of my question, I just found the Supported Platforms part of the manual, and sure enough Mac OS X is there.

    The question remains though - are there plans for a Mac OS X installer package?

  10. Re:Erm? by Delirium+Tremens · · Score: 3, Informative
    From http://www.postgresql.org/docs/7.3/interactive/use r-preface.html:

    PostgreSQL offers substantial additional power by incorporating the following additional concepts in such a way that users can easily extend the system:

    • inheritance
    • data types
    • functions

    Other features provide additional power and flexibility:

    • constraints
    • triggers
    • rules
    • transactional integrity

    These features put PostgreSQL into the category of databases referred to as object-relational. Note that this is distinct from those referred to as object-oriented, which in general are not as well suited to supporting traditional relational database languages. So, although PostgreSQL has some object-oriented features, it is firmly in the relational database world.

  11. Re:Erm? by quigonn · · Score: 2, Informative
    --
    A monkey is doing the real work for me.
  12. Re:Mac OS X support? by DrZZ · · Score: 2, Informative

    This guy usually isn't too far behind in creating .pkg for the stable PostgreSQL releases. I have run it on OS X for a number of years and I have been very happy with it.

  13. Re:How does it compare to Oracle? by nemesisj · · Score: 4, Informative

    It's got a long way to go as far as enterprise features.

    There is no clustering support in PostgreSQL (and I mean real clustering, not some Java hack where transactions are shipped off to two separate DB servers, both of which don't know they're part of a cluster). This is pretty much a show stopper as far as using PostgreSQL in the company I work for, as high availability is a large concern, and any downtime would be serious.

    In previous versions of PostgreSQL, the pg_dump and pg_restore tools were not very good - dumps that included tables or views often would fail on reimport because PostgreSQL wouldn't know the order in which to import everything. You also had to pass in a number of options on the command line just to get a dump that made sense, and large object support was kind of clunky.

    That said, I still use PostgreSQL for many many projects and have used PostgreSQL for many years. It's a great product, but it isn't near Oracle in terms of enterprise level features.

  14. Re:Mac OS X support? by larkost · · Score: 2, Informative

    The standard way of finding MacOS software would have answered this question in a heartbeat: VersionTracker or MacUpdate, both of which list installers.

  15. Re:Magical upgrade needed by Dom2 · · Score: 2, Informative
    You need to look at setting up a second system and running slony-I.

    -Dom

  16. Re:I didn't read the article... by SiggyRadiation · · Score: 2, Informative

    If you want to migrate away from SQL-Server then you have MS DTS (at least for the time being).

    DTS can pump your MS-SQL-database into postgresql with little problem i'd expect. Now getting the logic (triggers, functions) transferred is a whole other question.

    Siggy.

    --
    This unique sig is intended to make this user more recognisable.
  17. Re:Sorry, don't want to start a war but... by Anonymous Coward · · Score: 1, Informative

    Could anyone give an example of where you might want to use postgresql over mysql and vice versa?

    Here it is.

  18. Re:Replication and vacuum? by IsleOfView · · Score: 3, Informative
    Yes and Yes.

    Master-Slave replication is available through Slony1. (This is currently used by Afilias on the .info domain) Slony2 is in progress and will provide multi-master replication.

    Vacuuming is still necessary, but it no longer locks tables. The distribution includes a utility called pg_autovacuum which can take care of all the vacuuming tasks on an automated basis if you desire. (The gentoo release automatically installs this with a nice init script :) )

  19. Use Slony for replication by chriskl · · Score: 3, Informative

    Check out the new Slony replication engine:

    http://www.slony.info/

    It is probably the best master->slave data replication engine for PostgreSQL at the moment. It is free and developed by one of the core developers.

  20. Re:Magical upgrade needed by DrSkwid · · Score: 2, Informative

    Do you know of any database (free or commercial) that supports such a feature (auto)magically?

    yes : this one

    see http://slony.info/ as the other poster mentioned

    --
    There are places where the networks are not touching,and there are places where they are-Boeing's Lori Gunter
  21. Re:Two more features... by JohanV · · Score: 4, Informative

    Most of your first request is already implemented in PostgreSQL 8. You can combine a hot backup of the files on the filesystem with the WAL-archiver to have the backup feature you want. It is not per tablespace (yet) so you have to backup your entire database.

    For the second request, keep a close eye on the mailinglists. Affilias has hired a core developer to make it happen.
    The first stage, master-slave replication, has been released in the form of Slony-1. Yes, it is an add on. No, it is not integrated. But you can add Slony-1 to a running system and add slaves without ever taking the master down, and it is backwards compatible so you can even use it to upgrade running 7.3.x installations to PostgreSQL 8.
    The second stage, Slony-2, will be a full multi-master replication solution. (I read something about a 'kickoff' meeting today hosted by Affilias.) The goal is to be able to take a single, out of the box installation of PostgreSQL, plug Slony-1 into it, replicate the database to another box and when that box has caught up switch to full multi-master mode under Slony-2.
    The code won't fall out of the sky tomorrow, but people are working on it.

  22. Re:Mac OS X support? by SuperBanana · · Score: 3, Informative
    My favoured platform though is Mac OS X. There's a whole list of platforms in the FAQ, but Mac isn't amongst them. So my questions are is Mac OS X supported, and if so are there any plans to make a Mac OS X .pkg installation file?

    7.x compiles right out of the box- in fact, Apple's Remote Desktop system actually installs and uses PostgreSQL for all its data storage (client system data and whatnot; ARD can collect a lot of per-system data). Very slick.

  23. Re:PGSQL has its own gotchas by Hammer · · Score: 2, Informative

    Another garage product also fares badly on COUNT(*) however if you do COUNT() they both do real well. It has to do with the fact that when you do COUNT(*) you have to count every row and that takes a fair bit of time. When you do COUNT(key) you count rows in the index file and that is real quick :-)

  24. Re:PGSQL has its own gotchas by jedidiah · · Score: 2, Informative

    If your RDBMS is doing a full table scan just to do a count(*), then it (or your code) is badly broken.

    --
    A Pirate and a Puritan look the same on a balance sheet.
  25. Re:PGSQL has its own gotchas by Cajal · · Score: 5, Informative

    In MySQL (with MyISAM tables), the reason things like count(*) are fast is that MyISAM pre-computes those values. It can do this because it locks the table on insert and update. PostgreSQL doesn't lock the table on modifications -- it allows concurrent access via Multi-Version Concurrency Control (MVCC). Basically, each row in the DB has additional information (used internally by PostgreSQL), which stores which transaction created and last modified the row. PG uses this to determine if any given row should be "visible" to the current transaction. Because this informaiton is constantly changing (and varies from transaction to transaction), you can't precompute things like count(*) and sum(*). See http://developer.postgresql.org/pdf/internalpics.p df for more info (start around page 56).

  26. Re:correcting you if you're wrong ;-) by mborland · · Score: 2, Informative
    You're probably referring to BCP or a similar function, which dumps a single table of data at a time to a text file in a specified format. What the original poster is probably referring to is the ability to dump a database into an SQL script that, when run, completely re-creates the schema, data and other features of the database. It's a very simple backup/restore mechanism and makes various conversions and other operations much easier.

  27. Re:How does it compare to Oracle? by kpharmer · · Score: 4, Informative

    Postgresql is ready to take on the smaller, non-critical databases that oracle used to get. This is significant proportion of the databases out there, and will take revenue away from oracle. (Mysql will actually probably take more revenue away, but it has too many quality problems and functionality gaps to really deserve to.)

    But there are many other, more demanding databases that postgresql isn't yet ready for. Oracle, DB2, and even SQL Server 2005 all have very mature & solid: optimizers, replication, partitioning solutions, parallelism, failover/clustering support, etc.

    Here are two examples:

    Using db2 for example, you can create a view which is automatically populated by the database like a table (MQT). Then any queries against the base tables that could be sped up by hitting this view will be rewritten by the engine to hit the view. Now, this might seem like needless fluff if you're just writing a hobby php app. But if you need to implement a commercial app like SAP with its 6,000 tables - and you have performance issues - you can make adjustments in the database layer this way. Also, if you're provoding adhoc reporting for hundreds of users on a terrabyte of data - this technique can provide *dramatic* performance benefits.

    Another example is partitioning. Back to db2 (which I work with the most): you can spread a database across a dozen separate servers using a hashkey. Now, every query will have all dozen servers working independently on its own fraction of the data. On each of those servers, you can then partition again, this time using ranges or values (MDC) - so that data that doesn't apply to a query will be skipped in tablescans of that table. Using these techniques you can get sub-second response to *adhoc* queries against a terrabyte of data - without indexes (notoriously unreliable here).

    Lots more examples where the above came from. Sure, you will pay real money for licensing, hardware, and labor to implement these. Then again, the two above features actually save you in hardware costs. Additionally, some problems are big enough that they can easily justify the cost of licensing a product like this. I've seen these techniques used to save companies million, even hundreds of millions of dollars.

  28. Re:It's easier to install and admin than mysql by DigitalRaptor · · Score: 3, Informative

    Threads have to do solely with 3rd party plugins, not with PHP itself. PHP5 is completely thread safe.

    --
    Lose Weight and Feel Great with Isagenix
  29. Re:PGSQL has its own gotchas by amorsen · · Score: 4, Informative
    If your RDBMS is doing a full table scan just to do a count(*), then it (or your code) is badly broken.

    Postgres knows how many rows are in the table, but it does not know how many of those you can see. Some of them may be inserted speculatively by another transaction. Postgres needs to go through each row to determine whether or not that row is actually visible to you. It is possible to turn this into an O(1) operation if you're willing to do sufficient work on inserts and deletes. Whether this is a good tradeoff depends on how often you do count(*) compared to how often you do inserts and deletes.

    --
    Finally! A year of moderation! Ready for 2019?
  30. And my favorite features are by plopez · · Score: 2, Informative

    playing around with the beta and RCs several items impressed me:

    1) GIS support. Very important for what I do. This is probably due to how closely they work with GRASS (which I haven't used yet).

    2) Ability to define and bind operators. Very flexible.

    3) Much more relationally compliant while also supporting OOP.

    4) PGAdmin II is very handy. A few rough points but now there is no excuse for those afraid of a command line.

    It just gets better every release. I am currently porting a MMSQL database over and so far so good.

    --
    putting the 'B' in LGBTQ+
  31. Re:How does it compare to Oracle? by chriskl · · Score: 3, Informative

    Try Slony for full, production quality replication on PostgreSQL:

    http://www.slony.info/

  32. Re:PGSQL has its own gotchas by joib · · Score: 2, Informative


    No matter which version you use, if you never VACUUM dead row versions will accumulate and eventually kill your performance.


    Actually, for 7.4 and newer that isn't true, since they include the aptly named "autovacuum" daemon. And yes, autovacuum also does "VACUUM ANALYZE", so no need to worry about that either.

  33. Re:MySQL and Postgres by Martin+Foster · · Score: 2, Informative

    I switched a an open-source project from MySQL to PostgreSQL a year or so back. The application of proper transactions, referential integrity, views and stored procedures really cleaned up the code.

    However, PostgreSQL is not necessarily the easiest DBMS to get used to. For one, some platforms such as *BSD will require a recompile of the kernel to support a bit more then 32 concurrent connections. While well documented if you know what your looking for, this can prove to difficult to implement if for example your on a shared hosting system.

    Documentation can be cryptic, tending to be more like a reference manual then an actual manual to teach you how something works. When it comes to optimizing the database itself this becomes painfully obvious as certain switches and options in the postgresql.conf file do little more then offer a one line description with no real clue on how a change will affect it.

    In MySQL for example there are sample configation files which show a 'typical' configuration for small, mid-sized and dedicated setups. I have yet to see something similiar and such discussions on the newsgroups have generally shot it down because of the exotic configurations out there.

    Vacuuming is one of those things that can really confuse people. While in MySQL deleting and altering rows has no real lasting effect for the user, this is not the case with Postgres. When a row is deleted, the information remains, but is unlinked, making the system run less IO but forcing you to juggle vacuuming, re-indexing and server operations.

    You could make use of the auto-vacuum daemon available. I found however, that performance suffered greatly when it was being used on my live system.

    More often then not, documentation will speak of load testing and tweaking the server at different values to see how it works. This is sound advice if you have the hardware and time necessary to get things going properly.

    On light loads, Postgres can be great, but once you start pounding at it it will slow down unless you know what your doing. The learning curve is far greater then MySQL, the documentation could stand to be more descriptive to end-users/non-Oracle DBA's and the tools available for Windows less advanced but the feature set will make it worth while if you can devote some time for trail and error.

  34. Almost accurate by einhverfr · · Score: 3, Informative

    While I think that PostgreSQL is the best open source database out there, there is one very important gotcha wrt: MVCC which can cause data integrity. This only happens when autovacuum is not running, of course.

    If you run enough transactions between vacuum runs (iirc a billion), the transaction counter will wrap around and suddenly your data does not have a consistant point of reference regarding visible transactions. Now, if you wait for a billion transactions to run VACUUM, you either:
    1) Have extremely poor performance anyway (not to mention having all your stats off so the planner is doing seq scans when it should use an index)
    2) Are doing something with the database which I cannot imagine (I guess a huge number of select statements could cause this, but updates cause old tuples to sit around, so you would have bad performance).

    Now, I am not aware of this ever actually having happened, but it is in the documentation, so I figure I should point it out. Of course if you let the database get to this point, then you have bigger problems than your data (chief among them being the IT staff and/or management)..

    In general, PostgreSQL focuses on data integrity to a degree not seen elsewhere in the open source database world. Even Firebird does not have such a heavy focus in this area, though to be fair it is a different enough product that their focus works well in their target markets.

    My company offers application development, remote administration, and implimentation services for PostgreSQL, MySQL, and Firebird. I am very excited about this release because it will enable us to do more with the database manager which makes us most productive.

    As a side note, PostgreSQL-Win32 will not run on Win9x because it requires an NTFS filesystem, iirc. So it is not a perfect solution for Windows development yet (until Win9x fades into the distance or until they decide that they should port it to FAT). Of course you could still use the Cygwin installation, I think. But it is better, IMO, to run it on a arguably stable system anyway.

    --

    LedgerSMB: Open source Accounting/ERP
  35. Change Column Types - finally by EugeneK · · Score: 3, Informative
    from the release notes :

    Change Column Types

    A column's data type can now be changed with ALTER TABLE.



    Before, to do this, you had to create a temporary table with the changed column type, copy all the data over to it, and then rename the temp table as the old table.

    Thank you Postgres team! Now, if we can rename a column, that would be a nice bonus.

  36. That's really dumb. by emil · · Score: 3, Informative

    You're telling me that MySQL locks the entire table when I insert a row? You must be joking - that would bring a database to it's knees.

    I'm an Oracle guy, and this is how they do it:

    • If you have an index on a NOT NULL column, count(*) will count the index, and it will be fast(er). If you don't have a suitable index, you will incur a full table scan. This is reasonable.
    • An Oracle table can have one or more "FREELISTS" - an insert will attempt to find a block from an available freelist, and a row lock will be applied to the transaction header of that block. If you have high insert activity, you can (re)build your table with more FREELISTS. You can have multiple transactions hitting a block if you don't exceed MAXTRANS. If you decided to shove the block clear full of data and you set INITTRANS to 1, you effectively have block-level locking, not row-level locking.
    • Oracle NEVER escalates a lock, and there is no table of locked rows in memory (and you should run away from any database that has such a structure).

    Oracle has the best technology in the industry, hands down (DB2 didn't even get triggers until v5). Postgres appears to be paying much more attention to Oracle's methods than MySQL.

    Guess which database I'd use if I had no money to spend?

    1. Re:That's really dumb. by Cajal · · Score: 4, Informative
      You're telling me that MySQL locks the entire table when I insert a row? You must be joking - that would bring a database to it's knees.

      MySQL can use different "storage engines" for different tables. One of their older (and arguably, more widely deployed) engines in MyISAM, which does table-level locking (their newer engine, InnoDB, does row-level locking). From the MySQL Manual (sec 7.3.1):

      Currently, MySQL supports table-level locking for ISAM, MyISAM, and MEMORY (HEAP) tables, page-level locking for BDB tables, and row-level locking for InnoDB tables.

      and from Section 7.3.2:

      To achieve a very high lock speed, MySQL uses table locking (instead of page, row, or column locking) for all storage engines except InnoDB and BDB.

      This is one of the many problems with MySQL. I agree with you that Oracle (and PostgreSQL) are much better designed.

  37. Installing PostgreSQL 8.0 alongside older version by matchboy · · Score: 2, Informative
    --

    Robby Russell
    PLANET ARGON
    Robby on Rails
  38. It looks like a great year for PostgreSQL by smchris · · Score: 3, Informative


    Oxford University announced a while back that they will be scrapping most of their proprietary DBs for PostgreSQL over the course of '05:

    http://news.zdnet.co.uk/software/applications/0% 2C 39020384%2C39173013%2C00.htm

  39. Re:What about case sensitivity? by Anonymous Coward · · Score: 1, Informative

    Postgres can perform a case insensitive query, you use the operator ~~* instead of =, e.g.

    SELECT * FROM customers WHERE name ~~* 'bob';

    matches bob, Bob, BOB, etc.

    I hope you find this useful.

  40. Re:Replication by rkit · · Score: 2, Informative

    Did you already take a look at slony?
    http://gborg.postgresql.org/project/slony1/projdis play.php

    --
    sig intentionally left blank
  41. Re:Windows Version by LetterJ · · Score: 2, Informative

    *That's* the problem I remember from earlier setups. Basically, you have to *install* it as an administrator so that it can *run* as a non-administrator.

    That's a problem for users in a corporate environment where they aren't authorized to create users on their workstations.