挿入または更新してから、新しいログを別のテーブルに挿入したい。
ステージングテーブルから他のテーブルに情報をプルするための気の利いた小さなクエリを実行しています。
重複キーの更新時にselectに挿入
私がphpまたはトリガーなしでやりたいこと(リード開発者はemが好きではなく、私もそれらに精通していません)は、新しいレコードをロギングテーブルに挿入することです。どのデータが更新または挿入されたか、およびどのテーブルについて報告するために必要です。
ヒントや例はありますか?
注:5万行の処理には約4時間かかりましたが、これはphpで問題なく実行していました。laravel phpフレームワークを使用して、ステージングの各エントリをループすると、他の4つのテーブルのデータとログが、各行に対して8つのクエリに等しくなります(これは、raw sqlではなくlaravelモデルを使用していました)。ログを配列にプッシュしてバッチ処理することで最適化することができました。しかし、そのスループットをすべてバイパスすることによって、mysqlの15秒の処理時間を打ち負かすことはできません。今、私はSQLの方法で素晴らしいことをすることに夢中になっています。