Schichtplan_pro_MA_neu.sql 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. SELECT T1."REFERENCE_IDENT" AS "Reference Ident",
  2. T1."REFERENCE_NAME" AS "Reference Name",
  3. T1."CALENDAR_TYPE_ID" AS "Calendar Type Id_3",
  4. T1."TRANSACT_DATE" AS "Transact Date_2",
  5. T2."CALENDAR_INFO_ID" AS "Calendar Info Id_2",
  6. T2."CALENDAR_TYPE_ID" AS "Calendar Type Id_2",
  7. T2."RECURRING_PATTERN_ID" AS "Recurring Pattern Id_2",
  8. T2."RECURRING_PATTERN_PRIORITY" AS "Recurring Pattern Priority",
  9. T2."TRANSACT_DATE" AS "Transact Date",
  10. T3."SEL_NAME" AS "Name",
  11. (right(T2."RECURRING_PATTERN_ID", 3)) AS "Pattern_rechts_3",
  12. T4."CORE_WORKING_HOURS" AS "Std_Tag",
  13. T5."WORK_LEADER_GROUP" AS "Work Leader Group",
  14. T5."WORKLEADER_TEXT" AS "Workleader Text",
  15. T5."WORK_LEADER_GROUP" + ' - ' + T5."WORKLEADER_TEXT" AS "Monteur_Gruppe",
  16. T6."CALENDAR_EVENT_NAME" AS "Calendar Event Name",
  17. T6."EVENT_START" AS "Event Start",
  18. T6."EVENT_END" AS "Event End",
  19. T6."OCCURRENCE" AS "Occurrence",
  20. T6."ALL_DAY_EVENT" AS "All Day Event",
  21. T6."RECURRING_PATTERN_ID" AS "Recurring Pattern Id",
  22. T6."ACTIVITY_ID" AS "Activity Id",
  23. T6."CALENDAR_INFO_ID" AS "Calendar Info Id",
  24. T6."CALENDAR_TYPE_ID" AS "Calendar Type Id",
  25. T6."RECURRING_TYPE_ID" AS "Recurring Type Id",
  26. T6."HOLIDAY_ID" AS "Holiday Id",
  27. (datepart(weekday, T6."EVENT_START")) AS "Wochentag",
  28. T3."SEL_NAME" AS "Monteur_ori",
  29. T6."EVENT_START" AS "Datum",
  30. T7."PERS_DEPARTMENT" AS "Pers Department",
  31. T4."CLIENT_DB" AS "Hauptbetrieb",
  32. (left(T3."SEL_DEPARTMENT", 2)) AS "Standort",
  33. T8."PROFILE_CODE" AS "Profile Code",
  34. (substring(T3."SEL_DEPARTMENT", 4, 1)) AS "Kostenstelle",
  35. T4."CORE_WORKING_HOURS" AS "Feiertag",
  36. '' AS "Order Number",
  37. T9."WORK_LEADER_GROUP_ID" AS "Work Leader Group Id",
  38. T9."JOB_END_DATE" AS "Job End Date",
  39. T4."CORE_WORKING_HOURS" AS "abwesend",
  40. T4."RECURRING_PATTERN_ID" AS "Recurring Pattern Id_aus_Workin_Period",
  41. T4."CORE_WORKING_HOURS" AS "Core Working Hours",
  42. T4."WORKINGDAY" AS "Workingday",
  43. T4."START_DAY_ID" AS "Start Day Id",
  44. (rtrim(T8."PROFILE_CODE")) + ' - ' + T3."SEL_NAME" AS "Monteur",
  45. 'Abwesenheit' AS "Activity_Codes_Group1",
  46. 'Feiertag' AS "Activity_Codes_Group2",
  47. '' AS "Activity_Desc",
  48. T10."Hauptbetrieb_ID" AS "Hauptbetrieb Id",
  49. T10."Hauptbetrieb_Name" AS "Hauptbetrieb Name",
  50. T10."Standort_ID" AS "Standort Id",
  51. T10."Standort_Name" AS "Standort Name"
  52. FROM "OPTIMA"."import"."WORKING_PERIOD" T4,
  53. "OPTIMA"."import"."EMPLOYEE" T9,
  54. "OPTIMA"."import"."VPP91" T5,
  55. "OPTIMA"."import"."CALENDAR_EVENT" T6,
  56. (
  57. (
  58. "OPTIMA"."import"."CALENDAR_INFO" T1 LEFT JOIN "OPTIMA"."import"."CALENDAR_PATTERN" T2 ON (T2."CALENDAR_INFO_ID" = T1."REFERENCE_IDENT")
  59. AND (T2."CLIENT_DB" = T1."CLIENT_DB")
  60. ) LEFT JOIN "OPTIMA"."import"."PERSON_INFO" T7 ON (T1."REFERENCE_NAME" = T7."PERSON_NUMBER")
  61. AND (T1."CLIENT_DB" = T7."CLIENT_DB")
  62. ),
  63. (
  64. (
  65. "OPTIMA"."import"."VPP43" T3 LEFT JOIN "OPTIMA"."import"."PROFILE" T8 ON (T3."SELLER_CODE" = T8."PROFILE_CODE")
  66. AND (T3."CLIENT_DB" = T8."CLIENT_DB")
  67. ) LEFT JOIN "OPTIMA"."data"."GC_Department" T10 ON (T3."CLIENT_DB" = T10."Hauptbetrieb")
  68. AND ((left(T3."SEL_DEPARTMENT", 2)) = T10."Standort")
  69. )
  70. WHERE (
  71. (T8."PROFILE_CODE" = T1."REFERENCE_NAME")
  72. AND (T8."CLIENT_DB" = T1."CLIENT_DB")
  73. )
  74. AND (
  75. (T2."RECURRING_PATTERN_ID" = T4."RECURRING_PATTERN_ID")
  76. AND (T2."CLIENT_DB" = T4."CLIENT_DB")
  77. )
  78. AND (
  79. (T9."PERSON_ID" = T8."PERSON_ID")
  80. AND (T9."CLIENT_DB" = T8."CLIENT_DB")
  81. )
  82. AND (
  83. (T5."WORK_LEADER_GROUP" = T9."WORK_LEADER_GROUP_ID")
  84. AND (T5."CLIENT_DB" = T9."CLIENT_DB")
  85. )
  86. AND (
  87. (
  88. (
  89. (
  90. (
  91. (
  92. (
  93. (NOT T8."PROFILE_CODE" IN ('MARE'))
  94. AND (T6."HOLIDAY_ID" IS NOT NULL)
  95. )
  96. AND (T6."EVENT_START" >= convert(DATETIME, '2020-01-01 00:00:00.000'))
  97. )
  98. AND (T6."HOLIDAY_ID" IN (1, 3, 5, 6, 7, 9, 10, 12, 14, 17, 18))
  99. )
  100. AND (((datepart(weekday, T6."EVENT_START"))) BETWEEN 2 AND 6)
  101. )
  102. AND (T6."EVENT_START" < (getdate()))
  103. )
  104. AND ((T5."WORK_LEADER_GROUP" + ' - ' + T5."WORKLEADER_TEXT") IN ('1100 - LH KDD Mechaniker', '1700 - LH VW', '2100 - SE KDD Mechaniker', '2700 - SE VW', '3100 - L� KDD Mechaniker', '3200 - L� KAR', '3300 - L� LACK', '3700 - L� VW', '4100 - WE KDD Mechaniker', '4700 - WE VW', '6100 - DO KDD Mechaniker', '6700 - DO VW'))
  105. )
  106. AND (
  107. (T9."JOB_END_DATE" = convert(DATETIME, '1800-01-01 00:00:00.000'))
  108. OR (T6."EVENT_START" < T9."JOB_END_DATE")
  109. )
  110. )
  111. -- order by "Reference Name" asc