目錄
寫在前面
給你答案 in
exists 結論
網上看帖子的時候,經常會看到說盡量用exists,少用in。
那麼問題來了,是所有場景下都盡量用exists嗎,還是具體場景具體分析。
mysql做子查詢的時候,永遠記得要小表驅動大表。
select * from a where id in (select id from b);
相當於先迴圈b,再迴圈a。b表驅動a表。
也就是當b表資料少於a表時,用in最佳。
select * from a where exists (select 1 from b where b.id=a.id);
相當於先迴圈a,再迴圈b。a表驅動b表。
也就是當a表資料少於b表時,用exists最佳。
其實in和exists都有其存在的必要性,雖然有時候用起來含義一樣,但是其效率是不一樣的,也不存在哪乙個最好哪乙個最差。
根據實際情況來判斷使用哪種方式
什麼時候用exists 什麼時候用in
in not in exists not exists 使用exists,oracle會首先檢查主查詢,然後執行子查詢直到它找到第乙個匹配項,這就節省了時間。oracle在執行in子查詢時,首先執行 子查詢,並將獲得的結果列表存放在乙個加了索引的臨時表中。在執行子查詢之前,系統先將主查詢掛起 待子查...
什麼時候用GET?什麼時候用POST?
get和post兩種方法都是將資料送到伺服器,但你該用哪一種呢?http標準包含這兩種方法是為了達到不同的目的。post用於建立資源,資源的內容會被編入http請示的內容中。例如,處理訂貨表單 在資料庫中加入新資料行等。當請求無 時 如進行搜尋 便可使用get方法 當請求有 時 如新增資料行 則用p...
什麼時候用堆,什麼時候用棧?
參考文章 c 面試題之記憶體分配 一 首先,回顧一下c c 的記憶體分配機制。乙個c c 程式編譯時記憶體分為5大儲存區 堆區 棧區 靜態區 全域性區 文字常量區 儲存字串常量 程式 區 存放二進位制程式 下面主要闡述前面三個。1 靜態儲存區域 靜態儲存區域的 內存在程式編譯時就已經分配好,這塊內存...