Commerceで歴代購入数/金額を集計する方法

カテゴリ Commerce コアバージョン 8.6.x 関連モジュール Commerce Payment Order
購入件数/購入額/購入時刻を得る
    $ltv_query = \Drupal::database()->select('commerce_payment', 'p')
      ->condition('p.state', 'completed');
    $ltv_query->join('commerce_order', 'o', "o.order_id = p.order_id");
    $ltv_query->condition('o.uid', $this->account->id());
    $order_count_query = clone $ltv_query;
    $order_count_query->condition('p.payment_gateway', 'THIS_GATEWAY', '');
    $last_order_query = clone $order_count_query;
    $last_order_query
      ->fields('p', ['amount__number', 'completed'])
      ->orderBy('p.completed', 'DESC')
      ->range(0, 1);
    $last_order = $last_order_query->execute()->fetchObject();
    $last_order_amount = $last_order->amount__number ?? 0;
    $last_order_at = $last_order->completed ?? REQUEST_TIME;

    $order_count = $order_count_query->countQuery()->execute()->fetchField(); // 購入件数(THIS_GATEWAY以外)
    $ltv = $ltv_query->countQuery()->execute()->fetchField(); // 購入件数
    $last_order_amount = floor($last_order_amount); // 直近の購入額
    $last_order_at = floor((REQUEST_TIME - $last_order_at) / (60*60*24)); // 直近の購入時刻

OTHER FAQ

Drupal開発・運用の疑問/質問の答えはここに

無料ユーザー登録すると質問できます。

カテゴリ Core Ver. 関連モジュール降順で並び替える タイトル
アップデート 8.8.x Composer composer updateが異常終了する
アップデート 8.9.x composer patch patch を composer に 組み込む方法
アップデート 8.9.x Composer update composer update するときに パッチが必要なモジュールが更新されパッチが消えてしまうことへ対応する方法
アップデート 8.9.x Composer update Composer で drupal/core-8.9.7 に更新できなくなった場合の処置
サイトの構築 7.23 Conditional fields ノード編集フォームを動的にしたい
コンテンツの管理 7.15 Content Access 簡単に閲覧制限を行うには?
サイトの構築 7.38 Content Template ページテンプレートが反映されません。
サイトの構築 7.27 Context block ページ別、カテゴリ別等でブロックの表示有無を簡単にするには
拡張機能 8.3x Contribute modules drupal8-寄贈モジュールの動向
テーマ 8.3x Contribute themes drupal8-寄贈テーマの動向
テーマ 8.3x Core Twig開発用の設定
アップデート 7.16 Core 7.15→7.16アップデート
アップデート 7.34 Core 簡単にCoreのセキュリティアップデートがしたい
権限 7.50 Cron Basic認証時のCron(wget)実行方法
コンテンツの作成 8.9.x CSS キャプション付きの(右寄/左寄)画像を画像サイズを基準にきれいに表示する方法
テーマ 7.15 CSS Injector 簡単にCSSを追加したい
Custom module 8.3x Custom module Twig Block Cache カスタムモジュールのレンダリングを非キャッシュ化する方法
コンテンツの作成 7.15 Darty Form 編集ページでの操作ミス
フォーム 7.15 DefaultTextForNode 新しいページの作成方法を一から教えてください
サイトの構築 7.38 deployment 冗長構成におけるアップロードおよび時間指定公開について

ページ