模糊查询和in的组合使用

假如我们有这样的一个表:

然后我们想要查询姓名里面(图中红框)名字以A,B,C开头的姓名的全部信息:

我们一般会这样写:

select * from emp where ename like  'A%' or ename like 'B%' or ename like 'C%';

但是如果需要很多这样的字符串的模糊查询呢。

我们可能会想到用 in 关键字,但是in关键字和like关键字是没有办法直接一起使用的。

所以我们想到了一种解决办法:

select * from emp where name like substr(name,0,1) in ('A','B','S');

通过截取字符串来配合like和in的使用来达到我们的目的。

在Oracle中,使用LIKE关键字进行模糊查询可以匹配多个字符,你可以使用通配符“%”来代表任意字符或字符序列。例如,如果你想查询所有以字母J开头并以字母S结尾的名字,可以使用以下语句: SELECT ENAME, JOB, SAL FROM EMP WHERE ENAME LIKE 'J%S'; 这个查询会返回所有满足条件的员工的姓名、职位和薪水。 同时,你也可以在LIKE语句中使用IN关键字进行多个模糊查询。例如,如果你想查询所有名字以A开头或者以B开头的员工,可以使用以下语句: SELECT ENAME, JOB, SAL FROM EMP WHERE ENAME LIKE 'A%' OR ENAME LIKE 'B%'; 这个查询会返回所有满足条件的员工的姓名、职位和薪水。使用OR关键字可以实现多个模糊查询的条件组合。 需要注意的是,在使用LIKE语句进行模糊查询时,可以使用ESCAPE关键字来指定转义字符,以防止通配符被误解。你可以在LIKE语句后面加上"ESCAPE '字符'"来指定转义字符。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Oracle:like模糊查询](https://blog.csdn.net/oraclestudyroad/article/details/52179501)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值