yuki-kimoto update document
8d90c6d 15 years ago
1 contributor
107 lines | 2.398kb
package DBIx::Custom::Query;
use Object::Simple;

use strict;
use warnings;

sub sql             : Attr {}
sub key_infos       : Attr {}
sub bind_filter     : Attr {}
sub fetch_filter     : Attr {}
sub sth             : Attr {}

sub no_bind_filters      : Attr { type => 'array', trigger => sub {
    my $self = shift;
    my $no_bind_filters = $self->no_bind_filters || [];
    my %no_bind_filters_map = map {$_ => 1} @{$no_bind_filters};
    $self->_no_bind_filters_map(\%no_bind_filters_map);
}}
sub _no_bind_filters_map : Attr {default => sub { {} }}

sub no_fetch_filters     : Attr { type => 'array', default => sub { [] } }

Object::Simple->build_class;

=head1 NAME

DBIx::Custom::Query - DBIx::Custom query

=head1 SYNOPSIS

    # Create query
    my $dbi = DBIx::Custom->new;
    my $query = $dbi->create_query($template);
    
    # Set query attributes
    $query->bind_filter($dbi->filters->{default_bind_filter});
    $query->no_bind_filters('title', 'author');
    
    $query->fetch_filter($dbi->filters->{default_fetch_filter});
    $query->no_fetch_filters('title', 'author');
    
    # Execute query
    $dbi->execute($query, $params);

=head1 Accessors

=head2 sth

Set and get statement handle

    $self = $self->sth($sql);
    $sth  = $self->sth;

=head2 sql

Set and get SQL

    $self = $self->sql($sql);
    $sql  = $self->sql;

=head2 bind_filter

Set and get bind filter

    $self        = $self->bind_filter($bind_filter);
    $bind_filter = $self->bind_filter;

=head2 no_bind_filters

Set and get keys of no filtering

    $self            = $self->no_bind_filters($no_filters);
    $no_bind_filters = $self->no_bind_filters;

=head2 fetch_filter

Set and get fetch filter

    $self         = $self->fetch_filter($fetch_filter);
    $fetch_filter = $self->fetch_filter;

=head2 no_fetch_filters

Set and get keys of no filtering

    $self             = $self->no_fetch_filters($no_filters);
    $no_fetch_filters = $self->no_fetch_filters;

=head2 key_infos

Set and get key informations

    $self      = $self->key_infos($key_infos);
    $key_infos = $self->key_infos;

=head1 AUTHOR

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

Github L<http://github.com/yuki-kimoto>

=head1 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.