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

מיזוג בין טבלאות באמצעות MySQL

רן בר-זיק דצמבר 7, 2010 7:55 am אין תגובות

הסבר על מיזוג טבלאותב-MySQL עם דוגמא מהמציאות ושימוש באופרטור NOT IN ו-Subquery.

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

כאשר אנו עושים Merge בין גרסאות, לא מעט פעמים אנו ממזגים בין טבלאות זהות שמכילות נתונים שונים. למרות שיש כלים שונים למיזוג, לפעמים עדיף לעשות את זה עם שאילתה מהירה שמבצעת את המיזוג.

ההנחה היא שסוג הטבלאות וסוג השדות שיש בטבלאות ה-MySQL הוא זהה לחלוטין. במידה ולא, אפשר לשנות את השאילתה בהתאם ולהכניס נתוני דיפולט או נתונים מטבלה אחרת.

הדוגמאות הן דוגמאות אמיתיות מתוך טבלה אמיתי שמודול בדרופל משתמש בה.

תיאור מבנה הנתונים של הטבלה באמצעות Describe:


+----------+------------------+------+-----+---------+----------------+
| Field    | Type             | Null | Key | Default | Extra          |
+----------+------------------+------+-----+---------+----------------+
| pid      | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| src      | varchar(128)     | NO   | MUL |         |                |
| dst      | varchar(255)     | NO   | MUL |         |                |
| language | varchar(12)      | NO   |     |         |                |
+----------+------------------+------+-----+---------+----------------+


הנה חלק מהטבלה להמחשה:


mysql> select * from url_alias_no1 LIMIT 3;
+-----+-------------------+---------------+----------+
| pid | src               | dst           | language |
+-----+-------------------+---------------+----------+
| 175 | taxonomy/term/60  | entertainment |          |
| 176 | taxonomy/term/54  | tournaments   |          |
| 177 | taxonomy/term/162 | software      |          |
+-----+-------------------+---------------+----------+
3 rows in set (0.00 sec)

כאמור יש לי שתי טבלאות – הראשונה היאurl_alias_no1 והשניה היא url_alias_no2. אני רוצה למזג את שתיהן אל url_alias. כאשר אני לא רוצה שתהיה כפילות בנתונים. אני לא יכול להשתמש ב-Primary key כאן כיוון שיש כפילות בשתי הטבלאות. אני חייב לבחור נתון אחר שאני לא רוצה שתהיה כפילות איתו. במקרה הזה מדובר בשדה src.

תיאור מילולי של השאילתה: בחר את כל הנתונים מהטבלה הראשונה שה-src שלהם לא מופיע ב-src של הטבלה השניה והכנס אותם אל טבלה שלישית.

פעולה ראשונה – יצירת טבלה שלישית חדשה.
אני יוצר עותק של הטבלה השניה url_alias_no2. העותק הוא זהה לחלוטין ושמו כמובן הוא url_alias.


CREATE TABLE url_alias SELECT * FROM url_alias_no_2

פעולה שניה – ההעתקה עצמה

אני משתמש כאן ב-subquery ובאופרטור הנפלא NOT IN:


INSERT INTO url_alias (url_alias.src, url_alias.dst, url_alias.language )
(SELECT url_alias_no_1.src, url_alias_no_1.dst, url_alias_no_1.language 
FROM url_alias_no_1 WHERE url_alias_no_1.src NOT IN (SELECT src FROM url_alias_no_2));

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

אני מנצל את הבמה להודות לאורן ולרוברט על הרעיון והעזרה.

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

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