2009-06-12 08:14:29 +00:00
|
|
|
<?php
|
|
|
|
// This file is part of Moodle - http://moodle.org/
|
|
|
|
//
|
|
|
|
// Moodle 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.
|
|
|
|
//
|
|
|
|
// Moodle is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Abstract recordset.
|
|
|
|
*
|
2012-06-05 10:31:03 +02:00
|
|
|
* @package core_dml
|
2009-06-12 08:14:29 +00:00
|
|
|
* @copyright 2008 Petr Skoda (http://skodak.org)
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*/
|
2008-05-25 20:17:40 +00:00
|
|
|
|
2010-07-25 12:57:24 +00:00
|
|
|
defined('MOODLE_INTERNAL') || die();
|
|
|
|
|
2008-05-25 20:17:40 +00:00
|
|
|
/**
|
2008-06-02 16:06:33 +00:00
|
|
|
* Abstract class for resultsets returned from database functions.
|
2008-05-25 20:17:40 +00:00
|
|
|
* This is a simple Iterator with needed recorset closing support.
|
|
|
|
*
|
2008-06-02 16:06:33 +00:00
|
|
|
* The difference from old recorset is that the records are returned
|
2008-05-25 20:17:40 +00:00
|
|
|
* as objects, not arrays. You should use "foreach ($recordset as $record) {}"
|
|
|
|
* followed by "$recordset->close()".
|
|
|
|
*
|
|
|
|
* Do not forget to close all recordsets when they are not needed anymore!
|
|
|
|
*/
|
|
|
|
abstract class moodle_recordset implements Iterator {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns current record - fields as object properties, lowercase
|
|
|
|
* @return object
|
|
|
|
*/
|
|
|
|
//public abstract function current();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the key of current row
|
|
|
|
* @return int current row
|
|
|
|
*/
|
|
|
|
//public abstract function key();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Moves forward to next row
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
//public abstract function next();
|
|
|
|
|
|
|
|
/**
|
2010-05-21 18:23:06 +00:00
|
|
|
* Rewinds are not supported!
|
2008-05-25 20:17:40 +00:00
|
|
|
* @return void
|
|
|
|
*/
|
2008-10-28 12:14:09 +00:00
|
|
|
public function rewind() {
|
|
|
|
// no seeking, sorry - let's ignore it ;-)
|
|
|
|
return;
|
|
|
|
}
|
2008-05-25 20:17:40 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Did we reach the end?
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
//public abstract function valid();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Free resources and connections, recordset can not be used anymore.
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public abstract function close();
|
2008-06-02 16:06:33 +00:00
|
|
|
}
|