国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Oracle > 正文

Oracle如何實現like多個值的查詢

2024-08-29 14:01:09
字體:
來源:轉載
供稿:網友

問題背景描述:

某天客戶有一個需求,給定一批的手機號碼或者電話號碼,查詢出相關的通話記錄,以及相關的一些信息。

客戶給定的被叫號碼如圖所示:

Oracle,like,查詢

查詢出來的結果如下圖所示(本批次的結果不是上圖導入的結果查詢的,為了格式說明,因此導入兩張結果不相關的圖片):

Oracle,like,查詢

由于客戶給的被叫號碼很不規范,查詢的時候比較麻煩。

分析過程:

我新建了一個表security_phonebill_callee_num,用以存放導入的被叫號碼信息

所有的通話數據保存在t_phonebill_201702中,想要查詢必須要實現like,就是以下sql的實現效果

select org_caller_num,org_callee_num,call_seconds,start_time,switch_id,in_trunk,out_trunk,settle_carrier,file_namefrom t_phonebill_201702 awhere a.org_callee_num like '%13800100186%'

但是這樣的號碼有好多個,有時候有一百多個,以上的sql只能查詢一個號碼的通話記錄

一開始我想用游標實現,寫一個游標,把被叫號碼放入游標中,然后寫一個循環,每次都依次查詢一下,

但后來發現t_phonebill_201702數據量太大,like一次就要花費時間20分鐘,100個就是2000分鐘(30個小時),耗時量太大,效率太低。

后來查閱資料,多次嘗試下寫下這個sql,總算是實現了查詢,實驗論證效率也還不錯。

select org_caller_num,a.org_callee_num,call_seconds,start_time,switch_id,in_trunk,out_trunk,settle_carrier,file_namefrom t_phonebill_201702 a where exists(select 1 from security_phonebill_callee_num c where a.org_callee_num  like '%||c.org_callee_num||%') ;

如果t_phonebill_201702表的數據量不大,可以考慮使用簡版,簡版更易于了解,也能更清楚明白like多個值是如何實現的,但使用exists總是一個好習慣。如果你有類似的需求,希望可以幫到你。

select org_caller_num,a.org_callee_num,call_seconds,start_time,switch_id,in_trunk,out_trunk,settle_carrier,file_namefrom t_phonebill_201702 a,security_phonebill_callee_num cwhere a.org_callee_num like '%||c.org_callee_num||%'

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 周宁县| 新昌县| 龙井市| 云龙县| 万安县| 丹棱县| 阿拉尔市| 页游| 益阳市| 报价| 江北区| 于都县| 通城县| 贡觉县| 南开区| 体育| 曲水县| 饶阳县| 屏南县| 城固县| 易门县| 云霄县| 务川| 醴陵市| 新营市| 泰安市| 临夏市| 岳阳县| 定日县| 台南县| 库伦旗| 海伦市| 牡丹江市| 广昌县| 东乌| 肇东市| 盐山县| 集贤县| 大竹县| 苏尼特右旗| 拉孜县|