silverstripe-sqlite3/code/SQLite3Query.php

73 lines
1.7 KiB
PHP
Raw Permalink Normal View History

<?php
namespace SilverStripe\SQLite;
2016-09-09 15:46:48 +12:00
use SilverStripe\ORM\Connect\Query;
use SQLite3Result;
use Traversable;
/**
* A result-set from a SQLite3 database.
*/
2016-09-09 15:46:48 +12:00
class SQLite3Query extends Query
2015-12-18 07:11:01 +13:00
{
/**
* The SQLite3Connector object that created this result set.
*
2015-12-18 07:11:01 +13:00
* @var SQLite3Connector
*/
protected $database;
/**
* The internal sqlite3 handle that points to the result set.
*
2015-12-18 07:11:01 +13:00
* @var SQLite3Result
*/
protected $handle;
/**
* Hook the result-set given into a Query class, suitable for use by framework.
* @param SQLite3Connector $database The database object that created this query.
* @param SQLite3Result $handle the internal sqlite3 handle that is points to the resultset.
*/
public function __construct(SQLite3Connector $database, SQLite3Result $handle)
{
$this->database = $database;
$this->handle = $handle;
}
public function __destruct()
{
2024-07-11 17:12:15 +02:00
if ($this->handle && $this->database->isActive()) {
2015-12-18 07:11:01 +13:00
$this->handle->finalize();
}
}
/**
* @todo This looks terrible but there is no SQLite3::get_num_rows() implementation
*/
public function numRecords()
{
// Some queries are not iterable using fetchArray like CREATE statement
if (!$this->handle->numColumns()) {
return 0;
}
$this->handle->reset();
2015-12-18 07:11:01 +13:00
$c=0;
while ($this->handle->fetchArray()) {
$c++;
}
$this->handle->reset();
return $c;
}
public function getIterator(): Traversable
2015-12-18 07:11:01 +13:00
{
while ($data = $this->handle->fetchArray(SQLITE3_ASSOC)) {
yield $data;
2015-12-18 07:11:01 +13:00
}
}
}