sql中like語句詳解

2021-06-15 22:50:28 字數 1436 閱讀 5305

like

確定給定的字串是否與指定的模式匹配。模式可以包含常規字元和萬用字元字元。模式匹配過程中,常規字元必須與字串中指定的字元完全匹配。然而,可使用字串的任意片段匹配萬用字元。與使用 = 和 != 字串比較運算子相比,使用萬用字元可使 like 運算子更加靈活。

如果任何引數都不屬於字串資料型別,microsoft® sql server™ 會將其轉換成字串資料型別(如果可能)。 語法

match_expression [ not ] like pattern [ escape escape_character ]

引數match_expression

任何字串資料型別的有效 sql server 表示式。

pattern

match_expression 中的搜尋模式,可以包含下列有效 sql server 萬用字元。

萬用字元 描述 示例

% 包含零個或更多字元的任意字串。 where title like '%computer%' 將查詢處於書名任意位置的包含單詞 computer 的所有書名。

_(下劃線) 任何單個字元。 where au_fname like '_ean' 將查詢以 ean 結尾的所有 4 個字母的名字(dean、sean 等)。

[ ] 指定範圍 ([a-f]) 或集合 ([abcdef]) 中的任何單個字元。 where au_lname like '[c-p]arsen' 將查詢以arsen 結尾且以介於 c 與 p 之間的任何單個字元開始的作者姓氏,例如,carsen、larsen、karsen 等。

[^] 不屬於指定範圍 ([a-f]) 或集合 ([abcdef]) 的任何單個字元。 where au_lname like 'de[^l]%' 將查詢以 de 開始且其後的字母不為 l 的所有作者的姓氏。

escape_character

字串資料型別分類中的所有資料型別的任何有效 sql server 表示式。escape_character 沒有預設值,且必須僅包含乙個字元。

結果型別

boolean

結果值如果 match_expression 匹配指定模式,like 將返回 true。

注釋當使用 like 進行字串比較時,模式字串中的所有字元都有意義,包括起始或尾隨空格。如果查詢中的比較要返回包含"abc "(abc 後有乙個空格)的所有行,則將不會返回包含"abc"(abc 後沒有空格)的列所在行。但是可以忽略模式所要匹配的表示式中的尾隨空格。如果查詢中的比較要返回包含"abc"(abc 後沒有空格)的所有行,則將返回以"abc"開始且具有零個或多個尾隨空格的所有行。

由於資料儲存方式的原因,使用包含 char 和 varchar 資料模式的字串比較可能無法通過 like 比較。了解每種資料型別的儲存方式以及導致 like 比較失敗的原因十分重要。下面的示例將區域性 char 變數傳遞給儲存過程,然後使用模式匹配查詢某個作者的所有著作。在此過程中,作者的姓將作為變數傳遞。

sql語句like的用法

在sql結構化查詢語言中,like語句有著至關重要的作用。like語句的語法格式是 select from 表名 where 欄位名 like 對應值 子串 它主要是針對字元型字段的,它的作用是在乙個字元型字段列中檢索包含對應子串的。假設有乙個資料庫中有個表table1,在table1中有兩個字段,...

Oracle常用sql語句 like

在where子句中,可以對datetime char varchar欄位型別的列用like子句配合萬用字元選取那些 很像 的資料記錄,以下是可使用的萬用字元 零或者多個字元 單一任何字元 下劃線 特殊字元 在某一範圍內的字元,如 0 9 或者 aeth 不在某範圍內的字元,如 0 9 或者 aeth...

Sql語句中LIKE的巢狀用法詳解

oracle中sql語句like語句的語法格式是 select from 表名 where 欄位名 like 對應值 子串 例 查詢name欄位中含有 林 字的 select from 表名 where name like 林 但是,我此次like關鍵字後面的對應值是乙個變數,需要用select語句...