OSDN Git Service

Remove crossdb content.
authorBruce Momjian <bruce@momjian.us>
Thu, 12 Feb 2004 17:23:30 +0000 (17:23 +0000)
committerBruce Momjian <bruce@momjian.us>
Thu, 12 Feb 2004 17:23:30 +0000 (17:23 +0000)
doc/TODO.detail/crossdb [deleted file]

diff --git a/doc/TODO.detail/crossdb b/doc/TODO.detail/crossdb
deleted file mode 100644 (file)
index a68fb19..0000000
+++ /dev/null
@@ -1,771 +0,0 @@
-From pgsql-hackers-owner+M16329=candle.pha.pa.us=pgman@postgresql.org Thu Dec  6 13:31:28 2001
-Return-path: <pgsql-hackers-owner+M16329=candle.pha.pa.us=pgman@postgresql.org>
-Received: from west.navpoint.com (west.navpoint.com [207.106.42.13])
-       by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id fB6IVRZ13376
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 13:31:27 -0500 (EST)
-Received: from rs.postgresql.org (server1.pgsql.org [64.39.15.238] (may be forged))
-       by west.navpoint.com (8.11.6/8.10.1) with ESMTP id fB6IVQa26949
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 13:31:26 -0500 (EST)
-Received: from postgresql.org (postgresql.org [64.49.215.8])
-       by rs.postgresql.org (8.11.6/8.11.6) with ESMTP id fB6IRvR61959
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 12:29:06 -0600 (CST)
-       (envelope-from pgsql-hackers-owner+M16329=candle.pha.pa.us=pgman@postgresql.org)
-Received: from gromit.dotclick.com (ipn9-f8366.net-resource.net [216.204.83.66])
-       by postgresql.org (8.11.3/8.11.4) with ESMTP id fB6IQ2m78192
-       for <pgsql-hackers@postgresql.org>; Thu, 6 Dec 2001 13:26:05 -0500 (EST)
-       (envelope-from markw@mohawksoft.com)
-Received: from mohawksoft.com (IDENT:markw@localhost.localdomain [127.0.0.1])
-       by gromit.dotclick.com (8.9.3/8.9.3) with ESMTP id NAA10076
-       for <pgsql-hackers@postgresql.org>; Thu, 6 Dec 2001 13:28:04 -0500
-Message-ID: <3C0FB8B4.382C7736@mohawksoft.com>
-Date: Thu, 06 Dec 2001 13:28:04 -0500
-From: mlw <markw@mohawksoft.com>
-X-Mailer: Mozilla 4.75 [en] (X11; U; Linux 2.4.16 i686)
-X-Accept-Language: en
-MIME-Version: 1.0
-To: "pgsql-hackers@postgresql.org" <pgsql-hackers@postgresql.org>
-Subject: [HACKERS] Remote connections?
-Content-Type: text/plain; charset=us-ascii
-Content-Transfer-Encoding: 7bit
-Precedence: bulk
-Sender: pgsql-hackers-owner@postgresql.org
-Status: OR
-
-I just found out something about Oracle which that looks like something
-that could be doable in PostgreSQL. 
-
-What do you all think:
-
-Oracle's version is something like this:
-
-create [public] database link using [...]
-
-select * from sometable@remotelink
-
-
-I was thinking how this could be done with postgreSQL. How hard would it
-be to make something that is similar to a view, but executes a query
-remotely? I envision something like this:
-
-create [public] link name query using [...]
-
-The table link will be similar to a view. It could be used like this:
-
-CREATE LINK test as select * from test WITH 'user=postgres host=remote
-db=data';
-
-SELECT * from test;
-
-or 
-
-SELECT * from fubar join test on (fubar.id = test.id) ;
-
-So, what do you think? Impossible, possible, too hard? too easy?
-
----------------------------(end of broadcast)---------------------------
-TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
-
-From pgsql-hackers-owner+M16331=candle.pha.pa.us=pgman@postgresql.org Thu Dec  6 15:12:28 2001
-Return-path: <pgsql-hackers-owner+M16331=candle.pha.pa.us=pgman@postgresql.org>
-Received: from west.navpoint.com (west.navpoint.com [207.106.42.13])
-       by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id fB6KCQZ19987
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 15:12:27 -0500 (EST)
-Received: from rs.postgresql.org (server1.pgsql.org [64.39.15.238] (may be forged))
-       by west.navpoint.com (8.11.6/8.10.1) with ESMTP id fB6KCQa13967
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 15:12:26 -0500 (EST)
-Received: from postgresql.org (postgresql.org [64.49.215.8])
-       by rs.postgresql.org (8.11.6/8.11.6) with ESMTP id fB6K6nR65020
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 14:07:54 -0600 (CST)
-       (envelope-from pgsql-hackers-owner+M16331=candle.pha.pa.us=pgman@postgresql.org)
-Received: from ece.rice.edu (ece.rice.edu [128.42.4.34])
-       by postgresql.org (8.11.3/8.11.4) with ESMTP id fB6K6Im96910
-       for <pgsql-hackers@postgresql.org>; Thu, 6 Dec 2001 15:06:18 -0500 (EST)
-       (envelope-from reedstrm@rice.edu)
-Received: from localhost (localhost [127.0.0.1])
-       by ece.rice.edu (Postfix) with ESMTP
-       id A9E4E68A1D; Thu,  6 Dec 2001 14:06:17 -0600 (CST)
-Received: from wallace.ece.rice.edu (wallace.ece.rice.edu [128.42.12.154])
-       by ece.rice.edu (Postfix) with ESMTP
-       id EA06668A17; Thu,  6 Dec 2001 14:06:16 -0600 (CST)
-Received: from reedstrm by wallace.ece.rice.edu with local (Exim 3.22 #1 (Debian))
-       id 16C4me-0002uX-00; Thu, 06 Dec 2001 14:06:16 -0600
-Date: Thu, 6 Dec 2001 14:06:16 -0600
-From: "Ross J. Reedstrom" <reedstrm@rice.edu>
-To: mlw <markw@mohawksoft.com>
-cc: "pgsql-hackers@postgresql.org" <pgsql-hackers@postgresql.org>
-Subject: Re: [HACKERS] Remote connections?
-Message-ID: <20011206140616.C10995@rice.edu>
-Mail-Followup-To: "Ross J. Reedstrom" <reedstrm@ece.rice.edu>,
-       mlw <markw@mohawksoft.com>,
-       "pgsql-hackers@postgresql.org" <pgsql-hackers@postgresql.org>
-References: <3C0FB8B4.382C7736@mohawksoft.com>
-MIME-Version: 1.0
-Content-Type: text/plain; charset=us-ascii
-Content-Disposition: inline
-In-Reply-To: <3C0FB8B4.382C7736@mohawksoft.com>
-User-Agent: Mutt/1.3.18i
-X-Virus-Scanned: by AMaViS snapshot-20010714
-Precedence: bulk
-Sender: pgsql-hackers-owner@postgresql.org
-Status: OR
-
-On Thu, Dec 06, 2001 at 01:28:04PM -0500, mlw wrote:
-> I just found out something about Oracle which that looks like something
-> that could be doable in PostgreSQL. 
-> 
-> What do you all think:
-> 
-> Oracle's version is something like this:
-> 
-> create [public] database link using [...]
-> 
-> select * from sometable@remotelink
-> 
-> 
-> I was thinking how this could be done with postgreSQL. How hard would it
-> be to make something that is similar to a view, but executes a query
-> remotely? I envision something like this:
-> 
-> create [public] link name query using [...]
-> 
-> The table link will be similar to a view. It could be used like this:
-> 
-> CREATE LINK test as select * from test WITH 'user=postgres host=remote
-> db=data';
-> 
-> SELECT * from test;
-> 
-> or 
-> 
-> SELECT * from fubar join test on (fubar.id = test.id) ;
-> 
-> So, what do you think? Impossible, possible, too hard? too easy?
-
-Here we come, full circle. This is just about where I came on board.
-Many moons ago, I started looking at Mariposa, in the hopes of forward
-patching it into PostgreSQL, and generalizing the 'remote' part to allow
-exactly the sort of access you described above.
-
-The biggest problem with this is transactional semantics: you need
-two-stage commits to get this right, and we don't hav'em. (Has there
-been an indepth discussion concerning what how hard it would be to do
-that with postgresql?) 
-
-The _actual_ biggest problem was my lack of knowledge of the PostgreSQL
-codebase ;-)
-
-Ross
--- 
-Ross Reedstrom, Ph.D.                                 reedstrm@rice.edu
-Executive Director                                  phone: 713-348-6166
-Gulf Coast Consortium for Bioinformatics              fax: 713-348-6182
-Rice University MS-39
-Houston, TX 77005
-
----------------------------(end of broadcast)---------------------------
-TIP 4: Don't 'kill -9' the postmaster
-
-From pgsql-hackers-owner+M16332=candle.pha.pa.us=pgman@postgresql.org Thu Dec  6 15:31:27 2001
-Return-path: <pgsql-hackers-owner+M16332=candle.pha.pa.us=pgman@postgresql.org>
-Received: from west.navpoint.com (west.navpoint.com [207.106.42.13])
-       by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id fB6KVQZ21158
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 15:31:26 -0500 (EST)
-Received: from rs.postgresql.org (server1.pgsql.org [64.39.15.238] (may be forged))
-       by west.navpoint.com (8.11.6/8.10.1) with ESMTP id fB6KVQa22900
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 15:31:26 -0500 (EST)
-Received: from postgresql.org (postgresql.org [64.49.215.8])
-       by rs.postgresql.org (8.11.6/8.11.6) with ESMTP id fB6KRrR65596
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 14:28:55 -0600 (CST)
-       (envelope-from pgsql-hackers-owner+M16332=candle.pha.pa.us=pgman@postgresql.org)
-Received: from gromit.dotclick.com (ipn9-f8366.net-resource.net [216.204.83.66])
-       by postgresql.org (8.11.3/8.11.4) with ESMTP id fB6KJXm97564
-       for <pgsql-hackers@postgresql.org>; Thu, 6 Dec 2001 15:19:33 -0500 (EST)
-       (envelope-from markw@mohawksoft.com)
-Received: from mohawksoft.com (IDENT:markw@localhost.localdomain [127.0.0.1])
-       by gromit.dotclick.com (8.9.3/8.9.3) with ESMTP id PAA10771;
-       Thu, 6 Dec 2001 15:21:13 -0500
-Message-ID: <3C0FD339.6F663329@mohawksoft.com>
-Date: Thu, 06 Dec 2001 15:21:13 -0500
-From: mlw <markw@mohawksoft.com>
-X-Mailer: Mozilla 4.75 [en] (X11; U; Linux 2.4.16 i686)
-X-Accept-Language: en
-MIME-Version: 1.0
-To: "Ross J. Reedstrom" <reedstrm@rice.edu>
-cc: "pgsql-hackers@postgresql.org" <pgsql-hackers@postgresql.org>
-Subject: Re: [HACKERS] Remote connections?
-References: <3C0FB8B4.382C7736@mohawksoft.com> <20011206140616.C10995@rice.edu>
-Content-Type: text/plain; charset=us-ascii
-Content-Transfer-Encoding: 7bit
-Precedence: bulk
-Sender: pgsql-hackers-owner@postgresql.org
-Status: OR
-
-"Ross J. Reedstrom" wrote:
-> 
-> On Thu, Dec 06, 2001 at 01:28:04PM -0500, mlw wrote:
-> > I just found out something about Oracle which that looks like something
-> > that could be doable in PostgreSQL.
-> >
-> > What do you all think:
-> >
-> > Oracle's version is something like this:
-> >
-> > create [public] database link using [...]
-> >
-> > select * from sometable@remotelink
-> >
-> >
-> > I was thinking how this could be done with postgreSQL. How hard would it
-> > be to make something that is similar to a view, but executes a query
-> > remotely? I envision something like this:
-> >
-> > create [public] link name query using [...]
-> >
-> > The table link will be similar to a view. It could be used like this:
-> >
-> > CREATE LINK test as select * from test WITH 'user=postgres host=remote
-> > db=data';
-> >
-> > SELECT * from test;
-> >
-> > or
-> >
-> > SELECT * from fubar join test on (fubar.id = test.id) ;
-> >
-> > So, what do you think? Impossible, possible, too hard? too easy?
-> 
-> Here we come, full circle. This is just about where I came on board.
-> Many moons ago, I started looking at Mariposa, in the hopes of forward
-> patching it into PostgreSQL, and generalizing the 'remote' part to allow
-> exactly the sort of access you described above.
-> 
-> The biggest problem with this is transactional semantics: you need
-> two-stage commits to get this right, and we don't hav'em. (Has there
-> been an indepth discussion concerning what how hard it would be to do
-> that with postgresql?)
-> 
-> The _actual_ biggest problem was my lack of knowledge of the PostgreSQL
-> codebase ;-)
-
-I think we can we can dispense worrying about two stage commits, if we
-assume that remote connections are treated as views with no rules. As
-long as remote tables are "read only" then the implementation is much
-easier.
-
-I too find the internals of PostgreSQL virtually incomprehensible at the
-internal level. If there were a document somewhere which published how a
-function could return multiple tuples, remote views would be a trivial
-undertaking. It could look like:
-
-select * from remote('select *from table', 'user=postgres host=outland
-db=remote');
-
----------------------------(end of broadcast)---------------------------
-TIP 4: Don't 'kill -9' the postmaster
-
-From pgsql-hackers-owner+M16335=candle.pha.pa.us=pgman@postgresql.org Thu Dec  6 17:11:29 2001
-Return-path: <pgsql-hackers-owner+M16335=candle.pha.pa.us=pgman@postgresql.org>
-Received: from west.navpoint.com (west.navpoint.com [207.106.42.13])
-       by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id fB6MBSZ06676
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 17:11:28 -0500 (EST)
-Received: from rs.postgresql.org (server1.pgsql.org [64.39.15.238] (may be forged))
-       by west.navpoint.com (8.11.6/8.10.1) with ESMTP id fB6MBSq07059
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 17:11:28 -0500 (EST)
-Received: from postgresql.org (postgresql.org [64.49.215.8])
-       by rs.postgresql.org (8.11.6/8.11.6) with ESMTP id fB6M6sR68489
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 16:08:16 -0600 (CST)
-       (envelope-from pgsql-hackers-owner+M16335=candle.pha.pa.us=pgman@postgresql.org)
-Received: from mx1.relaypoint.net (ns2.generalbroadband.com [64.32.62.5])
-       by postgresql.org (8.11.3/8.11.4) with ESMTP id fB6M3Im04451
-       for <pgsql-hackers@postgresql.org>; Thu, 6 Dec 2001 17:03:18 -0500 (EST)
-       (envelope-from joseph.conway@home.com)
-Received: from [206.19.64.3] (account jconway@wwc.com HELO home.com)
-  by mx1.relaypoint.net (CommuniGate Pro SMTP 3.4.8)
-  with ESMTP id 1707032; Thu, 06 Dec 2001 14:03:14 -0800
-Message-ID: <3C0FEB2C.70000@home.com>
-Date: Thu, 06 Dec 2001 14:03:24 -0800
-From: Joe Conway <joseph.conway@home.com>
-User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.0; en-US; rv:0.9.6+) Gecko/20011126
-X-Accept-Language: en-us
-MIME-Version: 1.0
-To: mlw <markw@mohawksoft.com>
-cc: "Ross J. Reedstrom" <reedstrm@rice.edu>,
-   "pgsql-hackers@postgresql.org" <pgsql-hackers@postgresql.org>
-Subject: Re: [HACKERS] Remote connections?
-References: <3C0FB8B4.382C7736@mohawksoft.com> <20011206140616.C10995@rice.edu> <3C0FD339.6F663329@mohawksoft.com>
-Content-Type: text/plain; charset=us-ascii; format=flowed
-Content-Transfer-Encoding: 7bit
-Precedence: bulk
-Sender: pgsql-hackers-owner@postgresql.org
-Status: OR
-
-mlw wrote:
-
-> I too find the internals of PostgreSQL virtually incomprehensible at the
-> internal level. If there were a document somewhere which published how a
-> function could return multiple tuples, remote views would be a trivial
-> undertaking. It could look like:
-> 
-> select * from remote('select *from table', 'user=postgres host=outland
-> db=remote');
-> 
-
-See contrib/dblink in the 7.2 beta. It was my attempt inspired by 
-Oracle's dblink and some code that you (mlw) posted a while back. Based 
-on the limitations wrt returning muliple tuples, I wound up with 
-something like:
-
-lt_lcat=# select dblink_tok(t1.dblink_p,0) as f1 from (select 
-dblink('hostaddr=127.0.0.1 dbname=template1 user=postgres 
-password=postgres','select proname from pg_proc') as dblink_p) as t1;
-
-Which, as has been pointed out more than once, is pretty ugly, but at 
-least it's a start ;-)
-
-
-Joe
-
-
----------------------------(end of broadcast)---------------------------
-TIP 4: Don't 'kill -9' the postmaster
-
-From pgsql-hackers-owner+M16336=candle.pha.pa.us=pgman@postgresql.org Thu Dec  6 18:41:31 2001
-Return-path: <pgsql-hackers-owner+M16336=candle.pha.pa.us=pgman@postgresql.org>
-Received: from west.navpoint.com (west.navpoint.com [207.106.42.13])
-       by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id fB6NfPZ12249
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 18:41:25 -0500 (EST)
-Received: from rs.postgresql.org (server1.pgsql.org [64.39.15.238] (may be forged))
-       by west.navpoint.com (8.11.6/8.10.1) with ESMTP id fB6NfQq03244
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 18:41:26 -0500 (EST)
-Received: from postgresql.org (postgresql.org [64.49.215.8])
-       by rs.postgresql.org (8.11.6/8.11.6) with ESMTP id fB6NbOR70960
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 17:38:19 -0600 (CST)
-       (envelope-from pgsql-hackers-owner+M16336=candle.pha.pa.us=pgman@postgresql.org)
-Received: from spider.pilosoft.com (p55-222.acedsl.com [160.79.55.222])
-       by postgresql.org (8.11.3/8.11.4) with ESMTP id fB6NIgm07232
-       for <pgsql-hackers@postgresql.org>; Thu, 6 Dec 2001 18:18:43 -0500 (EST)
-       (envelope-from alex@pilosoft.com)
-Received: from localhost (alexmail@localhost)
-       by spider.pilosoft.com (8.9.3/8.9.3) with ESMTP id SAA23999;
-       Thu, 6 Dec 2001 18:23:22 -0500 (EST)
-Date: Thu, 6 Dec 2001 18:23:22 -0500 (EST)
-From: Alex Pilosov <alex@pilosoft.com>
-To: mlw <markw@mohawksoft.com>
-cc: "pgsql-hackers@postgresql.org" <pgsql-hackers@postgresql.org>
-Subject: Re: [HACKERS] Remote connections?
-In-Reply-To: <3C0FD339.6F663329@mohawksoft.com>
-Message-ID: <Pine.BSO.4.10.10112061822080.22618-100000@spider.pilosoft.com>
-MIME-Version: 1.0
-Content-Type: TEXT/PLAIN; charset=US-ASCII
-Precedence: bulk
-Sender: pgsql-hackers-owner@postgresql.org
-Status: OR
-
-On Thu, 6 Dec 2001, mlw wrote:
-
-> I too find the internals of PostgreSQL virtually incomprehensible at the
-> internal level. If there were a document somewhere which published how a
-> function could return multiple tuples, remote views would be a trivial
-> undertaking. It could look like:
-> 
-> select * from remote('select *from table', 'user=postgres host=outland
-> db=remote');
-This isn't possible yet. I was working on implementation of this, about
-80% done, but never finished. Now I'm out of time to work more on this for
-a while. :(
-
-Let me know if you want my code.
-
--alex
-
-
----------------------------(end of broadcast)---------------------------
-TIP 6: Have you searched our list archives?
-
-http://archives.postgresql.org
-
-From pgsql-hackers-owner+M16340=candle.pha.pa.us=pgman@postgresql.org Fri Dec  7 00:32:59 2001
-Return-path: <pgsql-hackers-owner+M16340=candle.pha.pa.us=pgman@postgresql.org>
-Received: from west.navpoint.com (west.navpoint.com [207.106.42.13])
-       by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id fB75WsZ06911
-       for <pgman@candle.pha.pa.us>; Fri, 7 Dec 2001 00:32:54 -0500 (EST)
-Received: from rs.postgresql.org (server1.pgsql.org [64.39.15.238] (may be forged))
-       by west.navpoint.com (8.11.6/8.10.1) with ESMTP id fB75Wtq16801
-       for <pgman@candle.pha.pa.us>; Fri, 7 Dec 2001 00:32:55 -0500 (EST)
-Received: from postgresql.org (postgresql.org [64.49.215.8])
-       by rs.postgresql.org (8.11.6/8.11.6) with ESMTP id fB75SCR80525
-       for <pgman@candle.pha.pa.us>; Thu, 6 Dec 2001 23:29:17 -0600 (CST)
-       (envelope-from pgsql-hackers-owner+M16340=candle.pha.pa.us=pgman@postgresql.org)
-Received: from snoopy.mohawksoft.com (h0050bf7a618d.ne.mediaone.net [24.218.67.153])
-       by postgresql.org (8.11.3/8.11.4) with ESMTP id fB7593m27913
-       for <pgsql-hackers@postgresql.org>; Fri, 7 Dec 2001 00:09:03 -0500 (EST)
-       (envelope-from markw@mohawksoft.com)
-Received: from mohawksoft.com (localhost [127.0.0.1])
-       by snoopy.mohawksoft.com (8.11.6/8.11.6) with ESMTP id fB7561030613;
-       Fri, 7 Dec 2001 00:06:01 -0500
-Message-ID: <3C104E38.DA19C867@mohawksoft.com>
-Date: Fri, 07 Dec 2001 00:06:01 -0500
-From: mlw <markw@mohawksoft.com>
-X-Mailer: Mozilla 4.78 [en] (X11; U; Linux 2.4.14ext3 i686)
-X-Accept-Language: en
-MIME-Version: 1.0
-To: Joe Conway <joseph.conway@home.com>
-cc: "Ross J. Reedstrom" <reedstrm@rice.edu>,
-   "pgsql-hackers@postgresql.org" <pgsql-hackers@postgresql.org>
-Subject: Re: [HACKERS] Remote connections?
-References: <3C0FB8B4.382C7736@mohawksoft.com> <20011206140616.C10995@rice.edu> <3C0FD339.6F663329@mohawksoft.com> <3C0FEB2C.70000@home.com>
-Content-Type: text/plain; charset=us-ascii
-Content-Transfer-Encoding: 7bit
-Precedence: bulk
-Sender: pgsql-hackers-owner@postgresql.org
-Status: OR
-
-Hey this looks really cool. It looks like something I was thinking about doing.
-I have a couple suggestions that could make it a little better, I hope you will
-not be offended. (If you want my help, I'll chip in!)
-
-Why not use a binary cursor? That way native types can slip through without the
-overhead of conversion.
-
-Right now you get all rows up front, you may be able to increase overall
-performance by fetching only a few rows at a time, rather than get everything
-all at once. (Think on the order of 4 million rows from your remote query!)
-Execute the commit at the end of processing. There are even some asynchronous
-functions you may be able to utilize to reduce the I/O bottleneck. Use the
-synchronous function first, then before you return initiate an asynchronous
-read. Every successive pass through the function, read the newly arrived tuple,
-and initiate the next asynchronous read. (The two machine could be processing
-the query simultaneously, and this could even IMPROVE performance over a single
-system for heavy duty queries.)
-
-Setup a hash table for field names, rather than requiring field numbers. (Keep
-field number for efficiency, of course.)
-
-You could eliminate having to pass the result pointer around by keeping a
-static array in your extension. Use something like Oracle's "contains" notation
-of result number. Where each instantiation of "contains()" and "score()"
-require an id. i.e. 1,2,3,40 etc. Then hash those numbers into an array. I have
-some code that does this for a PostgreSQL extension (it implements contains) on
-my website (pgcontains, under download). It is ugly but works for the most
-part.
-
-Seriously, your stuff looks great. I think it could be the beginning of a
-fairly usable system for my company. Any help you need/want, just let me know.
-
-
-Joe Conway wrote:
-> 
-> mlw wrote:
-> 
-> > I too find the internals of PostgreSQL virtually incomprehensible at the
-> > internal level. If there were a document somewhere which published how a
-> > function could return multiple tuples, remote views would be a trivial
-> > undertaking. It could look like:
-> >
-> > select * from remote('select *from table', 'user=postgres host=outland
-> > db=remote');
-> >
-> 
-> See contrib/dblink in the 7.2 beta. It was my attempt inspired by
-> Oracle's dblink and some code that you (mlw) posted a while back. Based
-> on the limitations wrt returning muliple tuples, I wound up with
-> something like:
-> 
-> lt_lcat=# select dblink_tok(t1.dblink_p,0) as f1 from (select
-> dblink('hostaddr=127.0.0.1 dbname=template1 user=postgres
-> password=postgres','select proname from pg_proc') as dblink_p) as t1;
-> 
-> Which, as has been pointed out more than once, is pretty ugly, but at
-> least it's a start ;-)
-> 
-> Joe
-> 
-> ---------------------------(end of broadcast)---------------------------
-> TIP 4: Don't 'kill -9' the postmaster
-
----------------------------(end of broadcast)---------------------------
-TIP 3: if posting/reading through Usenet, please send an appropriate
-subscribe-nomail command to majordomo@postgresql.org so that your
-message can get through to the mailing list cleanly
-
-From pgsql-hackers-owner+M16344=candle.pha.pa.us=pgman@postgresql.org Fri Dec  7 02:51:51 2001
-Return-path: <pgsql-hackers-owner+M16344=candle.pha.pa.us=pgman@postgresql.org>
-Received: from west.navpoint.com (west.navpoint.com [207.106.42.13])
-       by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id fB77poZ14221
-       for <pgman@candle.pha.pa.us>; Fri, 7 Dec 2001 02:51:50 -0500 (EST)
-Received: from rs.postgresql.org (server1.pgsql.org [64.39.15.238] (may be forged))
-       by west.navpoint.com (8.11.6/8.10.1) with ESMTP id fB77pqq08152
-       for <pgman@candle.pha.pa.us>; Fri, 7 Dec 2001 02:51:52 -0500 (EST)
-Received: from postgresql.org (postgresql.org [64.49.215.8])
-       by rs.postgresql.org (8.11.6/8.11.6) with ESMTP id fB77lwR84105
-       for <pgman@candle.pha.pa.us>; Fri, 7 Dec 2001 01:49:04 -0600 (CST)
-       (envelope-from pgsql-hackers-owner+M16344=candle.pha.pa.us=pgman@postgresql.org)
-Received: from ra.sai.msu.su (ra.sai.msu.su [158.250.29.2])
-       by postgresql.org (8.11.3/8.11.4) with ESMTP id fB77bmm32783
-       for <pgsql-hackers@postgresql.org>; Fri, 7 Dec 2001 02:37:49 -0500 (EST)
-       (envelope-from oleg@sai.msu.su)
-Received: from ra (ra [158.250.29.2])
-       by ra.sai.msu.su (8.9.3/8.9.3) with ESMTP id KAA04160;
-       Fri, 7 Dec 2001 10:37:04 +0300 (GMT)
-Date: Fri, 7 Dec 2001 10:37:04 +0300 (GMT)
-From: Oleg Bartunov <oleg@sai.msu.su>
-X-X-Sender: <megera@ra.sai.msu.su>
-To: mlw <markw@mohawksoft.com>
-cc: Joe Conway <joseph.conway@home.com>,
-   "Ross J. Reedstrom" <reedstrm@rice.edu>,
-   "pgsql-hackers@postgresql.org" <pgsql-hackers@postgresql.org>
-Subject: Re: [HACKERS] Remote connections?
-In-Reply-To: <3C104E38.DA19C867@mohawksoft.com>
-Message-ID: <Pine.GSO.4.33.0112071035180.20511-100000@ra.sai.msu.su>
-MIME-Version: 1.0
-Content-Type: TEXT/PLAIN; charset=US-ASCII
-Precedence: bulk
-Sender: pgsql-hackers-owner@postgresql.org
-Status: OR
-
-On Fri, 7 Dec 2001, mlw wrote:
-
->
-> You could eliminate having to pass the result pointer around by keeping a
-> static array in your extension. Use something like Oracle's "contains" notation
-> of result number. Where each instantiation of "contains()" and "score()"
-> require an id. i.e. 1,2,3,40 etc. Then hash those numbers into an array. I have
-> some code that does this for a PostgreSQL extension (it implements contains) on
-> my website (pgcontains, under download). It is ugly but works for the most
-> part.
-
-contrib/intarray does this job very well
-
->
-> Seriously, your stuff looks great. I think it could be the beginning of a
-> fairly usable system for my company. Any help you need/want, just let me know.
->
->
-> Joe Conway wrote:
-> >
-> > mlw wrote:
-> >
-> > > I too find the internals of PostgreSQL virtually incomprehensible at the
-> > > internal level. If there were a document somewhere which published how a
-> > > function could return multiple tuples, remote views would be a trivial
-> > > undertaking. It could look like:
-> > >
-> > > select * from remote('select *from table', 'user=postgres host=outland
-> > > db=remote');
-> > >
-> >
-> > See contrib/dblink in the 7.2 beta. It was my attempt inspired by
-> > Oracle's dblink and some code that you (mlw) posted a while back. Based
-> > on the limitations wrt returning muliple tuples, I wound up with
-> > something like:
-> >
-> > lt_lcat=# select dblink_tok(t1.dblink_p,0) as f1 from (select
-> > dblink('hostaddr=127.0.0.1 dbname=template1 user=postgres
-> > password=postgres','select proname from pg_proc') as dblink_p) as t1;
-> >
-> > Which, as has been pointed out more than once, is pretty ugly, but at
-> > least it's a start ;-)
-> >
-> > Joe
-> >
-> > ---------------------------(end of broadcast)---------------------------
-> > TIP 4: Don't 'kill -9' the postmaster
->
-> ---------------------------(end of broadcast)---------------------------
-> TIP 3: if posting/reading through Usenet, please send an appropriate
-> subscribe-nomail command to majordomo@postgresql.org so that your
-> message can get through to the mailing list cleanly
->
-
-       Regards,
-               Oleg
-_____________________________________________________________
-Oleg Bartunov, sci.researcher, hostmaster of AstroNet,
-Sternberg Astronomical Institute, Moscow University (Russia)
-Internet: oleg@sai.msu.su, http://www.sai.msu.su/~megera/
-phone: +007(095)939-16-83, +007(095)939-23-83
-
-
----------------------------(end of broadcast)---------------------------
-TIP 3: if posting/reading through Usenet, please send an appropriate
-subscribe-nomail command to majordomo@postgresql.org so that your
-message can get through to the mailing list cleanly
-
-From pgsql-hackers-owner+M16412=candle.pha.pa.us=pgman@postgresql.org Mon Dec 10 12:35:01 2001
-Return-path: <pgsql-hackers-owner+M16412=candle.pha.pa.us=pgman@postgresql.org>
-Received: from west.navpoint.com (west.navpoint.com [207.106.42.13])
-       by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id fBAHZ0Z09772
-       for <pgman@candle.pha.pa.us>; Mon, 10 Dec 2001 12:35:00 -0500 (EST)
-Received: from rs.postgresql.org (server1.pgsql.org [64.39.15.238] (may be forged))
-       by west.navpoint.com (8.11.6/8.10.1) with ESMTP id fBAHZ0a11739
-       for <pgman@candle.pha.pa.us>; Mon, 10 Dec 2001 12:35:00 -0500 (EST)
-Received: from postgresql.org (postgresql.org [64.49.215.8])
-       by rs.postgresql.org (8.11.6/8.11.6) with ESMTP id fBAHRAR20284
-       for <pgman@candle.pha.pa.us>; Mon, 10 Dec 2001 11:32:00 -0600 (CST)
-       (envelope-from pgsql-hackers-owner+M16412=candle.pha.pa.us=pgman@postgresql.org)
-Received: from snoopy.mohawksoft.com (h0050bf7a618d.ne.mediaone.net [24.218.67.153])
-       by postgresql.org (8.11.3/8.11.4) with ESMTP id fB7DhOm75114
-       for <pgsql-hackers@postgresql.org>; Fri, 7 Dec 2001 08:43:24 -0500 (EST)
-       (envelope-from markw@mohawksoft.com)
-Received: from mohawksoft.com (localhost [127.0.0.1])
-       by snoopy.mohawksoft.com (8.11.6/8.11.6) with ESMTP id fB7De0000437;
-       Fri, 7 Dec 2001 08:40:01 -0500
-Message-ID: <3C10C6B0.865669C1@mohawksoft.com>
-Date: Fri, 07 Dec 2001 08:40:00 -0500
-From: mlw <markw@mohawksoft.com>
-X-Mailer: Mozilla 4.78 [en] (X11; U; Linux 2.4.14ext3 i686)
-X-Accept-Language: en
-MIME-Version: 1.0
-To: Oleg Bartunov <oleg@sai.msu.su>
-cc: Joe Conway <joseph.conway@home.com>,
-   "Ross J. Reedstrom" <reedstrm@rice.edu>,
-   "pgsql-hackers@postgresql.org" <pgsql-hackers@postgresql.org>
-Subject: Re: [HACKERS] Remote connections?
-References: <Pine.GSO.4.33.0112071035180.20511-100000@ra.sai.msu.su>
-Content-Type: text/plain; charset=us-ascii
-Content-Transfer-Encoding: 7bit
-Precedence: bulk
-Sender: pgsql-hackers-owner@postgresql.org
-Status: OR
-
-The dblink code is a very cool idea.
-
-It got me thinking, what if, just thinking out load here, it was redesigned as
-something a little more grandeous.
-
-Imagine this:
-
-
-select dblink('select * from table', 'table_name', 'db=oracle.test user=chris
-passwd=knight', 1) as t1, dblink('table2_name', 1) as t2
-
-
-Just something to think about. 
-
-The first instance of dblink would take 4 parameters: query, table which it
-returns, connect string, and link token.
-
-The second instance of dblink would just take the name of the table which it
-returns and a link token.
-
-The cool bit is the notion that the query string could specify different
-databases or even .DBF libraries. 
-
-Just something to think about.
-
-It would REALLY be great if functions could return multiple tuples!
-
----------------------------(end of broadcast)---------------------------
-TIP 5: Have you checked our extensive FAQ?
-
-http://www.postgresql.org/users-lounge/docs/faq.html
-
-From pgsql-hackers-owner+M16365=candle.pha.pa.us=pgman@postgresql.org Fri Dec  7 12:32:26 2001
-Return-path: <pgsql-hackers-owner+M16365=candle.pha.pa.us=pgman@postgresql.org>
-Received: from west.navpoint.com (west.navpoint.com [207.106.42.13])
-       by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id fB7HWMZ26245
-       for <pgman@candle.pha.pa.us>; Fri, 7 Dec 2001 12:32:22 -0500 (EST)
-Received: from rs.postgresql.org (server1.pgsql.org [64.39.15.238] (may be forged))
-       by west.navpoint.com (8.11.6/8.10.1) with ESMTP id fB7HWLB14472
-       for <pgman@candle.pha.pa.us>; Fri, 7 Dec 2001 12:32:21 -0500 (EST)
-Received: from postgresql.org (postgresql.org [64.49.215.8])
-       by rs.postgresql.org (8.11.6/8.11.6) with ESMTP id fB7HSHR01506
-       for <pgman@candle.pha.pa.us>; Fri, 7 Dec 2001 11:29:07 -0600 (CST)
-       (envelope-from pgsql-hackers-owner+M16365=candle.pha.pa.us=pgman@postgresql.org)
-Received: from mx1.relaypoint.net (ns2.generalbroadband.com [64.32.62.5])
-       by postgresql.org (8.11.3/8.11.4) with ESMTP id fB7HQfm90424
-       for <pgsql-hackers@postgresql.org>; Fri, 7 Dec 2001 12:26:42 -0500 (EST)
-       (envelope-from joseph.conway@home.com)
-Received: from [206.19.64.3] (account jconway@wwc.com HELO home.com)
-  by mx1.relaypoint.net (CommuniGate Pro SMTP 3.4.8)
-  with ESMTP id 1722339; Fri, 07 Dec 2001 09:26:46 -0800
-Message-ID: <3C10FBD7.4070602@home.com>
-Date: Fri, 07 Dec 2001 09:26:47 -0800
-From: Joe Conway <joseph.conway@home.com>
-User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.0; en-US; rv:0.9.6+) Gecko/20011126
-X-Accept-Language: en-us
-MIME-Version: 1.0
-To: mlw <markw@mohawksoft.com>
-cc: "Ross J. Reedstrom" <reedstrm@rice.edu>,
-   "pgsql-hackers@postgresql.org" <pgsql-hackers@postgresql.org>
-Subject: Re: [HACKERS] Remote connections?
-References: <3C0FB8B4.382C7736@mohawksoft.com> <20011206140616.C10995@rice.edu> <3C0FD339.6F663329@mohawksoft.com> <3C0FEB2C.70000@home.com> <3C104E38.DA19C867@mohawksoft.com>
-Content-Type: text/plain; charset=us-ascii; format=flowed
-Content-Transfer-Encoding: 7bit
-Precedence: bulk
-Sender: pgsql-hackers-owner@postgresql.org
-Status: OR
-
-mlw wrote:
-
-> Hey this looks really cool. It looks like something I was thinking about doing.
-> I have a couple suggestions that could make it a little better, I hope you will
-> not be offended. (If you want my help, I'll chip in!)
-> 
-
-
-Thanks! Suggestions welcomed.
-
-> Why not use a binary cursor? That way native types can slip through without the
-> overhead of conversion.
->
-
-
-I wasn't sure that would work. Would you create dblink_tok as returning 
-opaque then?
-
-> Right now you get all rows up front, you may be able to increase overall
-> performance by fetching only a few rows at a time, rather than get everything
-> all at once. (Think on the order of 4 million rows from your remote query!)
-> Execute the commit at the end of processing. There are even some asynchronous
-> functions you may be able to utilize to reduce the I/O bottleneck. Use the
-> synchronous function first, then before you return initiate an asynchronous
-> read. Every successive pass through the function, read the newly arrived tuple,
-> and initiate the next asynchronous read. (The two machine could be processing
-> the query simultaneously, and this could even IMPROVE performance over a single
-> system for heavy duty queries.)
-
-
-Interesting . . . but aren't there some issues with the asynch functions?
-
-> 
-> Setup a hash table for field names, rather than requiring field numbers. (Keep
-> field number for efficiency, of course.)
-> 
-> You could eliminate having to pass the result pointer around by keeping a
-> static array in your extension. Use something like Oracle's "contains" notation
-> of result number. Where each instantiation of "contains()" and "score()"
-> require an id. i.e. 1,2,3,40 etc. Then hash those numbers into an array. I have
-> some code that does this for a PostgreSQL extension (it implements contains) on
-> my website (pgcontains, under download). It is ugly but works for the most
-> part.
-> 
-
-
-I thought about the static array, but I'm not familiar with Oracle 
-contains() and score() -- I'm only fluent enough with Oracle to be 
-dangerous. Guess I'll have to dig out the books . . .
-
-
-> Seriously, your stuff looks great. I think it could be the beginning of a
-> fairly usable system for my company. Any help you need/want, just let me know.
-> 
-
-I am planning to improve dblink during the next release cycle, so I'll 
-keep all this in mind (and might take you up on the help offer too!). I 
-was hoping we'd have functions returning tuples by now, which would 
-improve this extension dramatically. Unfortunately, it sounds like Alex 
-won't have time to finish that even for 7.3 :(
-
-Alex, can we get a look at your latest code? Is it any different the 
-your last submission to PATCHES?
-
-Joe
-
-
----------------------------(end of broadcast)---------------------------
-TIP 3: if posting/reading through Usenet, please send an appropriate
-subscribe-nomail command to majordomo@postgresql.org so that your
-message can get through to the mailing list cleanly
-