これは私の最初の質問ですので、私にご負担ください。イベントリスナーを作成して別のデータベーステーブルを更新する
Sonataを使用して注文テーブル内で注文を作成または更新するときに、ログテーブルを更新するためにpostPersistイベントリスナーを実装する方法を教えてください。
私は、新しい注文を作成するとすぐprePersistを使用して同じデータベーステーブルに情報を追加する方法を理解しています。 (次のコードスニペットを参照してください)
public function prePersist(LifecycleEventArgs $args)
{
$order = $args->getEntity();
if ($order instanceof PmodOrder) {
$user = $this->serviceContainer->get('security.token_storage')->getToken()->getUser();
if ($user) {
$order->setCreatedBy($user);
$order->setCreatedAt(new \DateTime(date('Y-m-d H:i:s')));
}
}
}
しかし、私は完全に別のテーブルを更新するとき、それは同じエンティティではありませんので、私は、これを行うだろうか理解していません。
注文が作成された瞬間(私は思うが)、postPersistはその注文IDといくつかの追加情報で別のテーブルを更新する必要があります。
私はこのような行の間に何かを考えます。
私は忙しい現在の注文を取得する方法がわかりません。そして、ユーザーが注文を変更したときにsetActionが何か他のものになる方法。たとえば、「編集済み」または「承認済」などです。私は何かを読んでいない限り、運がないソナタの資料を通っています。
私はSonataを使用することを覚えておいてください。さもなければ、これは私自身のController Actionsで実装するのが簡単でした。
ありがとうございました。私は今それを試してみるつもりです(週末にはテストできませんでした)。私はログが完全な他のエンティティであるという事実をどうやってそれにするのかをかなり理解していません。 –
リスナーは新しいエンティティではありません。リスナーを作成すると、リスナー(これはここではOrder)をリスナーにリンクするために、エンティティの上部に注釈を追加するだけです(私の答えの最後のコードブロックを参照)。しかし、すべての変更情報を格納する新しいエンティティを追加したい場合は、(たとえばOrderLogクラスのように)行うことができます。 –
ありがとう、私は今それを得る。 –