2013-06-21 10:32:08 +12:00
|
|
|
<?php
|
|
|
|
|
2016-06-15 16:03:16 +12:00
|
|
|
namespace SilverStripe\ORM\Queries;
|
|
|
|
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Core\Injector\Injector;
|
2016-06-15 16:03:16 +12:00
|
|
|
|
2013-06-21 10:32:08 +12:00
|
|
|
/**
|
|
|
|
* Object representing a SQL DELETE query.
|
|
|
|
* The various parts of the SQL query can be manipulated individually.
|
|
|
|
*/
|
|
|
|
class SQLDelete extends SQLConditionalExpression {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* List of tables to limit the delete to, if multiple tables
|
|
|
|
* are specified in the condition clause
|
|
|
|
*
|
|
|
|
* @see http://dev.mysql.com/doc/refman/5.0/en/delete.html
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $delete = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Construct a new SQLDelete.
|
|
|
|
*
|
|
|
|
* @param array|string $from An array of Tables (FROM clauses). The first one should be just the table name.
|
2014-07-15 09:31:03 +12:00
|
|
|
* Each should be ANSI quoted.
|
2013-06-21 10:32:08 +12:00
|
|
|
* @param array $where An array of WHERE clauses.
|
|
|
|
* @param array|string $delete The table(s) to delete, if multiple tables are queried from
|
2016-08-19 10:51:35 +12:00
|
|
|
* @return static
|
2013-06-21 10:32:08 +12:00
|
|
|
*/
|
|
|
|
public static function create($from = array(), $where = array(), $delete = array()) {
|
|
|
|
return Injector::inst()->createWithArgs(__CLASS__, func_get_args());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Construct a new SQLDelete.
|
|
|
|
*
|
|
|
|
* @param array|string $from An array of Tables (FROM clauses). The first one should be just the table name.
|
2014-07-15 09:31:03 +12:00
|
|
|
* Each should be ANSI quoted.
|
2013-06-21 10:32:08 +12:00
|
|
|
* @param array $where An array of WHERE clauses.
|
|
|
|
* @param array|string $delete The table(s) to delete, if multiple tables are queried from
|
|
|
|
*/
|
|
|
|
function __construct($from = array(), $where = array(), $delete = array()) {
|
|
|
|
parent::__construct($from, $where);
|
|
|
|
$this->setDelete($delete);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* List of tables to limit the delete to, if multiple tables
|
|
|
|
* are specified in the condition clause
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getDelete() {
|
|
|
|
return $this->delete;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the list of tables to limit the delete to, if multiple tables
|
|
|
|
* are specified in the condition clause
|
|
|
|
*
|
|
|
|
* @param string|array $tables Escaped SQL statement, usually an unquoted table name
|
2016-08-19 10:51:35 +12:00
|
|
|
* @return $this Self reference
|
2013-06-21 10:32:08 +12:00
|
|
|
*/
|
|
|
|
public function setDelete($tables) {
|
|
|
|
$this->delete = array();
|
|
|
|
return $this->addDelete($tables);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the list of tables to limit the delete to, if multiple tables
|
|
|
|
* are specified in the condition clause
|
|
|
|
*
|
|
|
|
* @param string|array $tables Escaped SQL statement, usually an unquoted table name
|
2016-08-19 10:51:35 +12:00
|
|
|
* @return $this Self reference
|
2013-06-21 10:32:08 +12:00
|
|
|
*/
|
|
|
|
public function addDelete($tables) {
|
|
|
|
if(is_array($tables)) {
|
|
|
|
$this->delete = array_merge($this->delete, $tables);
|
|
|
|
} elseif(!empty($tables)) {
|
|
|
|
$this->delete[str_replace(array('"','`'), '', $tables)] = $tables;
|
|
|
|
}
|
2016-08-19 10:51:35 +12:00
|
|
|
return $this;
|
2013-06-21 10:32:08 +12:00
|
|
|
}
|
|
|
|
}
|