NAME
Mojo::SQLite::Results - Results
SYNOPSIS
use Mojo::SQLite::Results;
my $results = Mojo::SQLite::Results->new(sth => $sth);
$results->hashes->map(sub { $_->{foo} })->shuffle->join("\n")->say;
DESCRIPTION
Mojo::SQLite::Results is a container for DBD::SQLite statement handles used by Mojo::SQLite::Database.
ATTRIBUTES
Mojo::SQLite::Results implements the following attributes.
sth
my $sth = $results->sth;
$results = $results->sth($sth);
DBD::SQLite statement handle results are fetched from.
METHODS
Mojo::SQLite::Results inherits all methods from Mojo::Base and implements the following new ones.
new
my $results = Mojo::SQLite::Results->new(sth => $sth);
Construct a new Mojo::SQLite::Results object.
array
my $array = $results->array;
Fetch next row from "sth" and return it as an array reference.
# Process one row at a time
while (my $next = $results->array) {
say $next->[3];
}
arrays
my $collection = $results->arrays;
Fetch all rows from "sth" and return them as a Mojo::Collection object containing array references.
# Process all rows at once
say $results->arrays->reduce(sub { $a->[3] + $b->[3] });
columns
my $columns = $results->columns;
Return column names as an array reference.
hash
my $hash = $results->hash;
Fetch next row from "sth" and return it as a hash reference.
# Process one row at a time
while (my $next = $results->hash) {
say $next->{money};
}
hashes
my $collection = $results->hashes;
Fetch all rows from "sth" and return them as a Mojo::Collection object containing hash references.
# Process all rows at once
say $results->hashes->reduce(sub { $a->{money} + $b->{money} });
rows
my $num = $results->rows;
Number of rows. Note that for SELECT
statements, this count will not be accurate until all rows have been fetched.
text
my $text = $results->text;
Fetch all rows from "sth" and turn them into a table with "tablify" in Mojo::Util.
BUGS
Report any issues on the public bugtracker.
AUTHOR
Dan Book, dbook@cpan.org
COPYRIGHT AND LICENSE
Copyright 2015, Dan Book.
This library is free software; you may redistribute it and/or modify it under the terms of the Artistic License version 2.0.