[![Build Status](https://travis-ci.com/xaicron/p5-DBIx-QueryLog.svg?branch=master)](https://travis-ci.com/xaicron/p5-DBIx-QueryLog)
# NAME
DBIx::QueryLog - Logging queries for DBI
# SYNOPSIS
use DBIx::QueryLog;
my $row = $dbh->selectrow_hashref('SELECT * FROM people WHERE user_id = ?', undef, qw/1986/);
# => SELECT * FROM people WHERE user_id = '1986';
# DESCRIPTION
DBIx::QueryLog logs each execution time and the actual query.
Currently, it works with DBD::mysql, DBD::Pg and DBD::SQLite.
# CLASS METHODS
- threshold
If set, only queries that take more time than this threshold will be logged (default is undef)
DBIx::QueryLog->threshold(0.1); # sec
You can also specify this with `DBIX_QUERYLOG_THRESHOLD` environment variable.
- probability
If set, the logger logs only once per a defined value. (default is undef)
DBIx::QueryLog->probability(100); # about 1/100
You can also specify this with `DBIX_QUERYLOG_PROBABILITY` environment variable.
- logger
Sets a logger class (e.g. [Log::Dispach](https://metacpan.org/pod/Log::Dispach))
The logger class must have a \`log\` method, which should work like the one of [Log::Dispatch](https://metacpan.org/pod/Log::Dispatch) (but see also OUTPUT section below).
DBIx::QueryLog->logger($logger);
- skip\_bind
If set, DBIx::QueryLog runs faster, but placeholders are not processed.
DBIx::QueryLog->skip_bind(1);
my $row = $dbh->do(...);
# => 'SELECT * FROM people WHERE user_id = ?' : [1986]
You can also specify this with `DBIX_QUERYLOG_SKIP_BIND` environment variable.
- color
If set, log messages will be colored with [Term::ANSIColor](https://metacpan.org/pod/Term::ANSIColor).
DBIx::QueryLog->color('green');
You can also specify this with `DBIX_QUERYLOG_COLOR` environment variable.
- useqq
If set, DBIx::QueryLog uses `$Data::Dumper::Useqq`.
DBIx::QueryLog->useqq(1);
You can also specify this with `DBIX_QUERYLOG_USEQQ` environment variable.
- compact
If set, log messages will be compact.
DBIx::QueryLog->compact(1);
# FROM: SELECT * FROM foo WHERE bar = 'baz'
# TO : SELECT * FROM foo WHERE bar = 'baz'
You can also specify this with `DBIX_QUERYLOG_COMPACT` environment variable.
- explain
**EXPERIMENTAL**
If set, DBIx::QueryLog logs the result of a `EXPLAIN` statement.
DBIx::QueryLog->explain(1);
my $row = $dbh->do(...);
# => SELECT * FROM peaple WHERE user_id = '1986'
# .----------------------------------------------------------------------------------------------.
# | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
# +----+-------------+--------+-------+---------------+---------+---------+-------+------+-------+
# | 1 | SIMPLE | peaple | const | PRIMARY | PRIMARY | 4 | const | 1 | |
# '----+-------------+--------+-------+---------------+---------+---------+-------+------+-------'
You can also specify this with `DBIX_QUERYLOG_EXPLAIN` environment variable.
- show\_data\_source
if set, DBI data\_source will be added to the log messages.
$dbh->do('SELECT * FROM sqlite_master');
# [2012-03-09T00:58:23] [main] [0.000953] SELECT * FROM sqlite_master at foo.pl line 34
DBIx::QueryLog->show_data_source(1);
$dbh->do('SELECT * FROM sqlite_master');
# [2012-03-09T00:58:23] [main] [0.000953] [SQLite:dbname=/tmp/TrSATdY3cc] SELECT * FROM sqlite_master at foo.pl line 56
You can also specify this with `DBIX_QUERYLOG_SHOW_DATASOURCE` environment variable.
- guard
Returns a guard object.
use DBIx::QueryLog ();
{
my $guard = DBIx::QueryLog->guard;
# ... do something
}
The following code does the same:
use DBIx::QueryLog ();
DBIx::QueryLog->enable;
# ... do something
DBIx::QueryLog->disable;
- ignore\_trace
Returns a guard object and disables tracing while the object is alive.
use DBIx::QueryLog;
# enabled
$dbh->do(...);
{
my $guard = DBIx::QueryLog->ignore_trace;
# disable
$dbh->do(...);
}
# enabled
$dbh->do(...)
- is\_enabled
Returns if DBIx::QueryLog is enabled or not.
use DBIx::QueryLog ();
say DBIx::QueryLog->is_enabled;
DBIx::QueryLog->disable;
See also [Localization](https://metacpan.org/pod/Localization) section.
# TIPS
## Localization
If you want to log only in a specific scope:
use DBIx::QueryLog (); # or require DBIx::QueryLog;
DBIx::QueryLog->begin; # or DBIx::QueryLog->enable
my $row = $dbh->do(...);
DBIx::QueryLog->end; # or DBIx::QueryLog->disable
DBIx::QueryLog logs only between `begin` and `end`.
## LOG\_LEVEL
When you set a `logger`, you might also want to change a log level.
$DBIx::QueryLog::LOG_LEVEL = 'info'; # default 'debug'
## OUTPUT
If you want to change where to output:
open my $fh, '>', 'dbix_query.log';
$DBIx::QueryLog::OUTPUT = $fh;
You can also specify a code reference:
$DBIx::QueryLog::OUTPUT = sub {
my %params = @_;
my $format = << 'FORMAT';
localtime : %s # ISO-8601 without timezone
level : %s # log level ($DBIx::QueryLog::LOG_LEVEL)
time : %f # elasped time
data_source: $s # data_source
sql : %s # executed query
bind_params: %s # bind parameters
pkg : %s # caller package
file : %s # caller file
line : %d # caller line
FORMAT
printf $format,
@params{qw/localtime level pkg time data_source sql/},
join(', ', @{$params{bind_params}}),
@params{qw/file line/};
printf "AutoCommit?: %d\n", $params->{dbh}->{AutoCommit} ? 1 : 0;
};
You can also use this if you want to use a logger that doesn't have a `log` method like the one of [<Log::Dispatch](https://metacpan.org/pod/<Log::Dispatch)>.
$DBIx::QueryLog::OUTPUT = sub {
my %params = @_;
my $logger = Log::Any->get_logger;
$logger->debug("$params{message}");
};
Note that this only works when `<logger`> is not set.
Default `$OUTPUT` is `STDERR`.
# AUTHOR
xaicron <xaicron {at} cpan.org>
# THANKS TO
tokuhirom
yibe
kamipo
tomi-ru
riywo
makamaka
# BUG REPORTING
Plese use github issues: [https://github.com/xaicron/p5-DBIx-QueryLog/issues](https://github.com/xaicron/p5-DBIx-QueryLog/issues).
# COPYRIGHT
Copyright 2010 - xaicron
# LICENSE
This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.
# SEE ALSO
[DBI](https://metacpan.org/pod/DBI)