過濾 MySQL SELECT 語句中的空值
MySQL 查詢通常需要從結果集中排除空值。 標準 SELECT
語句包含所有行,不論是否為空。
IS NOT NULL
解
最直接的方法是使用 IS NOT NULL
運算子。 此運算子過濾指定列不為空的行。 例如:
<code class="language-sql">SELECT * FROM your_table WHERE your_column IS NOT NULL;</code>
替代技術
除了IS NOT NULL
之外,其他幾種方法也達到了相同的結果:
<code class="language-sql">SELECT * FROM your_table WHERE NOT (your_column <=> NULL);</code>
UNION ALL
具有多個 SELECT
語句: 當您需要跨多個欄位選擇非空值時,此方法非常有用。 <code class="language-sql">SELECT col1 AS value FROM your_table WHERE col1 IS NOT NULL UNION ALL SELECT col2 FROM your_table WHERE col2 IS NOT NULL -- Repeat for all columns</code>
CASE
有HAVING
子句的語句:此方法為複雜場景提供了更大的彈性。 <code class="language-sql">SELECT CASE column_index WHEN 1 THEN col1 WHEN 2 THEN col2 END AS value FROM your_table JOIN (SELECT 1 AS column_index UNION ALL SELECT 2) AS index_table HAVING value IS NOT NULL;</code>
這些方法提供了直接從 MySQL 中僅檢索非空資料的有效方法,而無需在 PHP 等應用程式程式碼中進行後處理。
以上是如何在 MySQL 中有效率地僅選擇非空值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!