NAME

DBIx::Custom - DBI with hash parameter binding and filtering system

STABILITY

This module is not stable. Method name and implementations will be change.

SYNOPSYS

# Connect
my $dbi = DBIx::Custom->connect(data_source => "dbi:mysql:database=books",
                                user => 'ken', password => '!LFKD%$&');

# Disconnect
$dbi->disconnect

# Insert 
$dbi->insert(table  => 'books',
             param  => {title => 'perl', author => 'Ken'},
             filter => {title => 'encode_utf8'});

# Update 
$dbi->update(table  => 'books', 
             param  => {title => 'aaa', author => 'Ken'}, 
             where  => {id => 5},
             filter => {title => 'encode_utf8'});

# Update all
$dbi->update_all(table  => 'books',
                 param  => {title => 'aaa'},
                 filter => {title => 'encode_utf8'});

# Delete
$dbi->delete(table  => 'books',
             where  => {author => 'Ken'},
             filter => {title => 'encode_utf8'});

# Delete all
$dbi->delete_all(table => 'books');

# Select
my $result = $dbi->select(table => 'books');

# Select(more complex)
my $result = $dbi->select(
    table  => 'books',
    column => [qw/author title/],
    where  => {author => 'Ken'},
    append => 'order by id limit 1',
    filter => {tilte => 'encode_utf8'}
);

# Select(Join table)
my $result = $dbi->select(
    table => ['books', 'rental'],
    column => ['books.name as book_name']
    relation => {'books.id' => 'rental.book_id'}
);

# Execute SQL
$dbi->execute("select title from books");

# Execute SQL with parameters and filter
$dbi->execute("select id from books where {= author} && {like title}",
              param  => {author => 'ken', title => '%Perl%'},
              filter => {tilte => 'encode_utf8'});

# Create query and execute it
my $query = $dbi->create_query(
    "select id from books where {= author} && {like title}"
);
$dbi->execute($query, param => {author => 'ken', title => '%Perl%'})

# Default filter
$dbi->default_query_filter('encode_utf8');
$dbi->default_fetch_filter('decode_utf8');

# Fetch
while (my $row = $result->fetch) {
    # ...
}

# Fetch hash
while (my $row = $result->fetch_hash) {
    
}

# DBI instance
my $dbh = $dbi->dbh;

DESCRIPTION

DBIx::Custom is useful DBI extention. This module have hash parameter binding and filtering system.

Normally, binding parameter is array. DBIx::Custom enable you to pass binding parameter as hash.

This module also provide filtering system. You can filter the binding parameter or the value of fetching row.

And have useful method such as insert(), update(), delete(), and select().

Features

1. Hash parameter binding.
2. Value filtering.
3. Useful methos such as insert(), update(), delete(), and select().

ATTRIBUTES

user

Database user name.

$dbi  = $dbi->user('Ken');
$user = $dbi->user;

password

Database password.

$dbi      = $dbi->password('lkj&le`@s');
$password = $dbi->password;

data_source

Database data source.

$dbi         = $dbi->data_source("dbi:mysql:dbname=$database");
$data_source = $dbi->data_source;

dbh

Database handle. This is the innstance of DBI

$dbi = $dbi->dbh($dbh);
$dbh = $dbi->dbh;

You can use all methods of DBI

my $sth    = $dbi->dbh->prepare("...");
my $errstr = $dbi->dbh->errstr;

filters

Filters

$dbi     = $dbi->filters({%filters});
$filters = $dbi->filters;

encode_utf8 and decode_utf8 is set to this attribute by default.

$encode_utf8 = $dbi->filters->{encode_utf8};
$decode_utf8 = $dbi->filters->{decode_utf8};

default_query_filter

Default query filter.

$dbi                  = $dbi->default_query_filter('encode_utf8');
$default_query_filter = $dbi->default_query_filter

default_fetch_filter

Fetching filter.

$dbi                  = $dbi->default_fetch_filter('decode_utf8');
$default_fetch_filter = $dbi->default_fetch_filter;

result_class

Result class.

$dbi          = $dbi->result_class('DBIx::Custom::Result');
$result_class = $dbi->result_class;

DBIx::Custom::Result is set to this attribute by default.

sql_template

SQLTemplate instance. sql_template attribute must be the instance of DBIx::Cutom::SQLTemplate subclass.

$dbi          = $dbi->sql_template(DBIx::Cutom::SQLTemplate->new);
$sql_template = $dbi->sql_template;

the instance of DBIx::Cutom::SQLTemplate is set to this attribute by default.

METHODS

This class is Object::Simple subclass. You can use all methods of Object::Simple

connect

Connect to database.

my $dbi = DBIx::Custom->connect(data_source => "dbi:mysql:database=books",
                                user => 'ken', password => '!LFKD%$&');

"AutoCommit" and "RaiseError" option is true, and "PrintError" option is false by dfault.

disconnect

Disconnect database.

$dbi->disconnect;

If database is already disconnected, this method do nothing.

insert

Insert row.

$affected = $dbi->insert(table  => $table, 
                         param  => {%param},
                         append => $append,
                         filter => {%filter});

Retruned value is affected rows count.

Example:

# insert
$dbi->insert(table  => 'books', 
             param  => {title => 'Perl', author => 'Taro'},
             append => "some statement",
             filter => {title => 'encode_utf8'})

update

Update rows.

$affected = $dbi->update(table  => $table, 
                         param  => {%params},
                         where  => {%where},
                         append => $append,
                         filter => {%filter})

Retruned value is affected rows count

Example:

#update
$dbi->update(table  => 'books',
             param  => {title => 'Perl', author => 'Taro'},
             where  => {id => 5},
             append => "some statement",
             filter => {title => 'encode_utf8'});

update_all

Update all rows.

$affected = $dbi->update_all(table  => $table, 
                             param  => {%params},
                             filter => {%filter},
                             append => $append);

Retruned value is affected rows count.

Example:

# update_all
$dbi->update_all(table  => 'books', 
                 param  => {author => 'taro'},
                 filter => {author => 'encode_utf8'});

delete

Delete rows.

$affected = $dbi->delete(table  => $table,
                         where  => {%where},
                         append => $append,
                         filter => {%filter});

Retrun value is affected rows count

Example:

# delete
$dbi->delete(table  => 'books',
             where  => {id => 5},
             append => 'some statement',
             filter => {id => 'encode_utf8'});

delete_all

Delete all rows.

$affected = $dbi->delete_all(table => $table);

Retruned value is affected rows count.

Example:

# delete_all
$dbi->delete_all(table => 'books');

select

Select rows.

$result = $dbi->select(table    => $table,
                       column   => [@column],
                       where    => {%where},
                       append   => $append,
                       relation => {%relation},
                       filter   => {%filter});

Return value is the instance of DBIx::Custom::Result.

Example:

# select * from books;
$result = $dbi->select(table => 'books');

# select * from books where title = 'Perl';
$result = $dbi->select(table => 'books', where => {title => 1});

# select title, author from books where id = 1 for update;
$result = $dbi->select(
    table  => 'books',
    column => ['title', 'author'],
    where  => {id => 1},
    appned => 'for update'
);

# select books.name as book_name from books, rental 
# where books.id = rental.book_id;
my $result = $dbi->select(
    table    => ['books', 'rental'],
    column   => ['books.name as book_name']
    relation => {'books.id' => 'rental.book_id'}
);

create_query

my $query = $dbi->create_query(
    "select * from authors where {= name} and {= age};"
);

Create the instance of DBIx::Custom::Query. This receive the string written by SQL template.

execute

$result = $dbi->execute($query,    param => $params, filter => {%filter});
$result = $dbi->execute($template, param => $params, filter => {%filter});

Execute the instace of DBIx::Custom::Query or the string written by SQL template. Return value is the instance of DBIx::Custom::Result.

Example:

$result = $dbi->execute("select * from authors where {= name} and {= age}", 
                        param => {name => 'taro', age => 19});

while (my $row = $result->fetch) {
    # do something
}

See also DBIx::Custom::SQLTemplate to know how to write SQL template.

register_filter

$dbi->register_filter(%filters);

Resister filter.

Example:

$dbi->register_filter(
    encode_utf8 => sub {
        my $value = shift;
        
        require Encode;
        
        return Encode::encode('UTF-8', $value);
    },
    decode_utf8 => sub {
        my $value = shift;
        
        require Encode;
        
        return Encode::decode('UTF-8', $value)
    }
);

cache

$dbi   = $dbi->cache(1);
$cache = $dbi->cache;

Cache the result of parsing SQL template. Default to 1.

cache_method

$dbi          = $dbi->cache_method(\&cache_method);
$cache_method = $dbi->cache_method

Method for cache.

Example:

$dbi->cache_method(
    sub {
        my $self = shift;
        
        $self->{_cached} ||= {};
        
        if (@_ > 1) {
            $self->{_cached}{$_[0]} = $_[1] 
        }
        else {
            return $self->{_cached}{$_[0]}
        }
    }
);

AUTHOR

Yuki Kimoto, <kimoto.yuki at gmail.com>

COPYRIGHT & LICENSE

Copyright 2009 Yuki Kimoto, all rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.