use ->do instead of ->prepare_cached in oracle's connected() too
[dbsrgits/DBIx-Class.git] / lib / DBIx / Class / Storage / DBI / Sybase / Base.pm
CommitLineData
eabab5d0 1package DBIx::Class::Storage::DBI::Sybase::Base;
2
3use strict;
4use warnings;
5
6=head1 NAME
7
8DBIx::Class::Storage::DBI::Sybase::Base - Common functionality for drivers using
2932b9a6 9DBD::Sybase
eabab5d0 10
11=head1 METHODS
12
13=head2 connected
14
15Returns true if we have an open (and working) database connection, false if it
16is not (yet) open (or does not work). (Executes a simple SELECT to make sure it
17works.)
18
19The reason this is needed is that L<DBD::Sybase>'s ping() does not work with an
20active statement handle, leading to masked database errors.
21
22=cut
23
24sub connected {
25 my $self = shift;
26
526dc858 27 my $dbh = $self->_dbh;
28 local $dbh->{RaiseError} = 1;
eabab5d0 29 eval {
283fb613 30 $dbh->do('select 1');
eabab5d0 31 };
32
33 return $@ ? 0 : 1;
34}
35
361;
37
38=head1 AUTHORS
39
40See L<DBIx::Class/CONTRIBUTORS>.
41
42=head1 LICENSE
43
44You may distribute this code under the same terms as Perl itself.
45
46=cut