line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package Class::DBI::Plugin::QueriesTime; |
2
|
|
|
|
|
|
|
|
3
|
1
|
|
|
1
|
|
22240
|
use strict; |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
49
|
|
4
|
1
|
|
|
1
|
|
5
|
use warnings; |
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
36
|
|
5
|
1
|
|
|
1
|
|
2792
|
use Time::HiRes qw( tv_interval gettimeofday ); |
|
1
|
|
|
|
|
1896
|
|
|
1
|
|
|
|
|
4
|
|
6
|
1
|
|
|
1
|
|
178
|
use vars qw($VERSION); |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
77
|
|
7
|
|
|
|
|
|
|
$VERSION = '0.01'; |
8
|
|
|
|
|
|
|
|
9
|
|
|
|
|
|
|
sub import { |
10
|
1
|
|
|
1
|
|
11
|
my $class = shift; |
11
|
1
|
|
|
|
|
2
|
my $pkg = caller(0); |
12
|
1
|
|
|
|
|
2
|
my $befor_query; |
13
|
|
|
|
|
|
|
|
14
|
1
|
|
|
1
|
|
4
|
no strict 'refs'; |
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
25
|
|
15
|
1
|
|
|
1
|
|
6
|
no warnings 'redefine'; |
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
325
|
|
16
|
1
|
|
|
|
|
14
|
*{"$pkg\::sth_to_objects"} = sub { |
17
|
0
|
|
|
0
|
|
|
my ($class, $sth, $args) = @_; |
18
|
0
|
0
|
|
|
|
|
$class->_croak("sth_to_objects needs a statement handle") unless $sth; |
19
|
0
|
0
|
|
|
|
|
unless (UNIVERSAL::isa($sth => "DBI::st")) { |
20
|
0
|
|
|
|
|
|
my $meth = "sql_$sth"; |
21
|
0
|
|
|
|
|
|
$sth = $class->$meth(); |
22
|
|
|
|
|
|
|
} |
23
|
0
|
|
|
|
|
|
my (%data, @rows); |
24
|
0
|
|
|
|
|
|
eval { |
25
|
0
|
|
|
|
|
|
$befor_query = [gettimeofday]; |
26
|
0
|
0
|
|
|
|
|
$sth->execute(@$args) unless $sth->{Active}; |
27
|
0
|
|
|
|
|
|
$sth->bind_columns(\(@data{ @{ $sth->{NAME_lc} } })); |
|
0
|
|
|
|
|
|
|
28
|
0
|
|
|
|
|
|
warn "Query Time: ",tv_interval ( $befor_query ); |
29
|
0
|
|
|
|
|
|
push @rows, {%data} while $sth->fetch; |
30
|
|
|
|
|
|
|
}; |
31
|
0
|
0
|
|
|
|
|
return $class->_croak("$class can't $sth->{Statement}: $@", err => $@) |
32
|
|
|
|
|
|
|
if $@; |
33
|
0
|
|
|
|
|
|
return $class->_ids_to_objects(\@rows); |
34
|
1
|
|
|
|
|
3
|
}; |
35
|
|
|
|
|
|
|
} |
36
|
|
|
|
|
|
|
1; |
37
|
|
|
|
|
|
|
|
38
|
|
|
|
|
|
|
=head1 NAME |
39
|
|
|
|
|
|
|
|
40
|
|
|
|
|
|
|
Class::DBI::Plugin::QueriesTime - Get your query's time. |
41
|
|
|
|
|
|
|
|
42
|
|
|
|
|
|
|
=head1 VERSION |
43
|
|
|
|
|
|
|
|
44
|
|
|
|
|
|
|
This documentation refers to Class::DBI::Plugin::QueriesTime version 0.01 |
45
|
|
|
|
|
|
|
|
46
|
|
|
|
|
|
|
=head1 SYNOPSIS |
47
|
|
|
|
|
|
|
|
48
|
|
|
|
|
|
|
package YourDB; |
49
|
|
|
|
|
|
|
use base qw/Class::DBI/; |
50
|
|
|
|
|
|
|
use Class::DBI::Plugin::QueriesTime; |
51
|
|
|
|
|
|
|
|
52
|
|
|
|
|
|
|
=head1 DESCRIPTION |
53
|
|
|
|
|
|
|
|
54
|
|
|
|
|
|
|
Class::DBI::Plugin::QueriesTime is Extension to Class::DBI. |
55
|
|
|
|
|
|
|
Class::DBI::Plugin::QueriesTime get your query's time. |
56
|
|
|
|
|
|
|
Class::DBI::Plugin::QueriesTime is redefine Class::DBI::sth_to_objects. |
57
|
|
|
|
|
|
|
|
58
|
|
|
|
|
|
|
=head1 DEPENDENCIES |
59
|
|
|
|
|
|
|
|
60
|
|
|
|
|
|
|
L |
61
|
|
|
|
|
|
|
|
62
|
|
|
|
|
|
|
L |
63
|
|
|
|
|
|
|
|
64
|
|
|
|
|
|
|
=head1 BUGS AND LIMITATIONS |
65
|
|
|
|
|
|
|
|
66
|
|
|
|
|
|
|
There are no known bugs in this module. |
67
|
|
|
|
|
|
|
Please report problems to Atsushi Kobayashi (Enekokak@cpan.orgE) |
68
|
|
|
|
|
|
|
Patches are welcome. |
69
|
|
|
|
|
|
|
|
70
|
|
|
|
|
|
|
=head1 SEE ALSO |
71
|
|
|
|
|
|
|
|
72
|
|
|
|
|
|
|
L |
73
|
|
|
|
|
|
|
|
74
|
|
|
|
|
|
|
L |
75
|
|
|
|
|
|
|
|
76
|
|
|
|
|
|
|
=head1 AUTHOR |
77
|
|
|
|
|
|
|
|
78
|
|
|
|
|
|
|
Atsushi Kobayashi, Enekokak@cpan.orgE |
79
|
|
|
|
|
|
|
|
80
|
|
|
|
|
|
|
=head1 COPYRIGHT AND LICENSE |
81
|
|
|
|
|
|
|
|
82
|
|
|
|
|
|
|
Copyright (C) 2006 by Atsushi Kobayashi (Enekokak@cpan.orgE). All rights reserved. |
83
|
|
|
|
|
|
|
|
84
|
|
|
|
|
|
|
This library is free software; you can redistribute it and/or modify it |
85
|
|
|
|
|
|
|
under the same terms as Perl itself. See L. |
86
|
|
|
|
|
|
|
|
87
|
|
|
|
|
|
|
=cut |