21-09-2006, 19:46
|
|
|
חבר מתאריך: 17.05.05
הודעות: 7,321
|
|
אם רוצים הכל אפשר (:
תשובה לשאלתך השנייה:
כתשובה לשאלה הראשונה שלך, הראתי לך את הקוד הבא:
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=0 ; $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
בהצלחה
|