A. 在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字段中含有“明”的记录,所以说,当我们作字符型字段包含一个子串的查询时最好采用“%”而不用“*”,用“*”的时候只在开头或者只在结尾时,而不能两端全由“*”代替任意字符的情况下。
B. sql中"select ...like '%%' "问题,高手请进!!
%可以代表任意字符,但必须是字符.
NULL表示没有都没有.
所以,select * from table_name where column_name like '%%'
选不出来column_name为NULL的记录.
删除记录直接用delete from table_name就可以,你说的不行是什么不行?
C. SQL多个关键字模糊查询(同一字段中)如何让尽量多的关键字相匹配的搜索结果在前面
思路:
我的感觉是、google是用的页面后台代码解析字符串,构造SQL语句条件部分,最后传递给底层与数据库连接的部分
用or like '%keyword%'来查询
规搜索引擎是关键字中无空格就构造where aa like '%keyword%'
有空格出现就对字符串拆分,构造语句,后面的全用or like '%keyword%'
LZ试试在查询%是没有结果的
用诸如:%abc查出来的结果是忽略%号的
在SQL中用@name传参数的话,不许要对SQL关键字屏蔽,唯一的解释就是对字符串构造后组成的SQL语句
同时用这样的方法,对多参数的处理更容易
D. SQL 怎么实现模糊查询
1、首先需要开启数据库管理工具,打开SQL语言编写窗体。
E. sql 的like语句
like后面的匹配字符不加通配符 % 的话就跟 = 是一样的。
F. sql like搜索
搜索进行优化,建立索引,另外对于数据量比较大的要进行SQL分页
我的blog中有些SQL方面的搜集资料可以供你参考一下
http://hi..com/datachina/blog/item/50365b165015444e21a4e96d.html
G. SQL中like的用法
LIKE是另一个在WHERE子句中会用到的指令。基本上,LIKE能让我们依据一个套(pattern) 来找出我们要的资料。相对来说,在运用IN的时候,我们完全地知道我们需要的条件;在运用BETWEEN的时候,我们则是列出一个范围。LIKE的语法如下:
H. sql语句进行模糊查询时如何同时用一句话筛选多个关键词
1、创建测试表,create table test_a(zlyt varchar2(20));
(8)sqllike关键字扩展阅读
1、在进行数据库查询时,有完整查询和模糊查询之分。
一般模糊查询语句如下:SELECT 字段 FROM 表 WHERE 某字段 Like 条件,其中关于条件,SQL提供了四种匹配模式:
1)% :表示任意0个或多个字符。可匹配任意类型和长度的字符,有些情况下若是中文,请使用两个百分号(%%)表示。
2)_ : 表示任意单个字符。匹配单个任意字符,它常用来限制表达式的字符长度语句:
3)[ ] :表示括号内所列字符中的一个(类似正则表达式)。指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。
4)[^ ] :表示不在括号所列之内的单个字符。其取值和 [] 相同,但它要求所匹配对象为指定字符以外的任一个字符。
2、REPLACE官方语法:
REPLACE ( string_expression , string_pattern , string_replacement )
1)参数含义:
string_expression 要搜索的字符串表达式。string_expression 可以是字符或二进制数据类型。
string_pattern 是要查找的子字符串。string_pattern 可以是字符或二进制数据类型。string_pattern 不能是空字符串 ('')。
string_replacement 替换字符串。string_replacement 可以是字符或二进制数据类型。
2)返回类型:
如果其中的一个输入参数数据类型为 nvarchar,则返回 nvarchar;否则 REPLACE 返回 varchar。
如果任何一个参数为 NULL,则返回 NULL。
REPLACE(String,from_str,to_str) 即:将String中所有出现的from_str替换为to_str。
I. SQL LIKE模糊查询
--下面这个应该是可以的!
create proc procget --[存储过程名]
@proc1 varchar(50),--这个是一定要存在的参数
@proc2 varchar(50),
@proc3 varchar(50)
as
--定义一个要执行的字符串语句
declare @aa varchar(200)
set @aa = 'select * from TA where ' + '[表中的列名] like ' + '''%' + @proc1 + '%'''
--组合要执行的语句
--如果参数为空,就加上字符空串,否则就加上相应的条件语句
set @aa = @aa + case when @proc2 is null then '' else ' and [表中列名] like'+'''%'+@proc2+ '%''' end
set @aa = @aa + case when @proc3 is null then '' else ' and [表中列名] like'+'''%'+@proc3+ '%''' end
--执行语句
exec(@aa)
J. SQL如何用LIKE查询出多个没有相同关键字的字符串,如100后面加任意3个字符,200后面加任意3个字符
是这个意思吗
select * from table1 where col1 like '[1-2]00___'
以上这种写法就是类似列表的,in里是不能用通配符来实现这种功能的。