关于子查询和连接的趣味小题目
今天有位同学出来一个趣味小题。 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。
小二: 恩,不错…..
。。。。。。
如果我在面试中碰到这样的小白,绝对会留下深刻的影响。
原文地址:关于子查询和连接的趣味小题目, 感谢原作者分享。

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Wie schließe ich die Körperfettwaage an? Keep verfügt über eine speziell entwickelte Körperfettwaage, aber die meisten Benutzer wissen nicht, wie sie die Körperfettwaage anschließen sollen Editor bringt zu den Nutzern, interessierte Nutzer kommen und schauen! So schließen Sie die Keep-Körperfettwaage an: 1. Öffnen Sie zunächst die Keep-Software, gehen Sie zur Hauptseite, klicken Sie auf [Mein] in der unteren rechten Ecke und wählen Sie [Smart Hardware] aus. 2. Klicken Sie dann auf der Seite „Meine Smart-Geräte“. Klicken Sie auf die Schaltfläche [Gerät hinzufügen] in der Mitte. 3 Wählen Sie dann das Gerät aus, dem Sie eine Schnittstelle hinzufügen möchten. Wählen Sie dann [Intelligente Körperfett-/Gewichtswaage] aus. 4. Klicken Sie dann auf der Seite zur Auswahl des Gerätemodells auf [Körperfettwaage behalten]. Option 5. Schließlich in der unten gezeigten Benutzeroberfläche unten [Jetzt hinzufügen].

Laden Sie die neueste Version der Ticketbuchungs-App 12306 herunter, mit der jeder sehr zufrieden ist. Es gibt viele Ticketquellen, die in der Software bereitgestellt werden -Namenauthentifizierung zum Online-Kauf von Tickets. Alle Benutzer können ganz einfach Reisetickets und Flugtickets kaufen und verschiedene Ermäßigungen genießen. Sie können auch im Voraus mit der Buchung beginnen, um Tickets zu erhalten. Damit können Sie mit einem Klick dorthin fahren, wo Sie möchten, und so das Reisen einfacher und bequemer gestalten Noch komfortabler: Der Herausgeber stellt die Details jetzt online dar. Bietet 12306 Benutzern die Möglichkeit, historische Ticketkaufaufzeichnungen einzusehen. 1. Öffnen Sie Railway 12306, klicken Sie unten rechts auf „Mein“ und dann auf „Meine Bestellung“. 2. Klicken Sie auf der Bestellseite auf „Bezahlt“. 3. Auf der kostenpflichtigen Seite

Wie kann ich meine akademischen Qualifikationen auf Xuexin.com überprüfen? Sie können Ihre akademischen Qualifikationen auf Xuexin.com überprüfen. Viele Benutzer wissen nicht, wie sie ihre akademischen Qualifikationen auf Xuexin.com überprüfen können Benutzer kommen vorbei und schauen sich um! Tutorial zur Nutzung von Xuexin.com: So überprüfen Sie Ihre akademischen Qualifikationen auf Xuexin.com 1. Zugang zu Xuexin.com: https://www.chsi.com.cn/ 2. Website-Abfrage: Schritt 1: Klicken Sie auf die Adresse von Xuexin.com Um die Startseite aufzurufen, klicken Sie oben auf [Bildungsabfrage]; Schritt 2: Klicken Sie auf der neuesten Webseite auf [Abfrage], wie durch den Pfeil in der Abbildung unten dargestellt. Schritt 3: Klicken Sie dann auf der neuen Seite auf [Anmelden bei akademischer Kreditdatei]. Schritt 4: Geben Sie auf der Anmeldeseite die Informationen ein und klicken Sie auf [Anmelden].

1. Legen Sie die Ohrhörer in die Ohrhörerbox und lassen Sie den Deckel geöffnet. Halten Sie die Taste an der Box gedrückt, um in den Kopplungsstatus der Ohrhörer zu gelangen. 2. Schalten Sie die Funktion „Musik ansehen“ ein und wählen Sie „Bluetooth-Kopfhörer“ oder wählen Sie „Bluetooth-Kopfhörer“ in der Funktion „Uhreneinstellungen“ aus. 3. Wählen Sie das Headset auf der Uhr aus, um die Kopplung erfolgreich durchzuführen.

Wenn Sie den Edge-Browser zum Zugriff auf Webseiten verwenden, sind Sie schon einmal auf die Meldung gestoßen, dass es sich bei Ihrer Verbindung nicht um eine dedizierte Verbindung handelt, was dazu führt, dass das Surfen im Internet fehlschlägt? Wie läuft das? Viele Freunde wissen nicht, wie sie mit diesem Problem umgehen sollen. Schauen Sie sich die folgenden drei Lösungen an. Methode 1 (einfach und grob): Im Edge-Browser können Sie versuchen, das Problem der Unzugänglichkeit der Website zu lösen, indem Sie die Einstellungen eingeben, die Sicherheitsfunktion deaktivieren und dann die Standortberechtigungen in den Website-Berechtigungen blockieren. Es ist wichtig zu beachten, dass die Wirksamkeit und Dauer dieses Ansatzes variieren kann und spezifische Auswirkungen nicht bestimmt werden können. Nachdem Sie Ihren Browser neu gestartet haben, können Sie versuchen, die Website zu besuchen, um zu sehen, ob das Problem behoben ist. Methode 2: Passen Sie die Tastatur an die englische Eingabe an

Wie verbinde ich einen Bluetooth-Controller mit Gohan Arcade? Gohan Game Center ist eine Spielebox, die von vielen Spielern mobiler Spiele verwendet wird. Sie enthält eine große Anzahl beliebter Spielressourcen und umfangreiche spielbezogene Funktionen. Im Folgenden stellt der Herausgeber die Verbindungsmethode für den Gamecontroller vor. 1. Gehen Sie zuerst zur Homepage der Gohan Game Center APP und klicken Sie dann auf die Option „Mein“ in der unteren rechten Ecke der Homepage. 2. Suchen Sie die Funktion [Controller] auf der Seite „Mein“. Der Speicherort wird im Bild angezeigt Klicken Sie unten, um zu den Einstellungen zu gelangen. 3. Wählen Sie, um die Bluetooth-Funktion des Mobiltelefons einzuschalten. Vergewissern Sie sich, dass der Controller eingeschaltet ist. 4. Befolgen Sie abschließend die Anweisungen des Controllers, um eine passende Verbindung herzustellen Bei erfolgreicher Verbindung können Sie mit dem Handyspiel verschiedene Spiele erleben.

Wie stellt man eine Verbindung zum Huawei-Armband her? Die meisten Benutzer wissen nicht, wie man eine Verbindung zum Huawei-Armband herstellt Es fühlt sich an, als würden interessierte Benutzer kommen und einen Blick darauf werfen! So verbinden Sie Keep mit dem Huawei-Armband 1. Öffnen Sie zunächst die Keep-Anwendung, klicken Sie auf „Ich“ in der unteren rechten Ecke der Hauptseite, um den speziellen Bereich aufzurufen, und wählen Sie „Smart Hardware“ aus. 2. Fordern Sie dann „My Smart Device“ an Funktionsseite und klicken Sie in der Mitte auf [Gerät hinzufügen]. 3. Wählen Sie dann auf der Seite zur Auswahl des Geräts, das Sie hinzufügen möchten, die Funktion [Smart-Armband/Uhr] aus. 4. Klicken Sie abschließend auf der unten gezeigten Oberfläche Huawei-Uhrenmodell zum Verbinden.

MySQL und PL/SQL sind zwei unterschiedliche Datenbankverwaltungssysteme, die die Merkmale relationaler Datenbanken bzw. prozeduraler Sprachen darstellen. In diesem Artikel werden die Ähnlichkeiten und Unterschiede zwischen MySQL und PL/SQL anhand konkreter Codebeispiele zur Veranschaulichung verglichen. MySQL ist ein beliebtes relationales Datenbankverwaltungssystem, das Structured Query Language (SQL) zum Verwalten und Betreiben von Datenbanken verwendet. PL/SQL ist eine für Oracle-Datenbanken einzigartige prozedurale Sprache und wird zum Schreiben von Datenbankobjekten wie gespeicherten Prozeduren, Triggern und Funktionen verwendet. Dasselbe
