AnyEvent-Pg-Pool-Multiserver
view release on metacpan or search on metacpan
lib/AnyEvent/Pg/Pool/Multiserver.pm view on Meta::CPAN
# And MUST call cb
$params->{cb}->();
},
);
# single-server request to select row in arrayref
$pool->selectrow_array(
query => 'SELECT val FROM ( SELECT 1 AS val ) tmp WHERE tmp.val = $1;',
args => [ 1 ],
server_id => 1,
cb => sub {
my $result = shift;
my $error = shift;
if ( $error ) {
say "err $error->{error} with $error->{server_name} $error->{server_id}";
}
if ( $result ) {
say "server_id=$result->[ 0 ] value=$result->[ 1 ]";
}
},
);
# single-server request to select row in hashref
$pool->selectrow_hashref(
query => 'SELECT val FROM ( SELECT 1 AS val ) tmp WHERE tmp.val = $1;',
args => [ 1 ],
server_id => 1,
cb => sub {
my $result = shift;
my $error = shift;
if ( $error ) {
say "err $error->{error} with $error->{server_name} $error->{server_id}";
}
if ( $result ) {
say "server_id=$result->{_server_id} value=$result->{val}";
}
},
);
# single-server request to do something
$pool->do(
query => 'UPDATE table SET column = 1 WHERE id = $1;',
args => [ 1 ],
server_id => 1,
cb => sub {
my $result = shift;
my $error = shift;
if ( $error ) {
say "err $error->{error} with $error->{server_name} $error->{server_id}";
}
if ( $result ) {
say "server_id=$result->[ 0 ] updated=$result->[ 1 ]";
}
},
);
# local-server request to do something
$pool->do(
query => 'UPDATE table SET column = 1 WHERE id = $1;',
args => [ 1 ],
server_id => $pool->local(),
cb => sub { ... },
);
=head1 DESCRIPTION
=head2 selectall_arrayref
query and args are the same, that in AnyEvent::Pg
Required: query, cb
Optional: args, cb_server, server_id
=head2 selectrow_array
query and args are the same, that in AnyEvent::Pg
Required: query, server_id, cb
Optional: args, cb_server
=head2 selectrow_hashref
query and args are the same, that in AnyEvent::Pg
Required: query, server_id, cb
Optional: args, cb_server
=head2 do
query and args are the same, that in AnyEvent::Pg
Required: query, server_id, cb
Optional: args, cb_server
=head1 SOURCE AVAILABILITY
The source code for this module is available
at L<Github|https://github.com/kak-tus/AnyEvent-Pg-Pool-Multiserver>
=head1 AUTHOR
Andrey Kuzmin, E<lt>kak-tus@mail.ruE<gt>
=head1 COPYRIGHT AND LICENSE
Copyright (C) 2014 by Andrey Kuzmin
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
=cut
( run in 0.840 second using v1.01-cache-2.11-cpan-39bf76dae61 )