① sql中like的用法
LIKE是另一個在WHERE子句中會用到的指令。基本上,LIKE能讓我們依據一個套(pattern) 來找出我們要的資料。相對來說,在運用IN的時候,我們完全地知道我們需要的條件;在運用BETWEEN的時候,我們則是列出一個范圍。LIKE的語法如下:
② sybase資料庫的「like」用法是什麼
想在SQL LIKE里查詢有下劃線'_'或是'%'等值的記錄,直接寫成like 'XXX_XX',則會把'_'當成是like的通配符。
SQL里提供了 escape子句來處理這種情況,escape可以指定like中使用的轉義符是什麼,而在轉義符後的字元將被當成原始字元,這和C里的''很像,但是escape要求自定義一個轉義符,而不是指定了'』字元。
③ sybase資料庫的like用法
想在SQL LIKE里查詢有下劃線'_'或是'%'等值的記錄,直接寫成like 'XXX_XX',則會把'_'當成是like的通配符。SQL里提供了 escape子句來處理這種情況,escape可以指定like中使用的轉義符是什麼,而在轉義符後的字元將被當成原始字元,這和C里的'\'很像,但是escape要求自定義一個轉義符,而不是指定了'\』字元。
如:
select * from user_all_tables where table_name like 'YW__%' escape '_'
含義是查出當前用戶表下所有以'YW_'開頭的表,其中第一個'_'是轉義符,第二個是被轉義的字元,等效可以寫成:
select * from user_all_tables where table_name like 'YW\_%' escape '\'
④ 如何在資料庫里用like語句查詢成語
在SQL結構化查詢語言中,LIKE語句有著至關重要的作用。
LIKE語句的語法格式是:select * from 表名 where 欄位名 like 對應值(子串),它主要是針對字元型欄位的,它的作用是在一個字元型欄位列中檢索包含對應子串的。
A:% 包含零個或多個字元的任意字元串: 1、LIKE'Mc%' 將搜索以字母 Mc 開頭的所有字元串(如 McBadden)。
2、LIKE'%inger' 將搜索以字母 inger 結尾的所有字元串(如 Ringer、Stringer)。
3、LIKE'%en%' 將搜索在任何位置包含字母 en 的所有字元串(如 Bennet、Green、McBadden)。
B:_(下劃線) 任何單個字元:LIKE'_heryl' 將搜索以字母 heryl 結尾的所有六個字母的名稱(如 Cheryl、Sheryl)。
C:[ ] 指定范圍 ([a-f]) 或集合 ([abcdef]) 中的任何單個字元: 1,LIKE'[CK]ars[eo]n' 將搜索下列字元串:Carsen、Karsen、Carson 和 Karson(如 Carson)。
2、LIKE'[M-Z]inger' 將搜索以字元串 inger 結尾、以從 M 到 Z 的任何單個字母開頭的所有名稱(如 Ringer)。
D:[^] 不屬於指定范圍 ([a-f]) 或集合 ([abcdef]) 的任何單個字元:LIKE'M[^c]%' 將搜索以字母 M 開頭,並且第二個字母不是 c 的所有名稱(如MacFeather)。
E:* 它同於DOS命令中的通配符,代表多個字元:c*c代表cc,cBc,cbc,cabdfec等多個字元。
F:?同於DOS命令中的?通配符,代表單個字元 :b?b代表brb,bFb等
G:# 大致同上,不同的是代只能代表單個數字。k#k代表k1k,k8k,k0k 。
F:[!] 排除 它只代表單個字元
下面我們來舉例說明一下:
例1,查詢name欄位中包含有「明」字的。
select * from table1 where name like '%明%'
例2,查詢name欄位中以「李」字開頭。
select * from table1 where name like '李*'
例3,查詢name欄位中含有數字的。
select * from table1 where name like '%[0-9]%'
例4,查詢name欄位中含有小寫字母的。
select * from table1 where name like '%[a-z]%'
例5,查詢name欄位中不含有數字的。
select * from table1 where name like '%[!0-9]%'
以上例子能列出什麼值來顯而易見。但在這里,我們著重要說明的是通配符「*」與「%」的區別。
很多朋友會問,為什麼我在以上查詢時有個別的表示所有字元的時候用"%"而不用「*」?先看看下面的例子能分別出現什麼結果:
select * from table1 where name like '*明*'
select * from table1 where name like '%明%'
大家會看到,前一條語句列出來的是所有的記錄,而後一條記錄列出來的是name欄位中含有「明」的記錄,所以說,當我們作字元型欄位包含一個子串的查詢時最好採用「%」而不用「*」,用「*」的時候只在開頭或者只在結尾時,而不能兩端全由「*」代替任意字元的情況下。
⑤ 資料庫中LIKE的功能
like可以用來模糊查詢like abc% 其中%代表任意字元竄 like abc_ 其中_代表一個字元 like abc[1-9]代表一個數字從1到9 例子如select * from table1 where aaa like abc% 查詢table1表中以abc開頭的欄位
⑥ sql語句里「like」有沒有反向用法
沒有的。
⑦ 請問SQL中的like子句中可以使用的通配符有
SQL中的like子句中可以使用的通配符有:*、%、_。
LIKE 操作符用於在 WHERE 子句中搜索列中的指定模式。"%" 可用於定義通配符(模式中缺少的字母)。在搜索資料庫中的數據時,SQL 通配符可以替代一個或多個字元。SQL 通配符必須與 LIKE 運算符一起使用。
SQL LIKE 操作符語法:
SELECT column_name(s)
FROM table_name
WHERE column_name LIKE pattern
(7)資料庫中like擴展閱讀
1、選取居住在以 "Ne" 開頭的城市裡的人: select * from Persons where city like '%Ne'
2、從 "Persons" 表中選取居住在包含 "lond" 的城市裡的人: select * from Persons where city like '%lon%'
3、從上面的 "Persons" 表中選取名字的第一個字元之後是 "eorge" 的人:select * from Persons where FirstName like '_eorge'
4、從 "Persons" 表中選取的這條記錄的姓氏以 "C" 開頭,然後是一個任意字元,然後是 "r",然後是任意字元,然後是 "er":
select * from Persons where FirstName like 'C_r_er'
5、從上面的 "Persons" 表中選取居住的城市以 "A" 或 "L" 或 "N" 開頭的人:
select * from Persons where City like '[ALN]%'
6、從上面的 "Persons" 表中選取居住的城市不以"A" 或 "L" 或 "N" 開頭的人:
select * from Persons where City like '[!ALN]%'
7、從 "Persons" 表中選取居住在以 "g" 結尾的城市裡的人:
select * from Persons where City like '%g'
8、從 "Persons" 表中選取居住在不包含"lon" 的城市裡的人
select * from Persons where city not like '%lon%'
⑧ sql的like語句怎麼用
IKE 操作符用於在 WHERE 子句中搜索列中的指定模式。
SQL LIKE 語法
SELECT column_name(s)
FROM table_name
WHERE column_name LIKE pattern;
⑨ 資料庫like前匹配快還是in
資料庫前匹配快in。
like最差,特別是以%(有的資料庫是*)開頭的匹配,是無法進行索引的,只有順序掃描。
首先是=,表示值必須是一個特定的值。然後是in,表示值是幾個特定的值中的一個。最後是like,通過匹配來查找值。其實還有一個is,只為null使用。
SQL對like 操作中的特殊字元處理方法:
SQL Server查詢過程中,單引號 ' 是特殊字元,所以在查詢的時候要轉換成雙單引號 '' 。
在like操作還有以下特殊字元:下劃線_,百分號%,方括弧[],尖號^。 其用途如下:下劃線:用於代替一個任意字元(相當於正則表達式中的 ? ) 百分號:用於代替任意數目的任意字元(相當於正則表達式中的 * )。
方括弧:用於轉義(事實上只有左方括弧用於轉義,右方括弧使用最近優先原則匹配最近的左方括弧)。
尖號:用於排除一些字元進行匹配(這個與正則表達式中的一樣)。