09-04-2006, 07:24
|
|
|
חבר מתאריך: 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.
|