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

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

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

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

מתוזמן נעוץ נעול הועבר תכנות
3 פוסטים 2 כותבים 85 צפיות 2 עוקבים
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
תגובה
  • תגובה כנושא
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • י מנותק
    י מנותק
    יוסף בן שמעון
    כתב ב נערך לאחרונה על ידי
    #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
    • י יוסף בן שמעון

      טבלת המוצרים

      +-------------+-------
      | 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
      אבל אני רוצה שרק הסינון יתבצע לפי התגית, ושיחזיר לי את כל התגיות שמשוייכות למוצר
      איך עושים את זה?

      א מנותק
      א מנותק
      ארכיטקט
      כתב ב נערך לאחרונה על ידי
      #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
      • א ארכיטקט
        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
        
        י מנותק
        י מנותק
        יוסף בן שמעון
        כתב ב נערך לאחרונה על ידי
        #3

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

        תגובה 1 תגובה אחרונה
        0
        תגובה
        • תגובה כנושא
        התחברו כדי לפרסם תגובה
        • מהישן לחדש
        • מהחדש לישן
        • הכי הרבה הצבעות


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

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

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