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

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



  #4  
ישן 21-09-2006, 19:46
  DCD DCD אינו מחובר  
 
חבר מתאריך: 17.05.05
הודעות: 7,321
בתגובה להודעה מספר 3 שנכתבה על ידי YARONALDINHO שמתחילה ב "תודה רבה קודם כל =)"

אם רוצים הכל אפשר (:

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

כתשובה לשאלה הראשונה שלך, הראתי לך את הקוד הבא:

UPDATE families SET childs=(SELECT COUNT(parent) FROM families WHERE parent='4') WHERE ID=4

עכשיו, מה שאתה רוצה לעשות זה להפעיל את אותה השאילתה הנ"ל, רק שתעבור על כל ה-parent'ים שיש.

אז דבר ראשון מה שאתה צריך לעשות זה למצוא את הערך המקסימלי שיש בטור ה-parent.
איך מוצאים את זה? ע"י שאילתת SELECT:

קוד:
Select MAX(parent) as max_p FROM families


עכשיו בוא רק בשביל הדוגמא, נגיד שהערך המקסימלי שיצא מהשאילתה זה 8.
אחרי שהשגנו את הערך המקסימלי, צריך לכתוב לולאה שתריץ 8 פעמים את שאילתת ה-UPDATE כשכל פעם יהיה ערך parent אחר בהתאמה.

את זה אתה יכול לעשות ע"י לולאת FOR ועם משתנה מסויים שיכיל את כמות הפעמים שהלולאה רצה (משתנה זה גם יכיל את הערך של ה-parent שצריך לעדכן לפיו).

בוא אביא לך דוגמא בקוד PHP:

קוד PHP:
 $q1 mysql_query("Select MAX(parent) as max_p FROM families");
$f1 mysql_fetch_array($q1);

FOR (
$i=$i<$f1['max_p'] ; i++)
{
 
mysql_query("UPDATE families SET childs=(SELECT COUNT(parent) FROM families WHERE parent='{$i}') WHERE ID={$i}");



אם אתה רוצה לשפר את מהירות השאילתות, נדמה לי שאפשר להשתמש בנעילת טבלה כמו שכתבתי באשכול הזה:

http://www.fresh.co.il/vBulletin/sh...ad.php?t=228859

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

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

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

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

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



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

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

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

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