Viewsクエリの条件式にサブクエリを追加する方法

カテゴリ Views コアバージョン 8.4x 関連モジュール hook_views_query_alter

modules/custom/your_module/your_module.module

/**
 * @param \Drupal\views\ViewExecutable $view
 * @param \Drupal\views\Plugin\views\query\QueryPluginBase $query
 */
function your_module_views_query_alter(ViewExecutable $view, QueryPluginBase $query) {
  if ($view->id() == 'your_view_id') {
    $query->addWhereExpression(
      $whereGroup,
      'node__field_xxxxx_value = (' .
      'SELECT MAX(c.field_yyyyy_value) FROM node__field_yyyyy c ' .
      'INNER JOIN node__field_zzzzz i ON i.entity_id = c.entity_id AND i.deleted = 0 ' .
      'WHERE c.deleted = 0 ' .
      'AND i.field_zzzzz_value = node__field_zzzzz.field_zzzzz_value' .
      ')');
  }
}

OTHER FAQ

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

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

カテゴリ Core Ver. 関連モジュール降順で並び替える タイトル
テーマ 8.3x Theme drupal8 で パスに応じたページテンプレート名を利用する方法
token 7.34 token オリジナルモジュールからtokenを提供する方法を教えて下さい。
Token 8.4x Token カスタムモジュールからtokenを提供する方法(drupal8版)
テーマ 8.9.x Twig Twig で 月末日を算出する方法
ユーザ 7.23 User 長い投稿者名の表示が切れる
ユーザ 7.38 user form 新規ユーザー登録時、パスワード再設定時のパスワード入力抜けを防ぎたい
ユーザの管理 7.59 user pass drupal 7 で 管理者(uid=1)パスワードがわからなくなったとき 新しいパスワードを設定する方法
ユーザの管理 8.9.x user pass drupal 8 で 管理者(uid=1)パスワードがわからなくなったとき 新しいパスワードを設定する方法
video 8.4x video map 動画上にクリッカブルマップを作成する方法
Viewsプログラミング 8.6.x Views Drupal8 Viewsの動的キャッシュをクリアする方法
コンテンツの作成 6.x Views カルーセルのように回転するコンテンツを作りたい
ブロック 7.15 Views ひとつのViewsをページやブックページ中で再利用する方法は?
コンテンツの作成 7.38 Views CSV出力にHTMLが入ってしまう
フォーム 8.9.x Views Views exposed filterのフォームに#default_valueを仕込む方法
フォーム 7.38 Views Views一覧の絞り込み検索フォームで複数フィールドを対象にしたい
Viewsプログラミング 8.4x Views drupal8におけるViewsプログラミング
サイトの構築 7.31 Views ブロックViewsの絞り込みが表示されない
アップデート 7.28 Views Pagerが表示されなくなった
サイトの構築 7.22 Views フィールドセットの伸縮をノンプログラミングでやりたい
表示 7.26 Views ページ内に2つ目Viewsブロックを設置するときPagerが連動してしまう

ページ