sql语句进行模糊查询时如何同时用一句话筛选多个关键词

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql语句进行模糊查询时如何同时用一句话筛选多个关键词相关的知识,希望对你有一定的参考价值。

例如,有一列数据 zlyt,类型为varchar,我想用sql语句批量改变其值.

比如取值有abc,dfs,rte.如何用一句话将值中包括b和f的字段全部选出来并批量改变其取值

1、创建测试表,create table test_a(zlyt varchar2(20));

2、插入测试数据,并提交;

insert into test_a values('abc');

insert into test_a values('dfs');

insert into test_a values('rte');

commit;

3、执行sql语句,

select zlyt, replace(replace(zlyt, 'b', 'x'), 'f', 'x') zlyt2

  from TEST_A t

 where zlyt like '%b%'

    or zlyt like '%f%'

扩展资料

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。

参考技术A 你自己都说了,使用模糊查询就可以了。
如果是查询zlyt中含有b或f可以这样写:
select * from 表名 where zlyt like '%b%' or zlyt like '%f%'
如果是查询zlyt中含有b和f可以这样写:
select * from 表名 where zlyt like '%b%f%' or zlyt like '%f%b%';
不同的是先后顺序,根据你的情况自己可能需要调整

更新:
update 表名 set 字段名 = 修改后的新值
where zlyt like '%b%' or zlyt like '%f%';
where条件可以参考上面select中where条件的写法,看你要匹配的规则。追问

哦,我写的语句中间直接加的or 没有zylt like,谢谢!

本回答被提问者采纳

SQL多个条件查询语句

设计了一个如图的查询项
如只填写地类编码(DLBM),则只搜索DLBM,其他不搜索
如果填写了多项(如地类编码DLBM和地类名称DLMC),则搜索DLBM and DLMC
想知道有什么语句能够实现这个功能么?就是将非空的textbox才作为搜索项
个人编程水平较差..只能想到用if 语句进行排列组合判断,感觉非常繁琐,效率也很低
所以特来求助

1、首先我们打开电脑里的SQL打开一个数据库。

2、然后我们点击界面上方菜单栏里的表选项打开数据库的一张表进行查询。

3、然后我们选择表右上角的加号键。

4、然后我们在编辑器中输入如图所示代码进行数据查询。

5、然后我们点击运行查看运行结果。

6、多条件查询最终结果如图所示我们可以看到多条件查询语句成功。

参考技术A Declare @DLBM nvarchar(255),@DLMC nvarchar(255)
set @DLBM='查询内容'
set @DLMC='查询内容'
select  * from 表名称 where DLBM=@DLBM and len(@DLBM)>0
union
select  * from 表名称 where DLMC=@DLMC and len(@DLMC)>0
.......拼接全部条件追问

编译出现以上错误..应该是SQL语句错误..麻烦请看下哪里应该修改

追答

你写的不对,不是给你定义了变量嘛,把数据放在
set @DLBM='查询内容'
set @DLMC='查询内容'

你的语法问题
两个SQL 拼 union 两头 都不需要分号,只要空格就可以

追问

这是在c#中调用的啊,变量在之前定义过了..
就是不知道C#中SQL语句具体怎么写

追答

string Sql="select * from dltb where 1=1 ";
if( DLBM.Length>0)
Sql+=" and DLBM='"+DLBM+"' ";
if( TBBH.Length>0)
Sql+=" and TBBH='"+TBBH+"' ";

本回答被提问者和网友采纳
参考技术B 你都用在一张表里面嘛追问

是来自同一张表的数据

追答

你可以这样写 select * from table where DLBM like ‘%+“DLBM”+%’ and DLMC like ‘%+“DLMC”+%’ and ·······但是影响查询效率。

以上是关于sql语句进行模糊查询时如何同时用一句话筛选多个关键词的主要内容,如果未能解决你的问题,请参考以下文章

sql查询语句如何能让cpu一下跑满

关于sql模糊查询(全字段)

多选择筛选查询SQL语句怎么写

SQL:一个表多列模糊查询

sql语句中条件查询里in、like、及=三个的效率怎么样?

模糊查询中含有单引号