关于子查询和连接的趣味小题目
今天有位同学出来一个趣味小题。 A: select title from simplified where id in (select id from analysis where word = something); B: select b.title from analysis a join simplified b on (a.id=b.id) where a.word=something; C: select simplified
今天有位同学出来一个趣味小题。
A:
select title
from simplified
where id in (select id
from analysis
where word = ‘something’);
B:
select b.title
from analysis a
join simplified b
on (a.id=b.id)
where a.word=’something’;
C:
select simplified.title
from analysis
join simplified
on (analysis.id=simplified.id)
where analysi.word=’something’;
上面的3段sql,在MYSQL中执行,哪一个效率最优,请讲出原因
看到这个问题,我想起了之前作面试官的时候,也问过这里的问题。从另一个角度,我收集了大家面对这题目的时候一些思考,总结成下面的一个面试小故事。
这类题目真得蛮适合面试的时候考察对sql的掌握程度。
模拟一个场景,面试者:小白,面试官:小二,下面开始这段面试过程…..
小二:…. 我这里有个小问题,你看看(给出上面3段sql),balabala。。。。
小白:这2个表数据量如何了,join ,子查询的优化根据数据量可能还有所不一样吧。子查询适合外结果集大,子查询结果集小的情况,最好是能保证子查询所返回的结果集尽量的小。
小二:假设2表,数据量差不多,都是万条记录左右。
小白:如果是这种的话,A应该会慢一点吧。 如果是在mysql上执行的话,A中子查询语句会认为与外面的simolified表进行关联比较有效率。这样的话A其实就回被翻译成:
select title from simplified where exists (select simplified.title from analysis where word= ‘something’ and id =simplified .id);
这种in子查询的形式,在外部表(比如上面的simplified )数据量较大的时候效率是很差的.
小二: 恩,那么B和C之间有什么区别呢?
小白:B和C在我看来,应该是差不多的,其主要区别就是B采用了别名。但是我认为应该是没多大影响的。
因为数据库本身执行时,都会再把表名给换成自己的别名。但我影响中好像记得有一条数据库的优化建议是尽量多表连接,最好是使用表的别名来引用列。
对了,有对id建索引吧。
小二: 2表id都是主键,这算是建了索引吗?
小白: 是的,主键可以保证记录的唯一和主键域非空,数据库管理系统对于主键自动生成唯一索引,所以主键也是一个特殊的索引。
小二: 恩,一张表只能有一个主键,是不是就可以说只能有一个唯一的索引呢?
小白: 不对,主键一定是唯一性索引,唯一性索引并不一定就是主键,主键就是能够唯一标识表中某一行的属性或属性组,一个表只能有一个主键,但可以有多个候选索引。
小二: 主键列和唯一索引列还有区别吗?
小白:应该有,我知道的主键列不允许空值,而唯一性索引列允许空值。一个表中可以有多个唯一性索引,但只能有一个主键。
小二: 恩,回到上面的问题,你记得多表连接,最好使用表的别名来引用列,哪你有想过会是什么原因导致的呢?
小白:我估计应该是Mysql内部处理逻辑有关吧,有可能是使用了别名,就会再建一个临时表放入内存,这样后面的命中会更高。
小二: 差不多吧,mysql引擎自动生成temp表,造成缓存的效果。从这个sql,你大致应该能明白它的意图了,你想想有没有更优的写法,可以试试看…
小白: 好的,我想想…..
小白:
select b.title from
(select id from analysis where word=’something’)a,
simplified b
where a.id=b.id;
如果这么去写,应该是最快的。放弃子查询和join。
小二: 恩,不错…..
。。。。。。
如果我在面试中碰到这样的小白,绝对会留下深刻的影响。
原文地址:关于子查询和连接的趣味小题目, 感谢原作者分享。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

keep體脂秤怎麼連接?keep是有專門設計的體脂秤,但是多數的用戶不知道如何連接keep的體脂秤,接下來就是小編為用戶帶來的keep體脂秤連接方法圖文教程,有興趣的用戶快來一起看看吧! keep體脂秤怎麼連接1、先打開keep軟體,進入到主頁點選右下角【我的】選擇其中的【智慧硬體】;2、然後在我的智慧型裝置頁面,中間【新增裝置】按鈕;3 、之後在選擇你要加入的設備介面,選擇【智慧體脂/體重計】;4、接著在選擇設備型號頁面,點選【keep體脂秤】選項;5、最後在下圖所示的介面,最底部的【立即添加】

12306訂票app下載最新版是一款大家非常滿意的出行購票軟體,想去哪裡就去那裡非常方便,軟體內提供的票源非常多,只需要通過實名認證就能在線購票,所有用戶的出行車票機票都可以輕鬆買到,享受不同的優惠折扣。還能提前開啟預約搶票,預約飯店、專車接送都是可以的,有了它想去哪裡就去那裡一鍵購票,出行更加簡單方便,讓大家的出行體驗更舒服,現在小編在線詳細為12306用戶帶來查看歷史購票記錄的方法。 1.打開鐵路12306,點擊右下角我的,點擊我的訂單 2.在訂單頁面點擊已支付。 3.在已支付頁

學信網如何查詢自己的學歷?在學信網中是可以查詢到自己的學歷,很多用戶都不知道如何在學信網中查詢到自己的學歷,接下來就是小編為用戶帶來的學信網查詢自己學歷方法圖文教程,感興趣的用戶快來一起看看吧!學信網使用教程學信網如何查詢自己的學歷一、學信網入口:https://www.chsi.com.cn/二、網站查詢:第一步:點選上方學信網位址,進入首頁點選【學歷查詢】;第二步:在最新的網頁中點選如下圖箭頭所示的【查詢】;第三步:之後在新頁面點選【的登陸學信檔案】;第四步:在登陸頁面輸入資料點選【登陸】;

大家在使用Edge瀏覽器訪問網頁的時候,有遇到提示你的連接不是專用連接,導致網頁瀏覽失敗的情況嗎?這是怎麼回事?很多朋友遇到這種問題都不知道該如何處理,可以看看下面三個解決方法。 方法一(簡單粗暴):在edge瀏覽器中,您可以透過進入設定並關閉安全性功能,然後在網站權限中阻止位置權限來嘗試解決原先報錯的網站無法存取的問題。需要注意的是,這種方法的有效性和持續時間可能會有所不同,無法確定特定的效果。重新啟動瀏覽器後,您可以嘗試造訪網站,看看是否有問題解決。 方法二: 調整鍵盤為英文輸

1、將耳機放在耳機盒中並保持蓋子打開,長按盒子上的按鍵使耳機進入進入配對狀態。 2.開啟手錶音樂功能並選擇藍牙耳機,或在手錶設定功能選擇藍牙耳機。 3.在手錶選擇該耳機即可配對成功。

MySQL與PL/SQL是兩種不同的資料庫管理系統,分別代表了關係型資料庫和過程化語言的特性。本文將比較MySQL和PL/SQL的異同點,並附帶具體的程式碼範例進行說明。 MySQL是一種流行的關聯式資料庫管理系統,採用結構化查詢語言(SQL)來管理和操作資料庫。而PL/SQL是Oracle資料庫特有的過程化語言,用於編寫預存程序、觸發器和函數等資料庫物件。相同

悟飯遊戲廳如何連接藍牙手把?悟飯遊戲廳是許多手機遊戲玩家在使用的一款遊戲盒子,裡面有著海量熱門遊戲資源,以及豐富的遊戲相關功能,下面小編帶來遊戲手把連接方法介紹,各位玩家們來看看吧。 1.首先來到悟飯遊戲廳APP首頁,再點選首頁右下角「我的」選項;2、在我的頁面中找到【手把】功能,位置下圖所示,點選前往設定;3、選擇開啟手機藍牙功能,確認手把電源是開啟狀態;4、最後依照手把說明書進行配對連接,連接成功即可使用手遊體驗各種遊戲了。

keep如何連接華為手環?在keep軟體中是可以連接華為手環,多數的用戶不知道如何連接華為手環,接下來就是小編為用戶帶來的keep連接華為手環方法圖文教程,感興趣的用戶快來一起看看吧! keep如何連接華為手環1、先開啟keep應用,主頁點選右下角【我】進入專區,選擇【智慧硬體】;2、之後挑戰到我的智慧型裝置功能頁,點選中間的【新增裝置】; 3.然後在選擇你要新增的裝置頁面,選擇【智慧手環/手錶】功能;4、最後在下圖所示的介面,點選華為手錶型號即可連接。
