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

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



  #1  
ישן 30-01-2008, 18:07
צלמית המשתמש של tnadav1
  משתמש זכר tnadav1 tnadav1 אינו מחובר  
 
חבר מתאריך: 02.10.05
הודעות: 2,355
שלח הודעה דרך MSN אל tnadav1
שם עמודה שונה לפי ערך מסוים של רשומה

שלום, יש לי טבלה של שעות עבודה, עם מזהה לרשומה מסוימת בטבלה persons שם יש מידע על עובדים.
בטבלה של השעות יש שדה בוליאני בשם job.

אני רוצה לשלוף שדה מורכז של השעות של עובד מסוים, אם job הוא TRUE שייהיה בעמודה אחת ואם הוא FALSE שייהיה בעבודה אחרת.

ככה ניסיתי לעשות את זה בשאילתה:
קוד:
SELECT `persons`.`userId`, `persons`.`fname_he`, `persons`.`lname_he`, SUBTIME(`work_hours`.`endHour` , `work_hours`.`startHour` ) AS CASE `work_hours`.`job` WHEN TRUE THEN `workHours` ELSE `planHours` FEOM `persons`, `work_hours` WHERE `persons`.`id` = `work_hours`.`personId` GROP BY `persons`.`id`

וקיבלתי את השגיאה הבאה:

קוד:
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'CASE `work_hours`.`job` WHEN TRUE THEN `workHours` ELSE `planHours` FEOM `perso' at line 3


אני מניח שזה בגלל שאי-אפשר לשים משפחת CASE במקום הזה, השאלה שלי היא: מה כן אפשר לשים.

וחוץ מזה, יש פונקציה כמו SUM רק לשדות מסוג TIME ?
_____________________________________



נערך לאחרונה ע"י ישראל K בתאריך 04-02-2008 בשעה 21:44. סיבה: תיקון תג - נערך באישור הכותב
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #8  
ישן 04-02-2008, 20:47
צלמית המשתמש של tnadav1
  משתמש זכר tnadav1 tnadav1 אינו מחובר  
 
חבר מתאריך: 02.10.05
הודעות: 2,355
שלח הודעה דרך MSN אל tnadav1
בתגובה להודעה מספר 7 שנכתבה על ידי DCD שמתחילה ב "טעות שלי XD"

פתרתי את הבעיה, מסתבר ש- CASE בעצם עובד רק לעמודה אחת, השתמשתי בשלושה CASE-ים ופתרתי את הבעיה.

עכשיו יש לי בעיה אחרת-
הנה השאילתה (השתנתה לצורך אחר)
קוד:
SELECT `persons`.`jobSize` , `persons`.`fname_he` AS `fname` , `persons`.`lname_he` AS `lname` , `persons`.`id` , `persons`.`disNum` , `persons`.`isWorker` , `persons`.`isDis` , `persons`.`isGuide` , MONTH( `work_hours`.`purposeTime` ) AS `month` , YEAR( `work_hours`.`purposeTime` ) AS `year` , CASE `work_hours`.`statusId` WHEN 22 THEN SEC_TO_TIME( SUM( TIME_TO_SEC( SUBTIME( `work_hours`.`endHour` , `work_hours`.`startHour` ) ) ) ) ELSE 0 END AS `vic` , CASE `work_hours`.`statusId` WHEN 20 THEN SEC_TO_TIME( SUM( TIME_TO_SEC( SUBTIME( `work_hours`.`endHour` , `work_hours`.`startHour` ) ) ) ) ELSE 0 END AS `seek` , CASE WHEN `work_hours`.`statusId` <> 22 AND `work_hours`.`statusId` <> 20 THEN SEC_TO_TIME( SUM( TIME_TO_SEC( SUBTIME( `work_hours`.`endHour` , `work_hours`.`startHour` ) ) ) ) ELSE 0 END AS `hours` FROM `work_hours` , `persons` WHERE `work_hours`.`personId` = `persons`.`id` AND `work_hours`.`job` = TRUE GROUP BY `persons`.`fname_he` , `persons`.`lname_he`, YEAR(`work_hours`.`purposeTime`), MONTH(`work_hours`.`purposeTime`) ORDER BY `work_hours`.`purposeTime`


עכשיו זה נותן לי 0 ב- seek ו- vic למרות שצריך להיות שם ערכים.
כאשר הורדתי את ה- GROUP BY הבעיה נפתרה..
_____________________________________



נערך לאחרונה ע"י tnadav1 בתאריך 04-02-2008 בשעה 21:06.
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #11  
ישן 07-02-2008, 21:36
  DCD DCD אינו מחובר  
 
חבר מתאריך: 17.05.05
הודעות: 7,321
בתגובה להודעה מספר 10 שנכתבה על ידי tnadav1 שמתחילה ב "זה שדה מסוג INT, יכול להיות 1..."

הממ...

בשאילתת ה-GROUP BY:
ציטוט:
GROUP BY `persons`.`fname_he` , `persons`.`lname_he`, YEAR(`work_hours`.`purposeTime`), MONTH(`work_hours`.`purposeTime`)


נסה להוריד את החלק האחרון שכולל את:

קוד:
, YEAR(`work_hours`.`purposeTime`), MONTH(`work_hours`.`purposeTime`)


יכול להיות שזה הגורם העיקרי לבעיה...
כי הרי מתי שעושים GROUP BY אז נוצר מצב כזה שבכל הרשומות שבהם יש ערך שווה (אותו הדבר בדיוק) אצל האובייקט ששמת ב-GROUP BY (כמו האובייקט שהוא החודש של הטור purposeTime ) - זה ייבחר אך ורק את אחד מהרשומות האלו. וכנראה זה בוחר רשומה שהערך של statusId שלה שונה מ-22 ו-20.

וכפי ששמים לב, יש לך בטור purposeTime את אותו החודש מופיע פעמים רבות (כנ"ל לגבי השנה).

יכול להיות שצריך תיקון קטן לשאילתה...

אני די בטוח שכאשר תסיר את 2 הפרמטרים האחרונים בפיסקת ה-GROUP BY אז תקבל ב- vic וב- seek ערך השונה מ-0...עדכן אותי
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

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

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

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

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



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

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

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

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