mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
pkrenn: getGeneratedID added, fixed class PDOQuery (merged from branches/gsoc)
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@41707 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
c144bf1aef
commit
08b2874a41
@ -94,8 +94,8 @@ class DB {
|
|||||||
* Get the autogenerated ID from the previous INSERT query.
|
* Get the autogenerated ID from the previous INSERT query.
|
||||||
* @return int
|
* @return int
|
||||||
*/
|
*/
|
||||||
static function getGeneratedID() {
|
static function getGeneratedID($table) {
|
||||||
return DB::$globalConn->getGeneratedID();
|
return DB::$globalConn->getGeneratedID($table);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -37,7 +37,7 @@ abstract class Database extends Object {
|
|||||||
* Get the autogenerated ID from the previous INSERT query.
|
* Get the autogenerated ID from the previous INSERT query.
|
||||||
* @return int
|
* @return int
|
||||||
*/
|
*/
|
||||||
abstract function getGeneratedID();
|
abstract function getGeneratedID($table);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if the connection to the database is active.
|
* Check if the connection to the database is active.
|
||||||
|
@ -99,7 +99,7 @@ class MySQLDatabase extends Database {
|
|||||||
return new MySQLQuery($this, $handle);
|
return new MySQLQuery($this, $handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getGeneratedID() {
|
public function getGeneratedID($table) {
|
||||||
return mysql_insert_id($this->dbConn);
|
return mysql_insert_id($this->dbConn);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -153,7 +153,6 @@ class PDODatabase extends Database {
|
|||||||
|
|
||||||
$stmt = $dbConn->prepare($sql);
|
$stmt = $dbConn->prepare($sql);
|
||||||
$handle = $stmt->execute(); // Execute and save the return value (true or false)
|
$handle = $stmt->execute(); // Execute and save the return value (true or false)
|
||||||
$result = $stmt->fetchAll(); // Get the result itself
|
|
||||||
|
|
||||||
if(isset($_REQUEST['showqueries'])) {
|
if(isset($_REQUEST['showqueries'])) {
|
||||||
$duration = microtime(true) - $starttime;
|
$duration = microtime(true) - $starttime;
|
||||||
@ -164,16 +163,21 @@ class PDODatabase extends Database {
|
|||||||
$error = $stmt->errorInfo();
|
$error = $stmt->errorInfo();
|
||||||
$this->databaseError("Couldn't run query: $sql | " . $error[2], $errorLevel);
|
$this->databaseError("Couldn't run query: $sql | " . $error[2], $errorLevel);
|
||||||
}
|
}
|
||||||
return new PDOQuery($result);
|
return new PDOQuery($stmt);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the ID for the next new record for the table.
|
* Get the ID for the next new record for the table.
|
||||||
* Get the autogenerated ID from the previous INSERT query.
|
* Get the autogenerated ID from the previous INSERT query.
|
||||||
|
* Simulate mysql_insert_id by fetching the highest ID as there is no other reliable method across databases.
|
||||||
* @return int
|
* @return int
|
||||||
*/
|
*/
|
||||||
public function getGeneratedID() {
|
public function getGeneratedID($table) {
|
||||||
|
$stmt = $dbConn->prepare("SELECT MAX(ID) FROM :table");
|
||||||
|
$stmt->bindParam(":table", $table);
|
||||||
|
$handle = $stmt->execute();
|
||||||
|
$result = $stmt->fetchColumn();
|
||||||
|
return $handle ? $result : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -512,30 +516,58 @@ class PDODatabase extends Database {
|
|||||||
* A result-set from a database query (array).
|
* A result-set from a database query (array).
|
||||||
*/
|
*/
|
||||||
class PDOQuery extends Query {
|
class PDOQuery extends Query {
|
||||||
private $result;
|
|
||||||
|
/**
|
||||||
|
* The object that holds the result set.
|
||||||
|
* @var $stmt
|
||||||
|
*/
|
||||||
|
private $stmt;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Hook the result-set given into a Query class, suitable for use by sapphire.
|
* Hook the result-set given into a Query class, suitable for use by sapphire.
|
||||||
* @param array $result The array of all returned values.
|
* @param PDO object $stmt The object of all returned values.
|
||||||
*/
|
*/
|
||||||
public function __construct(PDODatabase $result) {
|
public function __construct(PDODatabase $stmt) {
|
||||||
$this->result = $result;
|
$this->stmt = $stmt;
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Free the result-set given into a Query class.
|
||||||
|
*/
|
||||||
public function __destroy() {
|
public function __destroy() {
|
||||||
$this->result = null;
|
$this->stmt = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determine if a given element is part of the result set.
|
||||||
|
* @param string string $row The element to search for.
|
||||||
|
*/
|
||||||
public function seek($row) {
|
public function seek($row) {
|
||||||
return in_array($row, $this->result);
|
return in_array($row, $this->stmt->fetchAll());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the number of results.
|
||||||
|
*/
|
||||||
public function numRecords() {
|
public function numRecords() {
|
||||||
return count($this->result);
|
$value = $this->stmt->fetchAll();
|
||||||
|
return count($value);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function nextRecord() {
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public function nextRecord() {
|
||||||
|
$record = $this->stmt->fetch(PDO::FETCH_ASSOC);
|
||||||
|
if (count($record)) {
|
||||||
|
return $record;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user