Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Yielding rows lazily #4

Open
bts opened this issue Feb 24, 2015 · 8 comments
Open

Yielding rows lazily #4

bts opened this issue Feb 24, 2015 · 8 comments

Comments

@bts
Copy link

bts commented Feb 24, 2015

Hi Antti,

Thanks for this library. I was wondering if there are any plans to yield rows lazily? I see in PgResultSet that iterator() is currently backed by an eager List<Row>.

Thanks!
Brian

@bts
Copy link
Author

bts commented Feb 24, 2015

Could we pass stream at

applyConsumer(onQuery, reduce(new QueryResponseReader(), messages.stream()).get(), onError);
into a new ResultSet impl that takes a Stream<Message> instead of List<Row>? In that ResultSet, size() and updatedRows() would either have to block on completion of the streaming, or return some sort of future instead.

@alaisi
Copy link
Owner

alaisi commented Feb 25, 2015

Hi,

interesting idea.

The library has no blocking methods, but a callback-based API (or future or promise) could be added. NettyPgProtocolStream currently passes the backend messages to PgConnection only after ReadyForQuery message is received, but there is no limitation why the rows could not be processed as soon as each individual row is available. The API could probably look something like Rx Observable with onNext/onComplete/onError (I'm planning on creating an Observable wrapper for the library as a separate project).

Note that the implementation would not truly be lazy as the postgres backend always sends the entire result set (and cancelling is expensive as it opens a new physical connection), but the library could provide a Stream- or Observable-like API for consuming individual rows as early as possible.

I'll take a look. Pull requests are also welcome. :)

@bts
Copy link
Author

bts commented Feb 25, 2015

Cool.

I'm a little tied-up with other work at the moment (and I don't write much Java) so I was thinking about tackling the smaller task of adding a manifold interface (as an alternative to the core.async interface) to postgres.async first, if you'd be interested in having that in the library? The two interfaces could live side-by-side. Here's manifold's rationale. If you haven't played with it yet, the new version of aleph has switched to a manifold interface and it's really nice to use.

@alaisi
Copy link
Owner

alaisi commented Mar 3, 2015

Manifold looks interesting. That interface could be included in postgres.async in a separate namespace and with provided scope manifold leiningen dependency.

@hadronzoo
Copy link

👍 for a manifold interface

@sdeleuze
Copy link

sdeleuze commented Dec 1, 2015

Hi, I am one of the developer of the Reactive support of Spring Framework. As part of the spring-reactive project, I am working on a spring-reactive-playground experiment which is about integrating MongoDB, Couchebase and PostgreSQL async drivers in order to have an example of a Reactive application end to end (web to database).

Thanks a lot for your work on postgres-async-driver. I think being able to multiple rows in a non-blocking way with a stream would be really useful. I don't think we need manifold for that, exposing Rxjava Observable<Row> or Reactive Streams Publisher<Row> is perfect for this use case.

mongo-java-driver-reactivestreams, mongo-java-driver-rx or Couchbase AsyncN1qlQueryResult are good example of such API/implementation.

Any thoughts?

@alaisi
Copy link
Owner

alaisi commented Dec 2, 2015

Hi,
release 0.7 (just now syncing to maven central) returns query results as Rx Observables and can emit individual rows to the subscriber before the entire result set is received.

See queryRows: https://github.com/alaisi/postgres-async-driver/blob/master/src/main/java/com/github/pgasync/QueryExecutor.java

@sdeleuze: This probably fits your use case perfectly?

@sdeleuze
Copy link

sdeleuze commented Dec 2, 2015

@alaisi Awesome, perfect match cf. sdeleuze/spring-reactive-playground@b90efcb

Thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants