NAME
SQL::DB::Cursor - SQL::DB database cursor
SYNOPSIS
use SQL::DB::Cursor;
my $cursor = SQL::DB::Cursor->new(
sth => $sth,
db => $sqldb,
query => $expr,
);
while (my $next = $cursor->next) {
print $next->column()
}
# Or if you want you can get all at once:
my @objects = $cursor->all;
DESCRIPTION
SQL::DB::Cursor is a Perl-side cursor/read-only ORM interface to DBI. It is used by SQL::DB to create objects from rows. See the SQL::DB "fetch()" method for details.
CONSTRUCTOR
- new(sth => $sth, db => $db, query => $expr)
-
Create a new cursor object. $sth is a DBI statement handle (ie the result of a DBI->execute call). $db is the SQL::DB object creating the cursor. $expr must be the SQL::DB::Expr which was used to create $sth.
ATTRIBUTES
- sth
-
The DBI statement handle.
- db
-
The SQL::DB object that created the statement handle and query.
- query
-
The SQL::DB::Expr used to create the statement handle.
- class
-
The class into which retrieved objects are blessed into. This is automatically created from the first row retrieved.
- done
-
Boolean value that is set to true when there are no more rows to be returned.
METHODS
- next
-
Returns the next row from the statement handle as an object. Returns undef when no data is left. Croaks on failure.
- all
-
Returns all rows from the statement handle as a list of objects. Returns the empty list if no data is available (or has already been fetch with 'next' for example). Croaks on failure.
- finish
-
Calls finish() on the DBI statement handle.
AUTHOR
Mark Lawrence <nomad@null.net>
COPYRIGHT AND LICENSE
Copyright (C) 2007,2008 Mark Lawrence <nomad@null.net>
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version.