簡體   English   中英

Laravel - 使用單個查詢組合多個查詢來更新兩個表的數據

[英]Laravel - combining multiple queries to update two table's data using single query

在我的一個Laravel項目中,我必須在函數的同一范圍內更新兩個表的數據。 在第一次查詢時,我正在嘗試使用以下查詢更新表的數據 -

        DB::table('parameters')
        ->where($where)
        ->update($data);

在第二個和第三個查詢中,我正在添加和減去另一個表的兩列 -

DB::table('categories')
            ->where(['id' => $data['category_id']])
            ->increment('parameters');

DB::table('categories')
            ->where(['id' => $previous_category_id])
            ->decrement('parameters');

一切都很好。 但是,現在我想在一次查詢執行中完成所有這些操作。

據我所知, 一個查詢無法做到這一點。

您基本上使用DB:table Facade運行MySQL UPDATE語句,如: UPDATE <table_name> SET <field_name>=<value> WHERE condition

正如您所看到的,UPDATE查詢恰好指向一個表,而不是更多。 因此,要更新多個表,您需要運行多個UPDATE查詢。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM