第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

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

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

慕容森 2019-06-28 09:56:52
SQL中是否有“l(fā)ike”和“in”的組合?在SQL i中(遺憾的是)經(jīng)常不得不使用“LIKE“由于數(shù)據(jù)庫違反了幾乎所有的標準化規(guī)則,我現(xiàn)在不能改變這種情況,但這與問題無關(guān)?!贝送?,我經(jīng)常使用以下條件WHERE something in (1,1,2,3,5,8,13,21)以提高SQL語句的可讀性和靈活性。有沒有可能在不寫復(fù)雜的子選擇的情況下將這兩件事結(jié)合起來?我想要像這樣簡單的東西WHERE something LIKE ('bla%', '%foo%', 'batz%')而不是這樣:WHERE something LIKE 'bla%'OR something LIKE '%foo%'OR something LIKE 'batz%'我在這里使用SQL Server和Oracle,但我感興趣的是,這在任何RDBMS中都是可行的。在SQL i中(遺憾的是)經(jīng)常不得不使用“LIKE“由于數(shù)據(jù)庫違反了幾乎所有的標準化規(guī)則,我現(xiàn)在不能改變這種情況,但這與問題無關(guān)?!贝送?,我經(jīng)常使用以下條件WHERE something in (1,1,2,3,5,8,13,21)以提高SQL語句的可讀性和靈活性。有沒有可能在不寫復(fù)雜的子選擇的情況下將這兩件事結(jié)合起來?我想要像這樣簡單的東西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條經(jīng)驗 獲得超8個贊

SQL中不存在like&IN的組合,而在TSQL(SQLServer)或PLSQL(Oracle)中則更沒有這種組合。部分原因是因為全文搜索(FTS)是推薦的選擇。

Oracle和SQL Server FTS實現(xiàn)都支持CONSE關(guān)鍵字,但語法仍然略有不同:

甲骨文:

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

SQLServer:

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

TA貢獻1811條經(jīng)驗 獲得超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.

但是.。

我不推薦我自己,因為不太好的表現(xiàn)。我會堅持幾個像謂詞一樣。所以這些例子只是為了好玩。


查看完整回答
反對 回復(fù) 2019-06-28
  • 3 回答
  • 0 關(guān)注
  • 17219 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號