like 操作中对于'_'处理

本文介绍了在Oracle数据库中使用LIKE操作时如何正确处理特殊通配符的情况。特别是当需要排除包含下划线(_)的表名时,如何进行正确的SQL语句编写。通过两个不同的方法解决了这一问题,并提供了相关资源链接。

ORACLE对于like操作,默认%代表通配任意字符或任意N个字符。_代表通配任意一个字符。

只所以提到这个,是因为今天跟网闸公司的人确认我们的数据库中有多少表需要同步,我就写了如下的一条语句,想查到不带_的表。

select * from user_tables where table_name not like '%_%';

可是输入结果为空,实际上我们库里绝大多数表都是不带_的。

我这才意识到_肯定是特殊字符,需要转义。

上网查询资料后,知道正确写法应为:

select * from user_tables where table_name not like '%\_%' escape '\';

其中\可以为任意字符。

也可以这样写:

select * from user_tables where instr(table_name,_)=0;

参考文章:http://space.itpub.net/519536/viewspace-621900

http://www.hackhome.com/InfoView/Article_204376.html

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22034023/viewspace-662248/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/22034023/viewspace-662248/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值