NAME

Class::Classless::DBI - provides a Classless object-oriented database interface

SYNOPSIS

use DBI;
use DBIx::Interpolate;
use Class::Classless::DBI;

my $dbh = DBI->connect(...);
my $dbx = DBIx::Interpolate->new($dbh);

my $dbo = $Class::Classless::DBI::ROOT->clone;
$dbo->{METHODS}->{table} = 'table_name';
$dbo->{METHODS}->{dbx} = $dbx;

$dbo->insert_into_table(
  {
    values => [
      {col1 => 'A', col2 => 'B', col3 => 'C'},
      {col1 => 'a', col2 => 'b', col3 => 'c'},
      {col1 => '1', col2 => '2', col3 => '3'}
    ]
  }
);

$dbo->update_table(
  {
    values => {col1 => 'i', col2 => 'ii'},
    where   => {col1 => '1'}
  }
);

$dbo->delete_from_table(
  {
    where => {col3 => [qw(C c)]}
  }
);

$dbo->select_from_table();        # [{col1 => 'i', col2 => 'ii', col3 => '3'}]

DESCRIPTION

This module provides basic methods for classless objects to make database calls. It is designed to use DBIx::Interpolate, so future changes to that module are likely to affect this module as well.

METHODS

delete_from_table

insert_into_table

select_from_table

update_table

These methods do what you would expect them to do. Each method can accept a hashref as its argument. The following keys are used by these methods.

Note: select_from_table returns an arrayref of hashrefs. All other methods return the same information as &DBI::do.

columns

The value of this key should be a hashref. It allows you to use a key other than the column name when specifying table entries. For instance, the following two queries are equivalent.

$dbo->select_from_table(
  {
    where => {id => 5, val => 6}
  }
);

$dbo->select_from_table(
  {
    where => {foo => 5, val => 6},
    columns => {foo => 'id'}
  }
);

This key applies to the values key for insert_into_table and the where key for the other methods.

group

This key applies only to select_from_table. Its value should be an arrayref containing the names of columns by which to group results.

values

This key applies to the methods insert_into_table and update_table. Its value should be a hashref containing (column_name => value) entries. For insert_into_table it may also be an arrayref containing several hashrefs. In that case, each hashref must contain the same number of columns. Column values may also be arrayrefs, in which case a row will be inserted for each element of the referenced array.

select

This key applies only to select_from_table. Its value should be an arrayref containing the names of columns to select from the table.

where

This key applies to all methods but insert_into_table. Its value should be a hashref or an arrayref containing hashrefs. Each hashref should contain (column_name => value) entries that should all be satisfied for one row. An empty hashref will match all rows. All rows that match any of the hashrefs will be used. If the arrayref is empty, then no rows will be matched. However, if where is undefined, all rows will be matched. In order to simplify some queries, column values may also be arrayrefs, in which case rows that match any element of the referenced array will be used. For example, the following two queries are identical.

$dbo->select_from_table(
  {
    where => [
      {id => 5, val => 6},
      {id => 5, val => 7},
      {id => 6, val => 6},
      {id => 6, val => 7}
    ]
  }
);

$dbo->select_from_table(
  {
    where => {id => [5,6], val => [6,7]}
  }
);

make_where_clause

make_from_clause

These methods are used internally by the previous methods but are also available for public use. They generate fragments of SQL queries to be used with SQL::Interpolate. make_where_clause expects the where key to be present in the same format as specified above. make_from_clause expects a key named from in the same format as values in a insert_into_table method call. Both accept the columns key as well.

AUTHOR

Mark Tiefenbruck <mdash@cpan.org>

LEGAL STUFF

Copyright (c) 2005, Mark Tiefenbruck. All rights reserved. This module is free software. It may be used, redistributed and/or modified under the same terms as Perl itself.

SEE ALSO

L<Class::Classless>
L<DBIx::Interpolate>
L<Class::DBI>