Красноречивый запрос Laravel с суммой значений из другой таблицы по условиюPhp

Кемеровские программисты php общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Красноречивый запрос Laravel с суммой значений из другой таблицы по условию

Сообщение Anonymous »

У меня есть две таблицы. Транзакция и распределение.
Одна транзакция может иметь несколько распределений.
Отношения определяются следующим образом:

Внутри таблицы распределения< /p>

class Allocation extends Model
{
public function transaction_fk(){
return $this->belongsTo('App\Models\Transaction','transaction_id');
}
}


Внутри таблицы транзакций

class Transaction extends Model
{
public function allocations() {
return $this->hasMany('App\Models\Allocation');
}
}


Мне нужно запросить все строки из таблицы транзакций с определенным идентификатором, а также сумму выделений для этой строки транзакции с суммой итоговых выделений, если транзакция итог не равен сумме итогов распределения. Что-то вроде следующего:

Transaction::where('id',$id)->where('amount','!==','sum(allocations.amount)')->with('balance' as 'sum(allocations.amount)')->get();


Этот запрос не работает. Чего мне не хватает?

Мне удалось сделать это как простой запрос, который я пропустил, сделал второй запрос и добавил в список. Это дает мне правильный результат. Как видите, это долго и медленно. Мне нужно сделать это сразу, однократно запросив базу данных.

$transactions2 = Transaction::where('contact_type','supplier')
->where('contact_id',$ehead->supplier_id)
->get();

$transactions = [];
foreach ($transactions2 as $item) {
$sum = Allocation::where('transaction_id',$item['id'])->get()->sum('amount');
if($item['amount'] !== $sum){
$item->unallocated_amount = $sum;
array_push($transactions, $item);
}

}


Подробнее здесь: https://stackoverflow.com/questions/620 ... -condition
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Php»