zeit_2_c11.sql 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. select "Employee No" as "Employee No",
  2. "Datum" as "Datum",
  3. "Department No" as "Department No",
  4. "Time Account No" as "Time Account No",
  5. "Time Account Value" as "Time Account Value",
  6. "No" as "No",
  7. "Description" as "Description",
  8. "Description 2" as "Description 2",
  9. "Zeitdauer" as "Zeitdauer",
  10. RSUM("Time Account Value") as "Summe (Zeitdauer) Nr.1",
  11. "gesamt Stunden" as "gesamt Stunden",
  12. RSUM("gesamt Stunden" for "Datum","Employee No") as "Summe (gesamt Stunden) Nr.3",
  13. RSUM("gesamt Stunden") as "Summe (gesamt Stunden) Nr.2",
  14. RSUM("gesamt Stunden") as "Summe (gesamt Stunden) Nr.1",
  15. "Hauptbetrieb" as "Hauptbetrieb",
  16. "Standort" as "Standort",
  17. "First Name" as "First Name",
  18. "Last Name" as "Last Name",
  19. "Monteur_Gruppe_ori_alt" as "Monteur_Gruppe_ori_alt",
  20. "Abteilung" as "Abteilung",
  21. "Monteur" as "Monteur",
  22. "Leaving Date" as "Leaving Date",
  23. "Group No 1" as "Group No 1",
  24. "Group No 2" as "Group No 2",
  25. "Group No 3" as "Group No 3",
  26. "Tage Heute Leaving Date" as "Tage Heute Leaving Date",
  27. "Monteur_Gruppe" as "Monteur_Gruppe",
  28. "produktiv/unproduktiv" as "produktiv/unproduktiv",
  29. "Monatserster" as "Monatserster",
  30. "Monatsletzter" as "Monatsletzter",
  31. "Heute" as "Heute",
  32. "Datum Tagesbericht" as "Datum Tagesbericht",
  33. "Employment Date" as "Employment Date",
  34. "Kostenstelle" as "Kostenstelle",
  35. "Filialcode_Employee" as "Filialcode_Employee",
  36. "Kostenstellencode_Employee" as "Kostenstellencode_Employee",
  37. "Name_Kostenstelle" as "Name_Kostenstelle",
  38. "Betrieb" as "Betrieb",
  39. "Monteur_Gruppe_2" as "Monteur_Gruppe_2",
  40. "Arbeitsvertragscode" as "Arbeitsvertragscode",
  41. "Task Type Group" as "Task Type Group",
  42. "Monteur_Gruppe_ori" as "Monteur_Gruppe_ori",
  43. "Kontrolle" as "Kontrolle",
  44. "Date" as "Date",
  45. "Company_ID" as "Company_ID",
  46. "Department_ID" as "Department_ID",
  47. "Mechanic_Group2" as "Mechanic_Group2",
  48. "Mechanic" as "Mechanic",
  49. "Mechanic_Productive" as "Mechanic_Productive",
  50. "Mechanic_Group1" as "Mechanic_Group1",
  51. "Order Number" as "Order Number",
  52. "Activity_Codes_Group1" as "Activity_Codes_Group1",
  53. "Activity_Codes_Group2_ori" as "Activity_Codes_Group2_ori",
  54. "Activity_Codes_Group2" as "Activity_Codes_Group2",
  55. "Activity_Desc" as "Activity_Desc",
  56. "Mechanic_Trainee" as "Mechanic_Trainee",
  57. "produktiv" as "produktiv",
  58. "unproduktiv" as "unproduktiv",
  59. "abwesend" as "abwesend",
  60. "Filialcode_Employee" as "Filialcode_Employee"
  61. from
  62. (select T1."Employee No_" as "Employee No",
  63. T1."Current Date" as "Datum",
  64. T1."Department No_" as "Department No",
  65. T1."Time Account No_" as "Time Account No",
  66. T1."Time Account Value" as "Time Account Value",
  67. T2."No_" as "No",
  68. T2."Description" as "Description",
  69. T2."Description 2" as "Description 2",
  70. T1."Time Account Value" as "Zeitdauer",
  71. CASE WHEN (T2."No_" IN (100)) THEN (T1."Time Account Value") ELSE (0) END as "gesamt Stunden",
  72. '1' as "Hauptbetrieb",
  73. CASE WHEN ((CASE WHEN ((((day((now()) - T3."Leaving Date"))) > 0) and (T3."Leaving Date" <> convert(datetime, '1753-01-01 00:00:00.000'))) THEN ('ausgetretene Mitarbeiter') ELSE (T3."Group No_ 1") END) IN ('MONTEUR1','AZUBI 4','AZUBI 3','SPENG FL','AZUBI 1','AZUBI 2')) THEN ('00') WHEN ((CASE WHEN ((((day((now()) - T3."Leaving Date"))) > 0) and (T3."Leaving Date" <> convert(datetime, '1753-01-01 00:00:00.000'))) THEN ('ausgetretene Mitarbeiter') ELSE (T3."Group No_ 1") END) = 'MONTEUR2') THEN ('02') WHEN ((T4."Filialcode" = '') and (not (CASE WHEN ((((day((now()) - T3."Leaving Date"))) > 0) and (T3."Leaving Date" <> convert(datetime, '1753-01-01 00:00:00.000'))) THEN ('ausgetretene Mitarbeiter') ELSE (T3."Group No_ 1") END) IN ('MONTEUR1','AZUBI 4','AZUBI 3','SPENG FL','AZUBI 1','AZUBI 2','MONTEUR2'))) THEN ('00') ELSE (T4."Filialcode") END as "Standort",
  74. T4."Vorname" as "First Name",
  75. T4."Nachname" as "Last Name",
  76. T3."Group No_ 1" as "Monteur_Gruppe_ori_alt",
  77. '' as "Abteilung",
  78. T4."Vorname" + ' ' + T4."Nachname" as "Monteur",
  79. T3."Leaving Date" as "Leaving Date",
  80. T3."Group No_ 1" as "Group No 1",
  81. T3."Group No_ 2" as "Group No 2",
  82. T3."Group No_ 3" as "Group No 3",
  83. (day((now()) - T3."Leaving Date")) as "Tage Heute Leaving Date",
  84. CASE WHEN ((((day((now()) - T3."Leaving Date"))) > 0) and (T3."Leaving Date" <> convert(datetime, '1753-01-01 00:00:00.000'))) THEN ('ausgetretene Mitarbeiter') ELSE (T3."Group No_ 1") END as "Monteur_Gruppe",
  85. CASE WHEN (T4."Global Dimension 1 Code" IN ('40','41','44','45')) THEN ('prod. Personal') ELSE ('unprod. Personal') END as "produktiv/unproduktiv",
  86. (convert(datetime, T1."Current Date" - cinterval(day(T1."Current Date") - 1))) as "Monatserster",
  87. (convert(datetime, lastday((T1."Current Date")))) as "Monatsletzter",
  88. (now()) as "Heute",
  89. CASE WHEN (((now())) BETWEEN ((convert(datetime, T1."Current Date" - cinterval(day(T1."Current Date") - 1)))) AND ((convert(datetime, lastday((T1."Current Date")))))) THEN (T1."Current Date") ELSE null END as "Datum Tagesbericht",
  90. T4."Anstellungsdatum" as "Employment Date",
  91. T4."Global Dimension 1 Code" + ' - ' + T5."Name" as "Kostenstelle",
  92. T4."Filialcode" as "Filialcode_Employee",
  93. T4."Global Dimension 1 Code" as "Kostenstellencode_Employee",
  94. T5."Name" as "Name_Kostenstelle",
  95. '00' as "Betrieb",
  96. CASE WHEN (T4."Arbeitsvertragscode" IN ('AZUBI')) THEN ('AZUBI') WHEN (T4."Arbeitsvertragscode" IN ('MEIST')) THEN ('Meister') WHEN (T3."Task Type Group" = 'UNPROD') THEN ((CASE WHEN ((((day((now()) - T3."Leaving Date"))) > 0) and (T3."Leaving Date" <> convert(datetime, '1753-01-01 00:00:00.000'))) THEN ('ausgetretene Mitarbeiter') ELSE (T3."Group No_ 1") END)) ELSE ('Monteur') END as "Monteur_Gruppe_2",
  97. T4."Arbeitsvertragscode" as "Arbeitsvertragscode",
  98. T3."Task Type Group" as "Task Type Group",
  99. T3."Group No_ 1" as "Monteur_Gruppe_ori",
  100. T1."Time Account Value" - ((CASE WHEN (T2."No_" = 370) THEN (T1."Time Account Value") ELSE (0) END) + (CASE WHEN (T2."No_" = 379) THEN (T1."Time Account Value") ELSE (0) END) + (CASE WHEN (T2."No_" = 352) THEN (T1."Time Account Value") ELSE (0) END) + (CASE WHEN (T2."No_" = 354) THEN (T1."Time Account Value") ELSE (0) END) + 0 + (CASE WHEN (T2."No_" = 450) THEN (T1."Time Account Value") ELSE (0) END) + (CASE WHEN (T2."No_" = 355) THEN (T1."Time Account Value") ELSE (0) END) + (CASE WHEN (T2."No_" IN (350,351)) THEN (T1."Time Account Value") ELSE (0) END)) as "Kontrolle",
  101. T1."Current Date" as "Date",
  102. '1' as "Company_ID",
  103. '00' as "Department_ID",
  104. (CASE WHEN (T4."Arbeitsvertragscode" IN ('AZUBI')) THEN ('AZUBI') WHEN (T4."Arbeitsvertragscode" IN ('MEIST')) THEN ('Meister') WHEN (T3."Task Type Group" = 'UNPROD') THEN ((CASE WHEN ((((day((now()) - T3."Leaving Date"))) > 0) and (T3."Leaving Date" <> convert(datetime, '1753-01-01 00:00:00.000'))) THEN ('ausgetretene Mitarbeiter') ELSE (T3."Group No_ 1") END)) ELSE ('Monteur') END) as "Mechanic_Group2",
  105. (T4."Vorname" + ' ' + T4."Nachname") as "Mechanic",
  106. CASE WHEN ((CASE WHEN (T4."Global Dimension 1 Code" IN ('40','41','44','45')) THEN ('prod. Personal') ELSE ('unprod. Personal') END) = 'prod. Personal') THEN ('produktiv') ELSE ('unproduktiv') END as "Mechanic_Productive",
  107. (CASE WHEN ((((day((now()) - T3."Leaving Date"))) > 0) and (T3."Leaving Date" <> convert(datetime, '1753-01-01 00:00:00.000'))) THEN ('ausgetretene Mitarbeiter') ELSE (T3."Group No_ 1") END) as "Mechanic_Group1",
  108. '' as "Order Number",
  109. CASE WHEN (T1."Time Account No_" BETWEEN '300' AND '450') THEN ('abw.') ELSE null END as "Activity_Codes_Group1",
  110. (left((cast_numberToString(cast_integer(T2."No_"))),3)) + ' - ' + T2."Description" as "Activity_Codes_Group2_ori",
  111. CASE WHEN (((left((cast_numberToString(cast_integer(T2."No_"))),3)) + ' - ' + T2."Description") IN ('302 - Arztbesuch')) THEN ('ARZT - Arztbesuch') ELSE (((left((cast_numberToString(cast_integer(T2."No_"))),3)) + ' - ' + T2."Description")) END as "Activity_Codes_Group2",
  112. (CASE WHEN (((left((cast_numberToString(cast_integer(T2."No_"))),3)) + ' - ' + T2."Description") IN ('302 - Arztbesuch')) THEN ('ARZT - Arztbesuch') ELSE (((left((cast_numberToString(cast_integer(T2."No_"))),3)) + ' - ' + T2."Description")) END) as "Activity_Desc",
  113. CASE WHEN ((CASE WHEN (T4."Arbeitsvertragscode" IN ('AZUBI')) THEN ('AZUBI') WHEN (T4."Arbeitsvertragscode" IN ('MEIST')) THEN ('Meister') WHEN (T3."Task Type Group" = 'UNPROD') THEN ((CASE WHEN ((((day((now()) - T3."Leaving Date"))) > 0) and (T3."Leaving Date" <> convert(datetime, '1753-01-01 00:00:00.000'))) THEN ('ausgetretene Mitarbeiter') ELSE (T3."Group No_ 1") END)) ELSE ('Monteur') END) IN ('AZUBI')) THEN ('Azubi') ELSE ('Monteur') END as "Mechanic_Trainee",
  114. 0 as "produktiv",
  115. 0 as "unproduktiv",
  116. T1."Time Account Value" as "abwesend",
  117. T4."Filialcode" as "Filialcode_Employee"
  118. from "CARLO"."import"."Employee_T" T3,
  119. ((("CARLO"."import"."Time_Entry_T" T1 left outer join "CARLO"."import"."Time_Account_T" T2 on (T1."Time Account No_" = (cast_numberToString(cast_integer(T2."No_")))) and (T1."Client_DB" = T2."Client_DB")) left outer join "CARLO"."import"."Employee" T4 on (T4."Nr_" = T1."Employee No_") and (T4."Client_DB" = T1."Client_DB")) left outer join "CARLO"."import"."Kostenstelle" T5 on (T4."Global Dimension 1 Code" = T5."Code") and (T4."Client_DB" = T5."Client_DB"))
  120. where ((T4."Nr_" = T3."No_") and (T4."Client_DB" = T3."Client_DB"))
  121. and ((((((T2."No_" BETWEEN 299 AND 499) and (T1."Current Date" >= T4."Anstellungsdatum")) and (T1."Current Date" >= T4."Anstellungsdatum")) and ((od_year(T1."Current Date")) >= (od_year((now()))) - 2)) and (T3."Group No_ 1" IN ('AZUBI','MEISTER','MONTEUR','ANG','SB','VK'))) and ((CASE WHEN (((T4."Vorname" + ' ' + T4."Nachname") = 'Udo Litzinger') and (T1."Current Date" >= convert(datetime, '2018-01-01 00:00:00.000'))) THEN ('raus') ELSE ('rein') END) = 'rein'))
  122. -- order by "Datum" asc,"Employee No" asc
  123. ) D1