为了账号安全,请及时绑定邮箱和手机立即绑定

SQL中是否有“like”和“in”的组合?

SQL中是否有“like”和“in”的组合?

慕容森 2019-06-28 09:56:52
SQL中是否有“like”和“in”的组合?在SQL i中(遗憾的是)经常不得不使用“LIKE“由于数据库违反了几乎所有的标准化规则,我现在不能改变这种情况,但这与问题无关。”此外,我经常使用以下条件WHERE something in (1,1,2,3,5,8,13,21)以提高SQL语句的可读性和灵活性。有没有可能在不写复杂的子选择的情况下将这两件事结合起来?我想要像这样简单的东西WHERE something LIKE ('bla%', '%foo%', 'batz%')而不是这样:WHERE something LIKE 'bla%'OR something LIKE '%foo%'OR something LIKE 'batz%'我在这里使用SQL Server和Oracle,但我感兴趣的是,这在任何RDBMS中都是可行的。在SQL i中(遗憾的是)经常不得不使用“LIKE“由于数据库违反了几乎所有的标准化规则,我现在不能改变这种情况,但这与问题无关。”此外,我经常使用以下条件WHERE something in (1,1,2,3,5,8,13,21)以提高SQL语句的可读性和灵活性。有没有可能在不写复杂的子选择的情况下将这两件事结合起来?我想要像这样简单的东西WHERE something LIKE ('bla%', '%foo%', 'batz%')而不是这样:WHERE something LIKE 'bla%'OR something LIKE '%foo%'OR something LIKE 'batz%'我在这里使用SQL Server和Oracle,但我感兴趣的是,这在任何RDBMS中都是可行的。
查看完整描述

3 回答

?
弑天下

TA贡献1818条经验 获得超8个赞

SQL中不存在like&IN的组合,而在TSQL(SQLServer)或PLSQL(Oracle)中则更没有这种组合。部分原因是因为全文搜索(FTS)是推荐的选择。

Oracle和SQL Server FTS实现都支持CONSE关键字,但语法仍然略有不同:

甲骨文:

WHERE CONTAINS(t.something, 'bla OR foo OR batz', 1) > 0

SQLServer:

WHERE CONTAINS(t.something, '"bla*" OR "foo*" OR "batz*"')
查看完整回答
反对 回复 2019-06-28
?
波斯汪

TA贡献1811条经验 获得超4个赞

如果希望使语句易于读懂,则可以使用REGEXP_like(可从Oracle版本10开始)。

一个示例表:

SQL> create table mytable (something)
  2  as
  3  select 'blabla' from dual union all
  4  select 'notbla' from dual union all
  5  select 'ofooof' from dual union all
  6  select 'ofofof' from dual union all
  7  select 'batzzz' from dual  8  /Table created.

原始语法:

SQL> select something  2    from mytable  3   where something like 'bla%'
  4      or something like '%foo%'
  5      or something like 'batz%'
  6  /SOMETH------blabla
ofooof
batzzz3 rows selected.

和一个简单的REGEXP_like查询

SQL> select something  2    from mytable  3   where regexp_like (something,'^bla|foo|^batz')
  4  /SOMETH------blabla
ofooof
batzzz3 rows selected.

但是.。

我不推荐我自己,因为不太好的表现。我会坚持几个像谓词一样。所以这些例子只是为了好玩。


查看完整回答
反对 回复 2019-06-28
  • 3 回答
  • 0 关注
  • 17108 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信