在sql語句中,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 。
下麵我們來舉例說明一下:
例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字段中含有“明”的記錄,所以說,當我們作字符型字段包含一個子串的查詢時最好采用“%”而不用“*”,用“*”的時候隻在開頭或者隻在結尾時,而不能兩端全由“*”代替任意字符的情況下。
SQL like的反義詞,篩選like以外的詩句
select * from ccb where age = 23 and name not like '%陳成%'
not like...
祝你成功!
sql 的like語句
like後麵的匹配字符不加通配符 % 的話就跟 = 是一樣的。
SQL語句中“like”和“=”在判定字符串時候的效率問題
“like”後麵的格式字符串如果不含通配符“?、%”,從功能上講等同於比較符“=”。
學過算法的人都知道,每個比較運算都要用一段小程序來實現。“like”比“=”的算法要複雜,要消耗更多的係統資源。所以說,如果“like”後麵的格式字符串不含通配符“?、%”,最好是用“=”,否則,效率較低。
sql語句中的like語句中%和*的區別
*是一個實際的字符,而%是通配符,兩個不是一個概念
sql中的通配符%才代表任意字符,*在sql中沒有通配符的意思,雖然在像DOS環境之類下是代表任意字符的意思
elect * from sysuser a where a.login_name like 'sys*';
等於
select * from sysuser a where a.login_name = 'sys*';
SQL中like的用法
LIKE?是另一個在?WHERE?子句中會用到的指令。基本上,LIKE?能讓我們依據一個套(pattern) 來找出我們要的資料。相對來說,在運用?IN?的時候,我們完全地知道我們需要的條件;在運用?BETWEEN?的時候,我們則是列出一個範圍。?LIKE?的語法如下:
一下是具體應用:
1、like中or的應用:or指或者的意思,如果sql語句中用到這個連接字符,就說明查詢的結果隻要符合其中一種條件就可以。
例:SELECT t1? FROM table_test WHERE t1 LIKE '%a%' OR t1 LIKE '%b%'
2、like中and的應用:and指並且的意思,如果sql語句中用到這個連接字符,就說明查詢的是要完全符合sql語句中所有連接條件的數據。
例:SELECT t1? FROM table_test WHERE t1 LIKE '%a%' AND? t1 LIKE '%b%'
3、like中多個條件的拚接:如果sql語句中同時用逗號分開多個條件,結果根據實際表的值與結構決定。如果想要通過這種方式得到想要的結果值,需要反複的測試,否則結果會有偏差。
例:SELECT t1? FROM table_test WHERE t1 LIKE '%a%,%b%'
4、like語句的應用:用於篩選一些相似的信息或者是查詢樹形結構表數據時,是個很不錯的方式。
5、like的使用:雖然like有時在sql語句中還是很方便的可以找到自己想要的結果,但是在使用時也要考慮到sql的性能問題。
請教sql語句中not like的用法
標準SQL中用like進行模糊查詢,有兩個通配符:%百分號代表任意個字符,_下劃線代表一個字符。
例如查詢姓名中包含“曉”的人,where子句可以寫成:where name like '%曉%'
姓名由兩個字構成,並且第二個字是“紅”,可以寫成:where name like '_紅'
如果對like進行否定,前麵加上not即可
查詢姓名中不包含“曉”的人:where name not like '%曉%'
姓名由兩個字構成,第二個字不是“紅”:where name not like '_紅'
sql查詢語句Like 的問題
SQL裏麵模糊匹配要用%,所以必須是‘品牌%’
你受正則表達式的影響了
SQL模糊查詢Like語句中可以用變量嗎
sql的模糊查詢like字句是可以的使用變量的。
如圖:
使用 + 號連接變量,或者在變量中添加 % 都可以,如
declare?@test?varchar(20)
set?@test?=?'李%'
select?b?from?a?where?b?like?@test
sql 模糊查詢方法 sql語句裏like有沒有反向用法?
下麵方法試試:
SELECT * FROM 表 WHERE '字符串' LIKE CONCAT('%',字段,'%')
轉載請注明出處句子大全網 » 在sql語句中,like所有的用法