ホームページ >データベース >mysql チュートリアル >PHP でデータベース値を「NULL」と比較すると期待どおりに機能しないのはなぜですか?

PHP でデータベース値を「NULL」と比較すると期待どおりに機能しないのはなぜですか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-10-30 08:47:27958ブラウズ

Why Does Comparing a Database Value to

PHP で NULL 値を適切にチェックする方法

データベースの結果を操作する場合、意図しないエラーを避けるために NULL 値を正確にチェックすることが重要です。結果。これが発生する一般的なシナリオの 1 つは、NULL 値の有無に基づいて HTML 要素をレンダリングする場合です。

次の PHP コードを考えてみましょう。

<code class="php">$query = mysql_query("SELECT * FROM tablex");

if ($result = mysql_fetch_array($query)){

    if ($result['column'] == NULL) { print "<input type='checkbox' />"; }
    else { print "<input type='checkbox' checked />"; }
}</code>

この例では、コードは次のことを試みます。クエリされた行の「column」フィールドが NULL でない場合、チェックされたチェックボックスを表示します。ただし、「列」フィールドが NULL でない場合でも、表示されるチェックボックスはオフのままになります。この動作は予期しないように思えるかもしれません。

この問題を解決するには、NULL 値を明示的にチェックする演算子を使用する必要があります。 == 演算子は厳密な等価性をチェックします。つまり、型と値が一致する必要があります。ただし、この場合、値はリテラル文字列 'NULL' と照合され、常に誤った比較が行われます。

NULL 値を正しくチェックするには、次のいずれかの方法を使用できます。

1. is_null() 関数:

<code class="php">is_null($result['column'])</code>

2. === 演算子:

<code class="php">$result['column'] === NULL</code>

これらのメソッドはどちらも NULL 値を正確にチェックし、フィールドが NULL でない場合に意図したとおりにチェックされたチェックボックスを表示できます。

NULL 値をチェックするときは、誤解を避けるために、is_null() や === など、この条件を特別にテストする演算子を使用することが重要であることに注意してください。

以上がPHP でデータベース値を「NULL」と比較すると期待どおりに機能しないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。