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

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



  #2  
ישן 20-05-2011, 21:52
  stam1heahad stam1heahad אינו מחובר  
 
חבר מתאריך: 14.11.10
הודעות: 66
חישוב שעות ליום עבודה עם 2 שדות DateTime
בתגובה להודעה מספר 1 שנכתבה על ידי אוהבSQL שמתחילה ב "חישוב שעות ליום עבודה עם 2 שדות DateTime"

בניגוד ל MYSQL החופשי ששם החישוב פשוט ואלגנטי לדוגמא :
קוד:
SELECT TIME_FORMAT( TimeDiff( `End_Time` , `Beg_Time` ),'%H:%i' ) AS TtlHrs FROM `sumhrs`

MSSQL ב

המצב הרבה יותר מסובך: אני מצרף קוד שנכון במרבית המקרים
הבאג הוא במצב מיוחד שבו החישוב מתבצע על זמן סיום נמוך מזמן התחלה וגם אז מדובר רק עד ל 60 דקות ולאחר מכן הכל מסתדר
קוד:
SELECT PersID , CASE WHEN ((DATEDIFF( MINUTE , Beg_Time, End_Time) % 60) < 0 ) THEN CASE WHEN ( LEN(DATEDIFF( MINUTE , Beg_Time, End_Time) % 60 ) < 3 ) THEN CAST( DATEDIFF(MINUTE,Beg_Time ,End_Time)/60 as varchar)+ ':0' + cast(abs( (DATEDIFF( MI , Beg_Time ,End_Time )) % 60) as varchar(100) ) + ' Hrs' ELSE CAST( DATEDIFF(MINUTE,Beg_Time ,End_Time)/60 as varchar)+ ':' + cast(abs(( DATEDIFF( MI , Beg_Time ,End_Time )) % 60 ) as varchar(100) ) + ' Hrs' END ELSE CASE WHEN ( LEN(DATEDIFF( MINUTE , Beg_Time, End_Time) % 60 ) < 2 ) THEN CAST( datediff(MINUTE,Beg_Time ,End_Time)/60 as varchar) + ':0' + cast( ( DATEDIFF( MI , Beg_Time, End_Time)) % 60 as varchar(100) ) + ' Hrs' ELSE CAST( datediff(MINUTE,Beg_Time ,End_Time)/60 as varchar) + ':' + cast( ( DATEDIFF( MI , Beg_Time, End_Time)) % 60 as varchar(100) ) + ' Hrs' END END AS TtlHrs FROM sumhrs


בהצלחה במימוש
התוצאות אגב ניראות כך
TtlHrs
27:05 Hrs
42:00 Hrs
-4:05 Hrs

אם לא אוהב את הסיומת אז תמחק
+ ' Hrs'
בהצלחה

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

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

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

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

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



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

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

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

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