web-dev-qa-db-ja.com

結合してNULL値を探す

私はフラグモジュールを使用して、このサイトでの動作と同様に、ユーザーが質問を解決済みとしてマークできるようにしています。したがって、ユーザーが投稿をフィルタリングして、未解決の質問のみを表示できるようにしたいと考えています。さらに、一部の投稿はまったく質問ではない場合があります。したがって、「解決済み」のフラグを設定することはできませんが、未解決の質問のみでフィルタリングする場合は結果に表示されません。したがって、ノードテーブルを他の2つのflag_contentおよびfield_data_field_questionと結合する必要があります(この後者のテーブルは、投稿が質問であるかどうかを示すものです)。

これが私が試している現在のコードです:

$query->join('flag_content', 'f', 'f.content_id = n.nid AND f.content_type = "node" AND f.fid = 5');
$query->join('field_data_field_question', 'q', 'q.entity_id = n.nid AND q.field_question_value = 1');
$query->condition('f.fid', 'NULL', 'IS');
$query->condition('q.field_question_value', 'NULL', 'IS NOT');

ただし、これにより次のエラーが発生します。

PDOException: SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''NULL') AND (q.field_question_value IS NOT 'NULL')
LIMIT 21 OFFSET 0' at line 4: SELECT n.nid AS nid
FROM
{node} n
INNER JOIN {field_data_field_category} t ON t.entity_id = n.nid
INNER JOIN {flag_content} f ON f.content_id = n.nid AND f.content_type = "node" AND f.fid = 5 
INNER JOIN {field_data_field_question} q ON q.entity_id = n.nid AND q.field_question_value = 1
WHERE (t.field_category_tid = :db_condition_placeholder_0) AND (f.fid IS :db_condition_placeholder_1) AND (q.field_question_value IS NOT :db_condition_placeholder_2)
LIMIT 21 OFFSET 0; Array 
( [:db_condition_placeholder_0] => 464 [:db_condition_placeholder_1] => NULL [:db_condition_placeholder_2] => NULL
)
in queryExecuteRender_recentActivity() (line 57 of someFile.php).

これは、NULL値をクエリに渡す正しい方法ではありませんか?

18
maxedison

データベースAPIには、実際にはこのタイプの式を追加するための推奨される方法、つまり SelectQuery::isNull() および SelectQuery::isNotNull() 関数があります。次のように使用できます。

$query->isNull('f.fid');

$query->isNotNull('q.field_question_value');
31
Clive