SQL Server:結合 LIKE
和 IN
進行資料過濾
本文探討如何在單一 SQL Server 查詢中有效地使用 LIKE
和 IN
運算子來進行精細的資料過濾。 需要注意的是,直接組合這些運算符並不簡單,因為它們的交互作用不同於使用多個通配符與 LIKE
.
了解 IN
運算子
IN
運算子可以有效地將欄位與一組指定值進行比較。例如:
<code class="language-sql">SELECT * FROM MyTable WHERE MyColumn IN (1, 2, 3);</code>
此查詢檢索 MyColumn
包含 1、2 或 3 的所有行。
組合 LIKE
和 IN
雖然直接組合 LIKE
和 IN
似乎合乎邏輯,但這種方法不受直接支援。 IN
運算子充當一系列 OR
條件。 因此:
<code class="language-sql">SELECT * FROM MyTable WHERE MyColumn LIKE IN ('Text%', 'Link%', 'Hello%', '%World%'); -- Incorrect</code>
不是有效的 SQL。 它的行為不像使用多個通配符。
正確的方法:使用多重OR
條件
要實現所需的過濾,請使用由 LIKE
:OR
連接的單獨
<code class="language-sql">SELECT * FROM MyTable WHERE MyColumn LIKE 'Text%' OR MyColumn LIKE 'Hello%' OR MyColumn LIKE 'That%';</code>
這會正確傳回 MyColumn
在列值內的任何位置包含「Text」、「Hello」或「That」作為子字串的行。 此方法提供了複雜模式匹配所需的靈活性和控制。
以上是如何在SQL Server中高效率組合LIKE和IN運算子進行資料過濾?的詳細內容。更多資訊請關注PHP中文網其他相關文章!