דילוג לתוכן
  • דף הבית
  • קטגוריות
  • פוסטים אחרונים
  • משתמשים
  • חיפוש
  • חוקי הפורום
כיווץ
תחומים

תחומים - פורום חרדי מקצועי

💡 רוצה לזכור קריאת שמע בזמן? לחץ כאן!
  1. דף הבית
  2. תכנות
  3. MYSQL איחוד תוצאות וחיפוש בתוך התוצאות המאוחדות

MYSQL איחוד תוצאות וחיפוש בתוך התוצאות המאוחדות

מתוזמן נעוץ נעול הועבר תכנות
3 פוסטים 2 כותבים 85 צפיות
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • י מנותק
    י מנותק
    יוסף בן שמעון
    כתב ב נערך לאחרונה על ידי
    #1

    טבלת המוצרים

    +-------------+-------
    | id  | title | cost |
    +-----+------------+--
    

    טבלת התגים

    +-------------+-------------
    | id  | tag_name | item_id |
    +-----+------------+--------
    

    העמודה item_id זה מפתח זר של המוצר, לכל מוצר יש כמה תגיות.

    אם אני רוצה לשלוף מוצר עם כל התגיות שלו, אני עושה JOIN

    SELECT items.*, GROUP_CONCAT(items_tags.name, ',') as tags 
    FROM items 
    LEFT JOIN items_tags ON items_tags.item_id = items.id 
    WHERE items.id = 55
    GROUP BY items.id
    

    ומקבל את כל התגיות תחת השדה tags

    הבעיה מתחילה אם אני רוצה לשלוף כל מוצר שמכיל את תגית מסויימת
    אם אני עושה כך

    SELECT items.*, GROUP_CONCAT(items_tags.name, ',') as tags 
    FROM items 
    LEFT JOIN items_tags ON items_tags.item_id = items.id 
    WHERE items.tags = 'computer'
    GROUP BY items.id
    

    זה שולף את כל המוצרים, אבל זה לא מביא את כל התגיות שלהם, זה מחזיר רק את התגית computer בגלל ה WHERE
    אבל אני רוצה שרק הסינון יתבצע לפי התגית, ושיחזיר לי את כל התגיות שמשוייכות למוצר
    איך עושים את זה?

    א תגובה 1 תגובה אחרונה
    0
    • א מנותק
      א מנותק
      ארכיטקט
      השיב ליוסף בן שמעון ב נערך לאחרונה על ידי
      #2
      SELECT items.*, GROUP_CONCAT(items_tags.name, ',') as tags 
      FROM items 
      LEFT JOIN items_tags ON items_tags.item_id = items.id 
      WHERE items.id IN (select t.item_id from items_tags as t where t.name='computer')
      GROUP BY items.id
      

      אידיאולוגיות גדולות נכנסות למטחנה של עולם המעשה ויוצאות ממנו בפירורים (ווינסטון צ'רצ'יל, סתם סתם, זה שלי)

      י תגובה 1 תגובה אחרונה
      5
      • י מנותק
        י מנותק
        יוסף בן שמעון
        השיב לארכיטקט ב נערך לאחרונה על ידי
        #3

        @ארכיטקט תודה!

        תגובה 1 תגובה אחרונה
        0

        בא תתחבר לדף היומי!
        • התחברות

        • אין לך חשבון עדיין? הרשמה

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