1
0
mirror of synced 2025-02-01 04:51:45 +03:00

bulkdelete delete multikey rows

This commit is contained in:
runa 2007-04-10 17:31:22 +00:00
parent f402f879b2
commit 01c93d3e02

View File

@ -127,21 +127,35 @@ class Doctrine_Transaction extends Doctrine_Connection_Module
foreach ($this->delete as $name => $deletes) { foreach ($this->delete as $name => $deletes) {
$record = false; $record = false;
$ids = array(); $ids = array();
foreach ($deletes as $k => $record) { if (is_array($deletes[count($deletes)-1]->getTable()->getIdentifier())){
$ids[] = $record->getIncremented(); foreach($deletes as $k => $record){
$record->assignIdentifier(false); $cond = '';
} $ids = $record->obtainIdentifier();
if ($record instanceof Doctrine_Record) { $query = 'DELETE FROM '.$record->getTable()->getTableName().' WHERE ';
$params = substr(str_repeat("?, ",count($ids)),0,-2); foreach(array_keys($ids) as $id){
if ($cond){ $cond .= " AND ";}
$cond .= " $id = ? ";
}
$query = $query . $cond;
$this->conn->execute($query, array_values($ids));
}
}else{
foreach ($deletes as $k => $record) {
$ids[] = $record->getIncremented();
$record->assignIdentifier(false);
}
if ($record instanceof Doctrine_Record) {
$params = substr(str_repeat("?, ",count($ids)),0,-2);
$query = 'DELETE FROM ' $query = 'DELETE FROM '
. $record->getTable()->getTableName() . $record->getTable()->getTableName()
. ' WHERE ' . ' WHERE '
. $record->getTable()->getIdentifier() . $record->getTable()->getIdentifier()
. ' IN(' . $params . ')'; . ' IN(' . $params . ')';
$this->conn->execute($query, $ids); $this->conn->execute($query, $ids);
} }
}
} }
$this->delete = array(); $this->delete = array();