亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

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“由于數據庫違反了幾乎所有的標準化規則,我現在不能改變這種情況,但這與問題無關?!贝送猓医洺J褂靡韵聴l件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 關注
  • 17242 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號