共用方式為


[NOT] LIKE (Entity SQL)

判斷特定字元 String 是否符合指定的模式。

[NOT] LIKE ( expression )

引數

  • match
    評估為 String 的 實體 SQL 運算式。
  • pattern
    用來比對指定 String 的模式。
  • escape
    逸出字元。
  • NOT
    指定要否定 LIKE 的結果。

傳回值

如果 string 符合此模式則為 true;否則為 false

備註

使用 LIKE 運算子的 實體 SQL 運算式,其評估方式與使用等式做為篩選準則的運算式相同。不過使用 LIKE 運算子的 實體 SQL 運算式可以同時包括常值與萬用字元。

下表所述為模式 string 的語法。

萬用字元 描述 範例

%

任何包含零個或多個字元的 string

title like '%computer%' 會尋找標題中任何位置有單字 "computer" 的所有標題。

_ (底線)

任何單一字元。

firstname like '_ean' 會尋找所有四個字母且結尾為 "ean" 的名字,例如 Dean 或 Sean。

[ ]

在指定範圍 ([a-f]) 或集合 ([abcdef]) 中的任何單一字元。

lastname like '[C-P]arsen' 會尋找結尾為 "arsen" 且開頭為 C 和 P 之間任何單一字元的姓氏,例如 Carsen 或 Larsen。

[^]

不在指定範圍 ([^a-f]) 或集合 ([^abcdef]) 中的任何單一字元。

lastname like 'de[^l]%' 會尋找開頭為 "de" 且接下來的字母不包含 "l" 的姓氏。

Note附註

實體 SQL LIKE 運算子和 ESCAPE 子句不可套用到 System.DateTimeSystem.Guid 值。

LIKE 支援 ASCII 模式比對和 Unicode 模式比對。如果所有參數都是 ASCII 字元,便會執行 ASCII 模式比對。如果有任何引數不是 Unicode 資料類型,所有引數都會轉換成 Unicode,然後執行 Unicode 模式比對。使用 Unicode 配合 LIKE 時,尾端空白是有意義的;但是對於非 Unicode,尾端空白就無關重要了。實體 SQL 的模式字串語法與 Transact-SQL 相同。

模式可包括一般字元和萬用字元。在模式比對期間,一般字元必須與字元 string 中所指定的字元完全相符。不過,萬用字元可以符合任意字元字串片段。配合萬用字元使用時,LIKE 運算子會比 = 和 != 字串比較運算子更有彈性。

Note附註

如果您要針對特定的提供者,可以使用提供者專用的運算式。不過其他提供者可能會以不同方式處理這類建構。SqlServer 支援 [first-last] 和 [^first-last] 模式,前者會在最前與最後範圍之間恰好符合一個字元 (只能有一個字元相符),後者則是在最前與最後範圍之外恰好符合一個字元。

逸出

使用 ESCAPE 子句可以搜尋包含一或多個先前章節表格中所述特殊萬用字元的字元字串。舉例來講,假設有幾份文件的標題包含常值 "100%",而您想要搜尋所有這些文件。由於百分比 (%) 字元是萬用字元,所以您必須使用 實體 SQL ESCAPE 子句讓它逸出才能順利執行搜尋。以下就是這項篩選的範例。

"title like '%100!%%' escape '!'"

在這個搜尋運算式中,緊接在驚嘆號字元 (!) 後面的百分比萬用字元 (%)會被視為常值,而不是萬用字元。除了 實體 SQL 萬用字元和方括號 ([ ]) 字元以外,您可以使用任何字元做為逸出字元。在前面的範例中,驚嘆號 (!)字元就是逸出字元。

範例

下面兩個 實體 SQL 查詢使用 LIKE 和 ESCAPE 運算子來判斷特定的字元字串是否與指定的模式相符。第一個查詢會搜尋以字元 Down_ 開頭的 Name。這個查詢使用了 ESCAPE 選項,因為底線 (_) 是萬用字元。如果不指定 ESCAPE 選項,此查詢將會搜尋以單字 Down 開頭後面跟著任何單一字元 (底線字元除外) 的任何 Name 值。這些查詢是以 AdventureWorks Sales Model 為依據。若要編譯及執行此查詢,請遵循以下步驟:

  1. 按照 HOW TO:執行可傳回 PrimitiveType 結果的查詢 (EntityClient) 中的程序進行。

  2. 將下列查詢當成引數傳遞至 ExecutePrimitiveTypeQuery 方法:

// LIKE and ESCAPE
// If an AdventureWorksEntities.Product contained a Name 
// with the value 'Down_Tube', the following query would find that 
// value.
Select value P.Name FROM AdventureWorksEntities.Product 
    as P where P.Name LIKE 'DownA_%' ESCAPE 'A'

// LIKE
Select value P.Name FROM AdventureWorksEntities.Product 
    as P where P.Name like 'BB%'

另請參閱

概念

比較運算子 (Entity SQL)
Entity SQL 參考