mirror of
https://github.com/friendica/friendica
synced 2025-01-25 04:19:47 +00:00
Only fetch the rows when needed
This commit is contained in:
parent
f1c53530a1
commit
0d7996d852
1 changed files with 25 additions and 11 deletions
|
@ -812,26 +812,40 @@ class dba {
|
||||||
// Is there a relation entry for the table?
|
// Is there a relation entry for the table?
|
||||||
if (isset(self::$relation[$table])) {
|
if (isset(self::$relation[$table])) {
|
||||||
foreach (self::$relation[$table] AS $field => $rel_def) {
|
foreach (self::$relation[$table] AS $field => $rel_def) {
|
||||||
|
// Currently we only support relations with a single variable
|
||||||
|
if (count($rel_def) > 1) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$rel_field = array_values($rel_def)[0];
|
||||||
|
$rel_table = array_keys($rel_def)[0];
|
||||||
|
|
||||||
|
// When the search field is the relation field, we don't need to fetch the rows
|
||||||
|
// This is useful when the leading record is already deleted in the frontend but the rest is done in the backend
|
||||||
|
if ((count($param) == 1) AND ($field == array_keys($param)[0])) {
|
||||||
|
$retval = self::delete($rel_table, array($rel_field => array_values($param)[0]), true, $callstack);
|
||||||
|
if (!$retval) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
// Fetch all rows that are to be deleted
|
// Fetch all rows that are to be deleted
|
||||||
$sql = "SELECT ".self::$dbo->escape($field)." FROM `".$table."` WHERE `".
|
$sql = "SELECT ".self::$dbo->escape($field)." FROM `".$table."` WHERE `".
|
||||||
implode("` = ? AND `", array_keys($param))."` = ?";
|
implode("` = ? AND `", array_keys($param))."` = ?";
|
||||||
|
|
||||||
$retval = false;
|
$retval = false;
|
||||||
$data = self::p($sql, $param);
|
$data = self::p($sql, $param);
|
||||||
while ($row = self::fetch($data)) {
|
while ($row = self::fetch($data)) {
|
||||||
foreach ($rel_def AS $rel_table => $rel_field) {
|
// We have to do a separate delete process per row
|
||||||
// We do a separate delete process per row
|
|
||||||
$retval = self::delete($rel_table, array($rel_field => $row[$field]), true, $callstack);
|
$retval = self::delete($rel_table, array($rel_field => $row[$field]), true, $callstack);
|
||||||
if (!$retval) {
|
if (!$retval) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
if (!$retval) {
|
if (!$retval) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$sql = "DELETE FROM `".$table."` WHERE `".
|
$sql = "DELETE FROM `".$table."` WHERE `".
|
||||||
implode("` = ? AND `", array_keys($param))."` = ?";
|
implode("` = ? AND `", array_keys($param))."` = ?";
|
||||||
|
|
Loading…
Add table
Reference in a new issue