לוגו אתר Fresh          
 
 
  אפשרות תפריט  ראשי     אפשרות תפריט  צ'אט     אפשרות תפריט  מבזקים     אפשרות תפריט  צור קשר     חץ שמאלה ‎print ‎"Hello World!"; if‎ ‎not rules.‎know ‎then rules.‎read(); חץ ימינה  

לך אחורה   לובי הפורומים > מחשבים > תכנות ובניית אתרים
שמור לעצמך קישור לדף זה באתרי שמירת קישורים חברתיים
תגובה
 
כלי אשכול חפש באשכול זה



  #1  
ישן 08-01-2012, 16:29
צלמית המשתמש של Senda R
  Senda R Senda R אינו מחובר  
 
חבר מתאריך: 23.10.04
הודעות: 4,408
שאילתא מורכבת ושליפה מ2 טבלאות על פי מפתח זר

שלום לכולם.
יש לי 2 טבלאות לדוגמא -
קוד PHP:
 Table t1:   Table t2:
+----+----+  +----+----+
i1 c1 |  | i2 c2 |
+----+----+  +----+----+
1  a  |  | 1  y  |
2  b  |  | 1  k  |
3  c  |  | 1  o  |
2  b  |  | 3  p  |
3  c  |  | 3  q  |
+----+----+  +----+----+ 

בטבלה t1 יש אינדקס בשם i1 ויש לו מפתח זר בטבלה i2 .
זתומרת הטבלה t2 שדה i2 נבחר רק מתוך מה שקיים בt1 שדה i1.
השאלה היא - איך אני שולף את האינדקס i1 ביחד עם כל המזהים שמתאימים לו בt2.
לדוגמא שישלף לי a וכל מה שמתאים במזהה שזה y k o .
אני יודע לעשות את זה עם 2 שאילתות ופונציה שכתבתי אבל בטוח קיימת דרך קצרה בSQL.
תודה לעוזרים.
_____________________________________
חתימתכם הוסרה כיוון שלא עמדה בחוקי האתר. לפרטים נוספים לחצו כאן. תוכלו לקבל עזרה להתאמת החתימה לחוקים בפורום חתימות וצלמיות.

תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #3  
ישן 08-01-2012, 22:30
צלמית המשתמש של Senda R
  Senda R Senda R אינו מחובר  
 
חבר מתאריך: 23.10.04
הודעות: 4,408
בתגובה להודעה מספר 2 שנכתבה על ידי שימי שמתחילה ב "אתה אומר ש SELECT i1 FROM t1..."

עשיתי את זה בהתחלה זה לא עובד..
זה שולף לי את 2 הערכים במקביל.
זתומרת
a-y
a-o
a-k

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

בגדול אני משתמש בזה למשחק של שאלה ו4 תשובות .
לכל תשובה יש מפתח זר של השאלה שהיא מקושרת אליו.
נניח השאלה היא ID=1 אז תשובה "בלה בלה" יש לה qid=1 ותשובה 2 -"בלה בלה 2" יש לה qid=1 וכו..
אני רוצה לשלוף רק את התשובות + השאלה פעם אחת , זה לא אפשרי? רק בכמה שאילתות?
(נניח לשלוף שאלה ואז לשלוף 4 תשובות שלה וכן הלאה, הרבה פניות לSQL)
_____________________________________
חתימתכם הוסרה כיוון שלא עמדה בחוקי האתר. לפרטים נוספים לחצו כאן. תוכלו לקבל עזרה להתאמת החתימה לחוקים בפורום חתימות וצלמיות.

תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #8  
ישן 10-01-2012, 03:19
  שימיadmin שימי אינו מחובר  
מנהל פורומי "תכנות ובניית אתרים" ו"חומרה ורשתות"
 
חבר מתאריך: 25.10.01
הודעות: 42,775
בתגובה להודעה מספר 7 שנכתבה על ידי Senda R שמתחילה ב "אני אוהב קוד עם קצת פניות..."

בשאילתא שאני כתבתי יש פנייה אחת למסד הנתונים. אני באמת לא מבין איך אתה רוצה משהו יותר טוב מפניה אחת, פשוטה, שאם i1 ו i2 מאונדקסים כראוי, תיקח אולי מילי-שניה לכל היותר...

אל תניח שאני יודע למה אתה חושב שהשאילתא שהצעתי לא טובה. תסביר לי למה לא, ואני אנסה להוכיח לך שאתה טועה...

mysql_fetch_* לא ניגש למסד הנתונים בכלל - הוא ניגש למשאב תוצאה שחזרה מ mysql_query - שמכיל כבר את כל התוצאות. אם היית מבצע את השאילתא מול מסד הנתונים עם mysql_unbuffered_query(), זה היה עובד אחרת, אבל אתה לא.
_____________________________________
תמונה שהועלתה על ידי גולש באתר ולכן אין אנו יכולים לדעת מה היא מכילה
נמאס לכם לזכור סיסמאות? לחצו כאן!

תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #12  
ישן 09-01-2012, 08:41
צלמית המשתמש של Senda R
  Senda R Senda R אינו מחובר  
 
חבר מתאריך: 23.10.04
הודעות: 4,408
בתגובה להודעה מספר 1 שנכתבה על ידי Senda R שמתחילה ב "שאילתא מורכבת ושליפה מ2 טבלאות על פי מפתח זר"

אני עשיתי את זה אגב ככה :

קוד PHP:
 $Qdata mysql_query("SELECT * FROM `questions` ");
    
$Q=mysql_fetch_assoc($Qdata);



while (isset (
$Q['id']))
{

    echo 
'<div class="question"><span class="id">'.$Q['id'].'</span>'.$Q['text'].'';
    
$qid=$Q['id'];
    
$Adata mysql_query("SELECT * FROM `answers` WHERE `answers`.`idq`='$qid' ");
    
$A=mysql_fetch_assoc($Adata);
    while (isset (
$A['id']))
    {
        echo 
'<div class="answer"><span class="id">'.$A['id'].'</span>'.$A['text'].'</div>';
        
$A=mysql_fetch_assoc($Adata);
    }
    echo 
'</div>';
    
$Q=mysql_fetch_assoc($Qdata); 




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

תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

כלי אשכול חפש באשכול זה
חפש באשכול זה:

חיפוש מתקדם
מצבי תצוגה דרג אשכול זה
דרג אשכול זה:

מזער את תיבת המידע אפשרויות משלוח הודעות
אתה לא יכול לפתוח אשכולות חדשים
אתה לא יכול להגיב לאשכולות
אתה לא יכול לצרף קבצים
אתה לא יכול לערוך את ההודעות שלך

קוד vB פעיל
קוד [IMG] פעיל
קוד HTML כבוי
מעבר לפורום



כל הזמנים המוצגים בדף זה הם לפי איזור זמן GMT +2. השעה כעת היא 15:46

הדף נוצר ב 0.06 שניות עם 10 שאילתות

הפורום מבוסס על vBulletin, גירסא 3.0.6
כל הזכויות לתוכנת הפורומים שמורות © 2024 - 2000 לחברת Jelsoft Enterprises.
כל הזכויות שמורות ל Fresh.co.il ©

צור קשר | תקנון האתר