אינטרנט ישראל
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
ראשי » מדריכים » לימוד MySQL » Subqueries ב-MySQL

Subqueries ב-MySQL

רן בר-זיק ספטמבר 21, 2009 1:17 pm אין תגובות

הסבר על תתי שאילתות ב-MySQL וכיצד ליישם אותן בקלות.

כדאי תמיד להשאר מעודכנים! אם יש לכם טלגרם, בדקו את ערוץ הטלגרם של האתר שבו אני מעדכן על פוסטים חדשים 🙂 אם אתם רוצים ללמוד תכנות באופן מקיף ומסודר, הצטרפו לאלפי הלומדים בפרויקט "ללמוד ג'אווהסקריפט בעברית" שמלמד לתכנת בג'אווהסקריפט, ב-Node.js ובריאקט וגם מלמד על תרומה לקוד פתוח. גם ספרים דיגיטליים וגם ספרים מודפסים. בשיתוף הקריה האקדמית אונו ובתמיכת חברות מובילות כגון Wix, Outbrain, Elementor, Iron Source, Chegg, Really Good ועוד.

במאמר הקודם למדנו על JOIN ב-MySQL ובכך סיימנו את הדיון בשאילתות MySQL פשוטות יחסית. MySQL מאפשרת לנו ליצור שאילתות מורכבות באמצעות MySQL Subqueries.

לא צריך להבהל כל כך מהשם – מדובר במשהו פשוט לחלוטין שמוסבר היטב באמצעות דוגמא.

נניח שיש לי טבלה בשם city והיא כוללת את השדות idcity (מספר סידורי רץ), מיקוד, שם מדינה ושם עיר.


+--------+---------+---------+----------+
| idcity | zipcode | country | cityname |
+--------+---------+---------+----------+
|      1 | 12345   | Israel  | Tel Aviv |
|      2 | 123456  | Israel  | Holon    |
|      3 | 123457  | USA     | Georgia  |
+--------+---------+---------+----------+

ונניח שיש לי עוד טבלה ששמה הוא customer:


+------------+-----------+----------+---------+
| idcustomer | firstname | lastname | zipcode |
+------------+-----------+----------+---------+
|          1 | Moshe     | Levi     | 123456  |
|          2 | Avi       | Cohen    | 123456  |
|          3 | Yossi     | Bar      | 12345   |
+------------+-----------+----------+---------+

נניח שמשתי הטבלאות האלו אני צריך לשלוף את כל הלקוחות שגרים בחולון. אפשר לעשות את זה עם JOIN כמובן ואפילו די בקלות עם השאילתא הבאה:


SELECT idcustomer, firstname, lastname FROM customer INNER JOIN city ON city.zipcode = customer.zipcode WHERE city.cityname = 'holon';

שתביא לנו את התוצאה הבאה:


+------------+-----------+----------+
| idcustomer | firstname | lastname |
+------------+-----------+----------+
|          1 | Moshe     | Levi     |
|          2 | Avi       | Cohen    |
+------------+-----------+----------+

כאשר יש לי רק מעט נתונים, לא צריך להיות גאון כדי להבין שאולי עדיף להשתמש ב-INNER JOIN. אבל אם יש לי מספר עצום של שורות בטבלה, הרבה יותר כדאי לבצע שליפה של הלקוחות ישירות לפי ה-ZIPCODE ללא ביצוע JOIN של טבלאות עם לפעמים מאות אלפי שורות. שימוש ב-JOIN ואז ביצוע השאילתא ירצח את מסד הנתונים. הרבה יותר נעים מבחינת ביצועים לבדוק את ה-ZIPCODE של עיר ספציפית ואז לבצע את השאילתא מתוך טבלת הלקוחות:

ראשית:


SELECT zipcode FROM city WHERE cityname = 'holon';

ואז אני מקבל תוצאה:


+---------+
| zipcode |
+---------+
| 123456  |
+---------+

שאותה אני מציב בשאילתא:


SELECT idcustomer, firstname, lastname FROM customer WHERE zipcode = '123456';

ואז אני מקבל את התוצאה. זו דרך הרבה יותר יעילה, אבל זה דורש ממני שתי שאילתות ומאד מאד עדיף לנו לרכז את כל בקשות המידע בתוך שאילתא אחת. ובדיוק בשביל זה יש subquery – כדי שאני אוכל להכניס תוצאה שהתקבל משאילתא אחת לתוך שאילתא שניה – ובמקרה שלנו:


SELECT idcustomer, firstname, lastname FROM customer WHERE zipcode = (SELECT zipcode FROM city WHERE cityname ='holon');

subquery קלה מאד לשימוש – כל מה שצריך זה לשים סוגריים ו… זהו! כל עוד התוצאה המתקבלת היא נתון שיכול להכנס לתוך השאילתא שלנו, לא צריכה להיות בעיה. אפשר לשרשר כמה subqueries ביחד – כל עוד מקפידים על הסוגריים.

⚠️המדריכים כאן הם טעימה בלבד! יש ספר מקיף המלמד MySQL מרמת בסיס ועד רמה מתקדמת. הספר הדיגיטלי, שרלוונטי גם לכל מסדי הנתונים שעובדים עם SQL – זמין כאן כחלק מהפרויקט "ללמוד ג'אווהסקריפט בעברית" – זו הדרך הטובה ביותר ללמוד באופן מקיף MySQL.

במאמר הבא נדבר על VIEW ב-MySQL וגם על STORED PROCEDURES.

כדאי תמיד להשאר מעודכנים! אם יש לכם טלגרם, בדקו את ערוץ הטלגרם של האתר שבו אני מעדכן על פוסטים חדשים 🙂 אם אתם רוצים ללמוד תכנות באופן מקיף ומסודר, הצטרפו לאלפי הלומדים בפרויקט "ללמוד ג'אווהסקריפט בעברית" שמלמד לתכנת בג'אווהסקריפט, ב-Node.js ובריאקט וגם מלמד על תרומה לקוד פתוח. גם ספרים דיגיטליים וגם ספרים מודפסים. בשיתוף הקריה האקדמית אונו ובתמיכת חברות מובילות כגון Wix, Outbrain, Elementor, Iron Source, Chegg, Really Good ועוד.
למדריך ה-MySQL הקודםJoin – צירוף תוצאות מטבלאות ב-MySQL
למדריך ה-MySQL הבאViews ו-STORED PROCEDURES ב-MySQL
לתפריט המדריכים ל-MySQL
MySQL
ללמוד ג'אווהסקריפט בעברית

ללמוד לתכנת ג'אווהסקריפט בעברית שגייס יותר משלוש מאות אלף שקל ולמעלה מ-2000 תומכים - בואו ללמוד עכשיו איך לתכנת.

רשימת הנושאים
  • מדריכים
    • ריאקט
    • טייפסקריפט
    • ECMAScript 6
    • ES20XX
    • Node.js
    • Express
    • רספברי פיי
    • Babel
    • docker
    • MongoDB
    • Git
    • לימוד MySQL
    • SASS
    • jQuery
    • CSS3
    • HTML 5
    • SVN
    • LESS
  • פיתוח אינטרנט
    • פתרונות ומאמרים על פיתוח אינטרנט
    • jQuery Scripts
    • jQuery למתקדמים
    • יסודות בתכנות
    • נגישות אינטרנט
  • חדשות אינטרנט
  • מידע כללי על אינטרנט
    • רשת האינטרנט
    • בניית אתרי אינטרנט
  • rss logo

    לכל המאמרים

    לכל המאמרים שפורסמו באינטרנט ישראל משנת 2008 ועד עכשיו.
  • rss logo

    RSS Feed

    משתמשים בקורא RSS? אם כן, עקבו אחרי אינטרנט ישראל באמצעות פיד ה-RSS!
    מה זה RSS?
  • Twitter logo

    עקבו אחרי בטוויטר

    בחשבון הטוויטר שלי אני מפרסם עדכונים מהירים על חדשות בתחום התכנות והיזמות, התרעות על מצבי חירום ורכילות בוערת על תחום הווב.
    מה זה טוויטר?
  • facebook like image

    ערוץ הטלגרם של אינטרנט ישראל

    בערוץ הטלגרם של אינטרנט ישראל אני מפרסם את הפוסטים של באתר וכן עדכונים טכנולוגיים נוספים.
    מה זה טלגרם?
  • github logo

    הפרויקטים שלי בגיטהאב

    הפרויקטים שאני כותב ושוחררו לציבור ברישיון קוד פתוח נמצאים ברובם בגיטהאב.
חיפוש

כל הזכויות שמורות לרן בר-זיק ולאינטרנט ישראל | מדיניות הפרטיות של אתר אינטרנט ישראל | אתר אינטרנט ישראל נגיש לפי תקן WCAG 2.0 AA | הצהרת הנגישות של האתר | אבטחת מידע ודיווח על בעיית אבטחת מידע

גלילה לראש העמוד