mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
200 lines
4.3 KiB
PHP
200 lines
4.3 KiB
PHP
<?php
|
|
|
|
namespace SilverStripe\ORM\Queries;
|
|
|
|
use Injector;
|
|
|
|
/**
|
|
* Object representing a SQL INSERT query.
|
|
* The various parts of the SQL query can be manipulated individually.
|
|
*
|
|
* @package framework
|
|
* @subpackage orm
|
|
*/
|
|
class SQLInsert extends SQLExpression implements SQLWriteExpression {
|
|
|
|
/**
|
|
* List of rows to be inserted
|
|
*
|
|
* @var array[SQLAssignmentRow]
|
|
*/
|
|
protected $rows = array();
|
|
|
|
/**
|
|
* The table name to insert into
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $into = null;
|
|
|
|
/**
|
|
* Construct a new SQLInsert object
|
|
*
|
|
* @param string $into Table name to insert into (ANSI quoted)
|
|
* @param array $assignments List of column assignments
|
|
* @return static
|
|
*/
|
|
public static function create($into = null, $assignments = array()) {
|
|
return Injector::inst()->createWithArgs(__CLASS__, func_get_args());
|
|
}
|
|
|
|
/**
|
|
* Construct a new SQLInsert object
|
|
*
|
|
* @param string $into Table name to insert into (ANSI quoted)
|
|
* @param array $assignments List of column assignments
|
|
*/
|
|
function __construct($into = null, $assignments = array()) {
|
|
$this->setInto($into);
|
|
if(!empty($assignments)) {
|
|
$this->setAssignments($assignments);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Sets the table name to insert into
|
|
*
|
|
* @param string $into Single table name (ANSI quoted)
|
|
* @return self The self reference to this query
|
|
*/
|
|
public function setInto($into) {
|
|
$this->into = $into;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets the table name to insert into
|
|
*
|
|
* @return string Single table name
|
|
*/
|
|
public function getInto() {
|
|
return $this->into;
|
|
}
|
|
|
|
public function isEmpty() {
|
|
return empty($this->into) || empty($this->rows);
|
|
}
|
|
|
|
/**
|
|
* Appends a new row to insert
|
|
*
|
|
* @param array|SQLAssignmentRow $data A list of data to include for this row
|
|
* @return self The self reference to this query
|
|
*/
|
|
public function addRow($data = null) {
|
|
// Clear existing empty row
|
|
if(($current = $this->currentRow()) && $current->isEmpty()) {
|
|
array_pop($this->rows);
|
|
}
|
|
|
|
// Append data
|
|
if($data instanceof SQLAssignmentRow) {
|
|
$this->rows[] = $data;
|
|
} else {
|
|
$this->rows[] = new SQLAssignmentRow($data);
|
|
}
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Returns the current list of rows
|
|
*
|
|
* @return array[SQLAssignmentRow]
|
|
*/
|
|
public function getRows() {
|
|
return $this->rows;
|
|
}
|
|
|
|
/**
|
|
* Returns the list of distinct column names used in this insert
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getColumns() {
|
|
$columns = array();
|
|
foreach($this->getRows() as $row) {
|
|
$columns = array_merge($columns, $row->getColumns());
|
|
}
|
|
return array_unique($columns);
|
|
}
|
|
|
|
/**
|
|
* Sets all rows to the given array
|
|
*
|
|
* @param array $rows the list of rows
|
|
* @return self The self reference to this query
|
|
*/
|
|
public function setRows(array $rows) {
|
|
return $this->clear()->addRows($rows);
|
|
}
|
|
|
|
/**
|
|
* Adds the list of rows to the array
|
|
*
|
|
* @param array $rows the list of rows
|
|
* @return self The self reference to this query
|
|
*/
|
|
public function addRows(array $rows) {
|
|
foreach($rows as $row) $this->addRow($row);
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Returns the currently set row
|
|
*
|
|
* @param boolean $create Flag to indicate if a row should be created if none exists
|
|
* @return SQLAssignmentRow|false The row, or false if none exists
|
|
*/
|
|
public function currentRow($create = false) {
|
|
$current = end($this->rows);
|
|
if($create && !$current) {
|
|
$this->rows[] = $current = new SQLAssignmentRow();
|
|
}
|
|
return $current;
|
|
}
|
|
|
|
public function addAssignments(array $assignments) {
|
|
$this->currentRow(true)->addAssignments($assignments);
|
|
return $this;
|
|
}
|
|
|
|
public function setAssignments(array $assignments) {
|
|
$this->currentRow(true)->setAssignments($assignments);
|
|
return $this;
|
|
}
|
|
|
|
public function getAssignments() {
|
|
return $this->currentRow(true)->getAssignments();
|
|
}
|
|
|
|
public function assign($field, $value) {
|
|
$this->currentRow(true)->assign($field, $value);
|
|
return $this;
|
|
}
|
|
|
|
public function assignSQL($field, $sql) {
|
|
$this->currentRow(true)->assignSQL($field, $sql);
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Clears all currently set assigment values on the current row
|
|
*
|
|
* @return self The self reference to this query
|
|
*/
|
|
public function clearRow() {
|
|
$this->currentRow(true)->clear();
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Clears all rows
|
|
*
|
|
* @return self The self reference to this query
|
|
*/
|
|
public function clear() {
|
|
$this->rows = array();
|
|
return $this;
|
|
}
|
|
}
|