「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > MySQL が非数値データの「フィールド = 0」をクエリするとすべての行を返すのはなぜですか?

MySQL が非数値データの「フィールド = 0」をクエリするとすべての行を返すのはなぜですか?

2024 年 11 月 5 日に公開
ブラウズ:478

Why Does MySQL Return All Rows When Querying \

あいまいなクエリ: MySQL が "Field=0" のすべての行を返す理由を理解する

MySQL クエリの分野では、一見無害な比較「SELECT * FROM table WHERE email=0」など、予期しない結果が生じる可能性があります。意図したように特定の行をフィルタリングするのではなく、テーブルからすべてのレコードが返されるため、データ セキュリティとクエリの整合性に関する懸念が生じます。

この複雑な動作を理解するには、データ型の微妙な点を詳しく掘り下げる必要があります。この場合は電子メール アドレスなど、数値以外のデータを含むフィールドをクエリする場合、MySQL はそれを数値に変換しようとします。 「0」は有効な電子メールではないため、MySQL はそれを数値のゼロとして解釈し、比較条件を効果的に無効にします。

その結果、クエリ SELECT * FROM table WHERE email=0 は、本質的にフィルタリング基準のないクエリになります。 、その結果、すべての行が取得されます。権限のない個人がこの脆弱性を悪用して機密データにアクセスできる可能性があるため、これはセキュリティに重大な影響を与える可能性があります。

幸いなことに、この曖昧さを回避する簡単な解決策があります。 「0」値を一重引用符で囲むことで、値を文字列として扱うことを明示的に指定し、適切な比較を保証します。

SELECT * FROM table WHERE email='0';

この変更により、MySQL は値を文字列として正しく比較し、電子メール値が「0」の行のみを返すようになります。

今後このような不一致を防ぐには、次の点に細心の注意を払うことが重要です。クエリに含まれるデータ型。文字列フィールドが文字列値と比較され、数値フィールドが数値と比較されることを常に確認してください。この簡単な予防策により、予期せぬ事態を回避し、データベース操作の正確性を確保できます。

リリースステートメント この記事は次の場所に転載されています: 1729730570 侵害がある場合は、[email protected] に連絡して削除してください。
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3