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。

温馨提示:内容为网友见解,仅供参考
第1个回答  推荐于2017-11-28
你自己都说了,使用模糊查询就可以了。
如果是查询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,谢谢!

本回答被提问者采纳

Warning: Invalid argument supplied for foreach() in /www/wwwroot/www.t2y.org3v3b34/skin/templets/default/contents.html on line 47
相似回答