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

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



  #1  
ישן 09-04-2006, 07:24
  ישראל K ישראל K אינו מחובר  
 
חבר מתאריך: 25.08.03
הודעות: 9,114
חישוב עלות תקופתית לפי תאריכים החופפים תעריפים שונים

יש לי טבלת תעריפים הדומה לטבלה הבאה:
קוד:
+----+-----+------------+------------+-------+ | id | aId | fromDate | upToDate | price | +----+-----+------------+------------+-------+ | 2 | 1 | 2006-01-01 | 2006-03-25 | 17 | | 13 | 1 | 2006-03-26 | 2002-06-30 | 29 | | 12 | 1 | 2006-07-01 | 2003-08-31 | 25 | | 11 | 1 | 2006-09-01 | 2006-12-31 | 26 | | 14 | 2 | 2006-01-01 | 2003-03-25 | 29 | | 5 | 2 | 2006-03-26 | 2006-06-30 | 12 | | 4 | 2 | 2006-07-01 | 2006-08-31 | 20 | | 3 | 2 | 2006-09-01 | 2006-12-31 | 22 | | 7 | 10 | 2002-09-02 | 2002-11-05 | 26 | | 6 | 10 | 2000-09-29 | 2000-11-29 | 17 | | 8 | 10 | 2003-02-01 | 2003-02-01 | 258 | | 9 | 11 | 2002-09-02 | 2002-11-05 | 100 | | 10 | 11 | 2003-02-01 | 2003-02-01 | 258 | +----+-----+------------+------------+-------+

aid = ה-id של הדירה (שפרטיה המלאים בטבלה המתאימה).

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

בא נאמר שאני רוצה את הדירה שה-id שלה הוא 1 (aId=1) למשך חודשיים ימים, החל מהתאריך 2006-03-05 עד לתאריך 2006-05-05.
הטבלה מכילה את התעריף לכל יום שבין הימים המצויין בשדות התאריכים, כך שמה שאני צריך כאן זה לחשב כ-60 ימים המחושבים כל אחד לפי תעריף שונה.
אני בטוח שישנם מספר דרכים, כיצד אתם מציעים לעשות זאת בצורה הפשוטה, נוחה ויעילה ביותר [גם אם לא הכי פשוטה] ?
אני כמובן מעדיף שהחישוב יהיה כמה שיותר בשאילתה והרבה פחות בשפת התסריט (PHP).

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

הערה:
* אל תתייחסו כמעט לרשומות שה-aid שלהם הינו 10 או 11, כיון שברשומות אלו לא טרחתי כרגע להציב תאריכים הגיונים, אלא סתם מה שיצא (לצורך המחשת מבנה הטבלה).
* מסד הנתונים המדובר הינו MySQL.

תודה מראש לכולם

נערך לאחרונה ע"י ישראל K בתאריך 09-04-2006 בשעה 07:26.
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

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

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

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

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



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

הדף נוצר ב 0.03 שניות עם 11 שאילתות

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

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