17154 выборка по колву строк
This commit is contained in:
		| @ -77,11 +77,16 @@ | ||||
| 	В запросе возможно настроить цветовое отображение полей документов в зависимости от условий. Для этого в запросе необходимо указать поле "Colors" и заполнить его одним из  следующих значений: `1 -  colors.gray 2 - colors.orange 3 - colors.yellow 4 - colors.green 5 - colors.blue	6 - colors.indigo 7 -colors.violet`. Например в запросе: **Все документы** данное значение указано в конце запроса: `(select  top 1 wr."VCode" from "RP_Worker" wr join "RP_PersonContact" pc on wr."IdPerson"= pc."Pcode" and pc."IdTypeContact" = 6 and pc."Code" = t."StageUser" where wr."COrg" = 4 order by wr."DateBeg" ) as "AnyColumnO" | ||||
| 	, 2`, где цифра 2 цвет | ||||
|  | ||||
| !!! note | ||||
| 	Для того чтобы запрос фильтровался по заданному количеству документов, которое указывается в поле **Кол-во строк/Период (с/по):** необзодимо в конце запроса добавить строку `_topcount` , например: ```left join "tmp_workers_for_documentStatusJournalProc" w2 on w2."VCode" =  t."IdWorker" _topcount;``` | ||||
|  | ||||
| Примеры запросов: | ||||
| ### Примеры запросов: | ||||
|  | ||||
| **Просроченные документы** - в реестре отображаются документы, по которым были нарушены сроки обработки: | ||||
|  | ||||
| Основной запрос:  | ||||
|  | ||||
| Итоговая выборка: | ||||
| ```sql | ||||
| insert into "tmp_finresult"( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeName"    , "SettingsId"      | ||||
|   							   , "orgId" , "DocumentDate" , "DocumentNumber"  , "VirtualCUser"  , "DateOfExecution"  | ||||
| @ -117,6 +122,9 @@ coalesce(dd."expired", 0) <> 0 ; | ||||
|  | ||||
| **Зависшие документы у инициатора** - в реестре отображаются документы, которые были инициированы сотрудником, но не запущены далее по маршруту согласования. | ||||
|  | ||||
| Основной запрос:  | ||||
|  | ||||
| Итоговая выборка: | ||||
| ```sql | ||||
| insert into "tmp_finresult"( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeName"    , "SettingsId"      | ||||
|   							   , "orgId" , "DocumentDate" , "DocumentNumber"  , "VirtualCUser"  , "DateOfExecution"  | ||||
| @ -141,6 +149,9 @@ insert into "tmp_finresult"( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeNa | ||||
|  | ||||
| **Поступят к hr в ближайшее время** - в реестре отображаются документы, которые в данный момент находятся на стадии согласования у руководителя сотрудника, и после этого поступят в HR службу. | ||||
|  | ||||
| Основной запрос:  | ||||
|  | ||||
| Итоговая выборка: | ||||
| ```sql | ||||
| insert into "tmp_finresult"( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeName"    , "SettingsId"      | ||||
|   							   , "orgId" , "DocumentDate" , "DocumentNumber"  , "VirtualCUser"  , "DateOfExecution"  | ||||
| @ -174,6 +185,9 @@ insert into "tmp_finresult"( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeNa | ||||
|  | ||||
| **Сейчас в работе у hr** - в реестре отображаются документы, которые в данный момент находятся в HR службе в работе | ||||
|  | ||||
| Основной запрос:  | ||||
|  | ||||
| Итоговая выборка: | ||||
| ```sql | ||||
| 	insert into "tmp_finresult"( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeName"    , "SettingsId"      | ||||
|   							   , "orgId" , "DocumentDate" , "DocumentNumber"  , "VirtualCUser"  , "DateOfExecution"  | ||||
| @ -200,6 +214,9 @@ insert into "tmp_finresult"( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeNa | ||||
|  | ||||
| **Обработано службой HR сегодня** - в реестре отображаются документы, которые были обработаны сегодня службой HR сегодня. | ||||
|  | ||||
| Основной запрос:  | ||||
|  | ||||
| Итоговая выборка: | ||||
| ```sql | ||||
| 	insert into "tmp_finresult"( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeName"    , "SettingsId"      | ||||
|   							   , "orgId" , "DocumentDate" , "DocumentNumber"  , "VirtualCUser"  , "DateOfExecution"  | ||||
| @ -227,138 +244,584 @@ insert into "tmp_finresult"( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeNa | ||||
|  | ||||
| **Все документы** | ||||
|  | ||||
| Основной запрос:  | ||||
| ```sql | ||||
| insert into #tmp_finresult( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeName"    , "SettingsId"      | ||||
| do $myQ$ | ||||
| declare _str text; | ||||
| begin | ||||
| _str := 'INSERT INTO "tmp_calcWithBaseParams_for_documentStatusJournalProc"( | ||||
|        "DocCode", "DocType", "DocForm", "DocTypeName", "SettingsId", "orgId", "DocumentDate", "DocumentNumber",  | ||||
| 	"VirtualCUser", "DateOfExecution", "DateControl","DocumentSubtype", "Department", | ||||
| 		"IdWorker", "DocumentCategory" | ||||
| ) | ||||
| SELECT distinct e."VCode" AS "DocCode", s."DocType", s."DocForm", s."DocName" AS "DocTypeName", s."VCode" AS "SettingsId", e."COrg" AS "orgId", e."DocumentDate", e."DocumentNumber" | ||||
|      , e."VirtualCUser", e."DateOfExecution", e."DateControl", e."DocumentSubtype", e."Department", | ||||
| 	 e."IdWorker",  (select u."DocumentCategory" from dfd."UniversalDocument" u where u."VCode" = e."VCode") /*u."DocumentCategory"*/ | ||||
| FROM comdoc."DocflowExists" AS e | ||||
|   JOIN comdoc."DocflowDocumentSettings" AS s ON s."DocType" = e."TypeName" | ||||
|   -- left join dfd."UniversalDocument" u on u."VCode" = e."VCode" | ||||
| WHERE 1 = 1 ' | ||||
| || case when coalesce("orgParam",-1111)=-1111 then '' else ' and e."COrg" = '||_orgid::text  end | ||||
| || case when EXISTS(SELECT 1 FROM "tmp_docTypes_for_documentStatusJournalProc" t) then ' | ||||
|   and EXISTS( | ||||
|   SELECT 1 FROM "tmp_docTypes_for_documentStatusJournalProc" AS t WHERE t."DocType" = e."TypeName" | ||||
| )'  else '' end | ||||
| || case when exists(select 1 from "tmp_docSubTypes_for_documentStatusJournalProc" ) then ' | ||||
| AND EXISTS( | ||||
|   SELECT 1 FROM "tmp_docSubTypes_for_documentStatusJournalProc" AS t WHERE comdoc.try_cast_bigint(t."DocSubType") = e."DocumentSubtype" | ||||
| ) ' else '' end||' | ||||
|  and coalesce( e."DocumentDate",'''||_bdate||''') between '''||_bdate||''' and '''||_edate||''' | ||||
|  and e."TypeName" not in (''ServiceDesk'');' ; | ||||
| -- }} Выборка по основным атрибутам документа | ||||
| execute _str; | ||||
| end; | ||||
| $myQ$; | ||||
| ``` | ||||
|  | ||||
| Итоговая выборка: | ||||
| ```sql | ||||
| IF NOT comdoc."isTableExists"('tmp_addAtribute_for_documentStatusJournalProc', 'temp') THEN | ||||
|   	CREATE TEMP  TABLE "tmp_addAtribute_for_documentStatusJournalProc"( | ||||
|       "PCode" bigint NOT NULL, | ||||
| 	  worker bigint, | ||||
| 	  bdate text, | ||||
| 	  edate text, | ||||
| 	  kolvo text, | ||||
| 	  other text, | ||||
| 	 /* bdate_new1 text, | ||||
| 	  edate_new1 text, | ||||
| 	  kolvo_new1 text, | ||||
| 	  bdate_new2 text, | ||||
| 	  edate_new2 text, | ||||
| 	  kolvo_new2 text,*/ | ||||
| 	  TypeName varchar(255) | ||||
| 	   | ||||
|   );--  ON COMMIT DROP; | ||||
|   end if; | ||||
|    | ||||
|     IF NOT comdoc."isTableExists"('tmp_workers_for_documentStatusJournalProc', 'temp') THEN | ||||
|   	CREATE TEMP TABLE "tmp_workers_for_documentStatusJournalProc"( | ||||
|       "VCode" bigint NOT NULL, | ||||
| 	  "Login" varchar(255), | ||||
| 	  "NumTab" varchar(255), | ||||
| 	  "NameFull" varchar(255) | ||||
|   ) ;-- ON COMMIT DROP; | ||||
|   end if;  | ||||
|    | ||||
|   insert into "tmp_addAtribute_for_documentStatusJournalProc" | ||||
| select daa1."PCode", max(case when bd."ColumnName" = '#Worker#' then daa1."BigIntValue" end) as Worker,  | ||||
| max(case when bd."ColumnName" = '#bdate#' then to_char(daa1."DateValue", 'DD.MM.YYYY') end) as bdate,  | ||||
| max(case when bd."ColumnName" = '#edate#' then to_char(daa1."DateValue", 'DD.MM.YYYY') end) as edate,  | ||||
| max(case when bd."ColumnName" = '#kolvo#' then daa1."BigIntValue"::text end) as kolvo,  | ||||
| string_agg(case when bd."ColumnName" not in ('#bdate#', '#edate#', '#kolvo#','#bdate_new1#', '#edate_new1#', '#kolvo_new1#') then bd."Name" || ':' || (case  | ||||
| 				when coalesce(bd."AttributeType",'')  = 'string' and  coalesce(daa1."Value",'') <> '' then daa1."Value" | ||||
| 				when coalesce(bd."AttributeType",'')  = 'string' and coalesce(daa1."Value",'') = '' then ' ' | ||||
| 				 | ||||
| 				when coalesce(bd."AttributeType",'')  = 'bigint' and daa1."BigIntValue" is not null then cast(daa1."BigIntValue" as varchar(255)) | ||||
| 				when coalesce(bd."AttributeType",'')  = 'bigint' and daa1."BigIntValue" is null then ' ' | ||||
| 				 | ||||
| 				when coalesce(bd."AttributeType",'')  = 'string' and daa1."BigIntValue" is not null then cast(daa1."BigIntValue" as varchar(255)) | ||||
| 				when coalesce(bd."AttributeType",'')  = 'string' and daa1."BigIntValue" is null then ' ' | ||||
|  | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.Unispr' and daa1."BigIntValue" is null and coalesce(daa1."Value",'') = '' then ' ' | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.Unispr' and daa1."BigIntValue" is not null and coalesce(daa1."Value",'') <> '' then coalesce(daa1."Value",' ') | ||||
|  | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.Post' and daa1."BigIntValue" is null and coalesce(daa1."Value",'') = '' then ' ' | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.Post' and daa1."BigIntValue" is not null and coalesce(daa1."Value",'') <> '' then coalesce(daa1."Value",' ') | ||||
|  | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.RP_Worker' and daa1."BigIntValue" is null and coalesce(daa1."Value",'') = '' then ' ' | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.RP_Worker' and daa1."BigIntValue" is not null and coalesce(daa1."Value",'') <> '' then coalesce(daa1."Value",' ') | ||||
|  | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.Contract' and daa1."BigIntValue" is null and coalesce(daa1."Value",'') = '' then ' ' | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.Contract' and daa1."BigIntValue" is not null and coalesce(daa1."Value",'') <> '' then coalesce(daa1."Value",' ') | ||||
|  | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.Contractor' and daa1."BigIntValue" is null and coalesce(daa1."Value",'') = '' then ' ' | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.Contractor' and daa1."BigIntValue" is not null and coalesce(daa1."Value",'') <> '' then coalesce(daa1."Value",' ') | ||||
|  | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.Department' and daa1."BigIntValue" is null and coalesce(daa1."Value",'') = '' then ' ' | ||||
| 				when coalesce(bd."AttributeType",'') = 'Base.Department' and daa1."BigIntValue" is not null and coalesce(daa1."Value",'') <> '' then coalesce(daa1."Value",' ') | ||||
|  | ||||
| 				when coalesce(bd."AttributeType",'') = 'money' and daa1."MoneyValue"  is not null then cast(daa1."MoneyValue" as varchar(255)) | ||||
| 				when coalesce(bd."AttributeType",'') = 'money' and daa1."MoneyValue"  is  null then ' ' | ||||
|  | ||||
| 				when coalesce(bd."AttributeType",'') = 'Date' and daa1."DateValue"  is not null then to_char(daa1."DateValue", 'DD.MM.YYYY') | ||||
| 				when coalesce(bd."AttributeType",'') = 'Date' and daa1."DateValue"  is null then ' ' | ||||
|  | ||||
|         		when coalesce(bd."AttributeType",'') = 'DateTime' and daa1."DateTimeValue"  is not null then to_char(daa1."DateValue", 'DD.MM.YYYY') | ||||
| 				when coalesce(bd."AttributeType",'') = 'DateTime' and daa1."DateTimeValue"  is null then ' ' | ||||
| 			 | ||||
| 				when coalesce(bd."AttributeType",'')  = 'double' and daa1."DoubleValue"  is not null then cast(daa1."DoubleValue" as varchar(255)) | ||||
| 				when coalesce(bd."AttributeType",'')  = 'double' and daa1."DoubleValue"  is null then ' ' | ||||
|  | ||||
| 				when coalesce(bd."AttributeType",'')  = 'ServiceWord' and coalesce(daa1."Value",'') <> '' then coalesce(daa1."Value",' ')  | ||||
| 				when coalesce(bd."AttributeType",'')  = 'ServiceWord' and coalesce(daa1."Value",'') = '' then ' ' | ||||
|  | ||||
|        	 		when coalesce(bd."AttributeType",'')  = 'bool' and coalesce(daa1."BigIntValue"::integer,0) = 0 then substring(coalesce(daa1."Value",'|'),	position('|' in coalesce(daa1."Value",'|'))+1,char_length(coalesce(daa1."Value",'|'))) | ||||
| 				when coalesce(bd."AttributeType",'')  = 'bool' and coalesce(daa1."BigIntValue"::integer,0) = 1 then substring(coalesce(daa1."Value",'|'),0,	position('|' in coalesce(daa1."Value",'|'))) | ||||
| 								 | ||||
| 			end) end , '; ')   as other, | ||||
| /*max(case when bd."ColumnName" = '#bdate_new1#' then to_char(daa1."DateValue", 'DD.MM.YYYY') end) as bdate_new1,  | ||||
| max(case when bd."ColumnName" = '#edate_new1#' then to_char(daa1."DateValue", 'DD.MM.YYYY') end) as edate_new1,  | ||||
| max(case when bd."ColumnName" = '#kolvo_new1#' then daa1."BigIntValue"::text end) as kolvo_new1, | ||||
| max(case when bd."ColumnName" = '#bdate_new2#' then to_char(daa1."DateValue", 'DD.MM.YYYY') end) as bdate_new2,  | ||||
| max(case when bd."ColumnName" = '#edate_new2#' then to_char(daa1."DateValue", 'DD.MM.YYYY') end) as edate_new2,  | ||||
| max(case when bd."ColumnName" = '#kolvo_new2#' then daa1."BigIntValue"::text end) as kolvo_new2,*/ | ||||
| max(a."DocType") as TypeName  | ||||
| from dfd."DocumentAdditionalAttribute" daa1 | ||||
| join dfd."DocumentCategoryAttributeType" bd on daa1."CategoryAttributeType" = bd."VCode" | ||||
| join "tmp_calcWithBaseParams_for_documentStatusJournalProc_distinctVC" a on daa1."PCode" = a."DocCode" | ||||
| where a."DocType" in ('DocumentForSigining','UniversalDocument', 'EmployeeStatement') | ||||
| group by daa1."PCode"; | ||||
|  | ||||
| insert into "tmp_workers_for_documentStatusJournalProc" | ||||
| select w."VCode", max(pc."Code") as "Login", max(w."NumTab") as "NumTab", max(w."NameFull") as "NameFull" | ||||
| from rp."RP_Worker" w | ||||
| left join rp."RP_PersonContact" AS pc  on pc."Pcode" = w."IdPerson" AND pc."IdTypeContact" = 6 | ||||
| left join rp."RP_WorkerMove" mov on mov."IdWorker" = w."VCode" | ||||
| group by w."VCode" ; | ||||
|  | ||||
| insert into "tmp_finresult"( "DocCode", "DocType", "DocForm", "DocTypeName", "SettingsId"      | ||||
|   	, "orgId", "DocumentDate", "DocumentNumber", "VirtualCUser", "DateOfExecution"  | ||||
| 	, "DateControl", "RouteVCode", "RouteStatusId", "RouteStatusName", "DocName"      | ||||
| 	, "DocSubject", "expired", "StageNumber", "BeginDate", "ActionDate"     | ||||
| 	, "DocumentAction", "DocumentStatus", "FromMessage", "eDate"            | ||||
| 	, "StageUser", "StageItemStatus", "StageStatus", "StageItemAction", "IsMarked", "DocumentSubtype" | ||||
| 	, "AnyColumnA", "AnyColumnB", "AnyColumnC", "AnyColumnD", "AnyColumnE" | ||||
| 	, "AnyColumnF", "AnyColumnG" , "AnyColumnH", "AnyColumnI", "AnyColumnJ" | ||||
| 	, "AnyColumnK", "AnyColumnL", "AnyColumnM", "AnyColumnN", "EmailRecipient", "AnyColumnO", "Colors") | ||||
|  | ||||
| select t."DocCode", t."DocType", t."DocForm", t."DocTypeName", t."SettingsId"      | ||||
| 	, t."orgId" , t."DocumentDate" , t."DocumentNumber",       | ||||
| 	(case when    t."DocType"  in ('UniversalDocument','DocumentForSigning') then w."Login" else   t."VirtualCUser"  end)  , | ||||
|  	null/*t."DateOfExecution"*/ | ||||
| 	, t."DateControl", t."RouteVCode", t."RouteStatusId", t."RouteStatusName", t."DocName"      | ||||
| 	, t."DocSubject", null/* coalesce(t."expired", case when coalesce(t."eDate", t."ActionDate", _now)<COALESCE(t."ActionDate", _now) then comdoc."dfwcGetDuration"( | ||||
|                 t."eDate", COALESCE(t."ActionDate", _now), false, t."orgId", 1, _dayoff1, _dayoff2, null) end) */ | ||||
| 	, null/* t."StageNumber"  */, null/*t."BeginDate" */, null/*t."ActionDate"   */  | ||||
| 	, null/* t."DocumentAction"*/ , null/*t."DocumentStatus" */, null /*t."FromMessage" */, null /*t."eDate"*/ | ||||
| 	, null /*t."StageUser"  */, null /*t."StageItemStatus"*/, null/*t."StageStatus"  */, null/*t."StageItemAction"*/, t."IsMarked", t."DocumentSubtype"	 | ||||
| 	, t."AnyColumnA", null as  "AnyColumnB", null as "AnyColumnC", null as "AnyColumnD" ,  t."AnyColumnE"  | ||||
| 	, addit.bdate  as "AnyColumnF", addit.edate as "AnyColumnG", addit.kolvo as "AnyColumnH", addit.other as "AnyColumnI", null/*sii."Name"*/ as "AnyColumnJ", | ||||
| 	case when coalesce(t."RouteStatusId",0) = 2  | ||||
| 			and exists (select 1 from comdoc."RouteStage" rs where rs."PCode" = t."RouteVCode" and rs."StageNumber" = 1 and rs."Status" = 2  ) then 'Не запущен' | ||||
|   		when coalesce(t."RouteStatusId",0) = 2  and t."StageItemStatus"= 2  and t."StageNumber" > 1  | ||||
| 	        and exists (select 1 from  comdoc."RouteStage" rs where  rs."PCode" = t."RouteVCode" and rs."IsMarked" is not true and rs."StageName"  in ( 'Исполнить') | ||||
|                            and rs."Status"=1) then 'На согласовании / на согл у рук-ля' | ||||
|         when coalesce(t."RouteStatusId",0) =  3   | ||||
|             and not exists (select 1 from  comdoc."RouteStage" rs  | ||||
| 				            join comdoc."StageItem" si on rs."VCode" = si."PCode" | ||||
| 				            where  rs."PCode" = t."RouteVCode" and si."DocumentStatus" in (19,23))  then 'Завершен' | ||||
|         when coalesce(t."RouteStatusId",0) =  3   | ||||
| 			and exists (select 1 from  comdoc."RouteStage" rs  | ||||
| 				        join comdoc."StageItem" si on rs."VCode" = si."PCode" | ||||
| 				        where  rs."PCode" = t."RouteVCode" and si."DocumentStatus" in (19,23)) then 'Отклонен' end as "AnyColumnK" | ||||
| 	, ( SELECT DISTINCT string_agg(u."Initials"|| '(' || ds."Name"|| ')' , '; ')  AS "x" | ||||
|         FROM comdoc."RouteStage" as rs | ||||
|            join  comdoc."StageItem" AS i on i."PCode" = rs."VCode" | ||||
|            join comdoc."VUserMeta" AS u ON u."VCode" = i."StageUser" | ||||
|           join comdoc."DocumentStatus" AS ds ON ds."VCode" = i."DocumentStatus" | ||||
|          WHERE rs."PCode" = t."RouteVCode" AND i."StageItemStatus" = 3 and coalesce(i."DocumentStatus",0) <> 0) as "AnyColumnL" | ||||
| 	, case when  t."DocType"  in ('UniversalDocument','DocumentForSigning') then w."NumTab" else w2."NumTab" end as "AnyColumnM" | ||||
| 	, case when  t."DocType"  in ('UniversalDocument','DocumentForSigning') then w."NameFull" else w2."NameFull" end as "AnyColumnN" | ||||
| 	, (select wr."VCode" from rp."RP_Worker" wr join rp."RP_PersonContact" pc on wr."IdPerson"= pc."Pcode" and pc."IdTypeContact" = 6 and pc."Code" = t."StageUser" where wr."COrg" = 1 order by wr."DateBeg" limit 1) as "EmailRecipient" | ||||
| 	, (select wr."VCode" from rp."RP_Worker" wr join rp."RP_PersonContact" pc on wr."IdPerson"= pc."Pcode" and pc."IdTypeContact" = 6 and pc."Code" = t."StageUser" where wr."COrg" = 1 order by wr."DateBeg" limit 1) as "AnyColumnO" | ||||
| 	, 3 | ||||
| from "tmp_preresult" t  | ||||
| left join "tmp_addAtribute_for_documentStatusJournalProc" addit on addit."PCode" = t."DocCode" --and addit.TypeName = "DocType" | ||||
| left join "tmp_workers_for_documentStatusJournalProc" w on w."VCode" = addit.worker | ||||
| left join "tmp_workers_for_documentStatusJournalProc" w2 on w2."VCode" =  t."IdWorker" | ||||
| _topcount; | ||||
| drop table "tmp_addAtribute_for_documentStatusJournalProc"; | ||||
| drop table "tmp_workers_for_documentStatusJournalProc"; | ||||
| ``` | ||||
|  | ||||
| **Документы на подписание, просроченные работниками** | ||||
|  | ||||
| Основной запрос:  | ||||
|  | ||||
| Итоговая выборка: | ||||
| ```sql | ||||
|  insert into "tmp_finresult"( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeName"    , "SettingsId"      | ||||
|   							   , "orgId" , "DocumentDate" , "DocumentNumber"  , "VirtualCUser"  , "DateOfExecution"  | ||||
| 							   , "DateControl"     , "RouteVCode"  , "RouteStatusId"   , "RouteStatusName"  , "DocName"      | ||||
| 							    , "DocSubject"  	  , "expired" , "StageNumber"  	   , "BeginDate"     , "ActionDate"     | ||||
| 								, "DocumentAction" , "DocumentStatus"  , "FromMessage"      , "eDate"            | ||||
| 	   							, "StageUser"           , "StageItemStatus"  , "StageStatus"      , "StageItemAction" , "IsMarked", "DocumentSubtype"   , "AnyColumnA" , "AnyColumnB" , "AnyColumnC" 	, "AnyColumnD" 	, "AnyColumnE",  | ||||
|                                             "AnyColumnF", "AnyColumnG" , "AnyColumnH" 	, "AnyColumnI", "AnyColumnJ", "AnyColumnK","AnyColumnL", "AnyColumnM","AnyColumnN", "EmailRecipient","AnyColumnO", "Colors") | ||||
| 								, "DocumentAction" , "DocumentStatus"  , "FromMessage"      , "eDate", "Department"            | ||||
| 	   							, "StageUser"           , "StageItemStatus"  , "StageStatus"      , "StageItemAction" , "DocumentSubtype"   , | ||||
|  "AnyColumnA" , "AnyColumnB" , "AnyColumnC" 	, "AnyColumnD" 	, "AnyColumnE" ) | ||||
|   | ||||
| select t."DocCode"   , t."DocType"   , t."DocForm"  , t."DocTypeName"    , t."SettingsId"      | ||||
|   							   , t."orgId" , t."DocumentDate" , t."DocumentNumber"  ,       | ||||
| (case when    t."DocType"  in ('UniversalDocument','DocumentForSigning') then (select top 1 pc."Code"   from "DocumentCategoryAttributeType" bd  | ||||
|                                                                         join "DocumentAdditionalAttribute" daa1 on t."DocCode" = daa1."PCode" and daa1."CategoryAttributeType" = bd."VCode" and bd."ColumnName" = '#Worker#' | ||||
|                                                                       join "RP_Worker" w on w."VCode" = daa1."BigIntValue" | ||||
|                                                                       join "RP_PersonContact" AS pc ON pc."Pcode" = w."IdPerson" AND pc."IdTypeContact" = 6 | ||||
|                                                                         where  t."DocumentCategory" = bd."PCode")  | ||||
|             else   t."VirtualCUser"  end)  , | ||||
|  null/*t."DateOfExecution"*/	   , t."DateControl"     , t."RouteVCode"  , t."RouteStatusId"   , t."RouteStatusName"  , t."DocName"      | ||||
|   							   , t."orgId" , t."DocumentDate" , t."DocumentNumber"  , t."VirtualCUser"  , t."DateOfExecution"  | ||||
| 							   , t."DateControl"     , t."RouteVCode"  , t."RouteStatusId"   , t."RouteStatusName"  , t."DocName"      | ||||
| 							    , t."DocSubject"  	  ,    | ||||
| null/* comdoc."dfwcGetDuration"( | ||||
|                 t."eDate", COALESCE(t."ActionDate", _now), false, t."orgId", 1, _dayoff1, _dayoff2, null | ||||
|             ) */ | ||||
| 			, null/* t."StageNumber"  */	   ,  null/*t."BeginDate" */    ,  null/*t."ActionDate"   */  | ||||
| 								,null/* t."DocumentAction"*/ ,  null/*t."DocumentStatus" */ ,  null /*t."FromMessage" */     ,  null /*t."eDate"*/ | ||||
| 	   							, null /*t."StageUser"  */         , null /*t."StageItemStatus"*/  , null/*t."StageStatus"  */    , null/*t."StageItemAction"*/, t."IsMarked", t."DocumentSubtype"	, t."AnyColumnA" ,  | ||||
| null as  "AnyColumnB" , | ||||
| null as "AnyColumnC",  | ||||
| null as "AnyColumnD"  ,  t."AnyColumnE" , | ||||
| (select top 1  convert(varchar,daa1."DateValue",104)   from "DocumentCategoryAttributeType" bd  | ||||
|  join "DocumentAdditionalAttribute" daa1 on t."DocCode" = daa1."PCode" and daa1."CategoryAttributeType" = bd."VCode" and bd."ColumnName" = '#bdate#' where  t."DocumentCategory" = bd."PCode" )  as "AnyColumnF" , | ||||
| (select top 1 convert(varchar,daa1."DateValue",104)    from "DocumentCategoryAttributeType" bd  | ||||
|  join "DocumentAdditionalAttribute" daa1 on t."DocCode" = daa1."PCode" and daa1."CategoryAttributeType" = bd."VCode" and bd."ColumnName" = '#edate#' where  t."DocumentCategory" = bd."PCode")   as "AnyColumnG" , | ||||
| (select top 1 daa1."BigIntValue" from "DocumentCategoryAttributeType" bd  | ||||
|  join "DocumentAdditionalAttribute" daa1 on t."DocCode" = daa1."PCode" and daa1."CategoryAttributeType" = bd."VCode" and bd."ColumnName" ='#kolvo#' where  t."DocumentCategory" = bd."PCode")  as "AnyColumnH", | ||||
| /* (select string_agg(dca."Name" || ':' || (case  | ||||
| 				when coalesce(dca."AttributeType",'')  = 'string' and  coalesce(atr."Value",'') <> '' then atr."Value" | ||||
| 				when coalesce(dca."AttributeType",'')  = 'string' and coalesce(atr."Value",'') = '' then ' ' | ||||
| 				 | ||||
| 				when coalesce(dca."AttributeType",'')  = 'bigint' and atr."BigIntValue" is not null then cast(atr."BigIntValue" as varchar(255)) | ||||
| 				when coalesce(dca."AttributeType",'')  = 'bigint' and atr."BigIntValue" is null then ' ' | ||||
| 				 | ||||
| 				when coalesce(dca."AttributeType",'')  = 'string' and atr."BigIntValue" is not null then cast(atr."BigIntValue" as varchar(255)) | ||||
| 				when coalesce(dca."AttributeType",'')  = 'string' and atr."BigIntValue" is null then ' ' | ||||
|  | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.Unispr' and atr."BigIntValue" is null and coalesce(atr."Value",'') = '' then ' ' | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.Unispr' and atr."BigIntValue" is not null and coalesce(atr."Value",'') <> '' then coalesce(atr."Value",' ') | ||||
|  | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.Post' and atr."BigIntValue" is null and coalesce(atr."Value",'') = '' then ' ' | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.Post' and atr."BigIntValue" is not null and coalesce(atr."Value",'') <> '' then coalesce(atr."Value",' ') | ||||
|  | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.RP_Worker' and atr."BigIntValue" is null and coalesce(atr."Value",'') = '' then ' ' | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.RP_Worker' and atr."BigIntValue" is not null and coalesce(atr."Value",'') <> '' then coalesce(atr."Value",' ') | ||||
|  | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.Contract' and atr."BigIntValue" is null and coalesce(atr."Value",'') = '' then ' ' | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.Contract' and atr."BigIntValue" is not null and coalesce(atr."Value",'') <> '' then coalesce(atr."Value",' ') | ||||
|  | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.Contractor' and atr."BigIntValue" is null and coalesce(atr."Value",'') = '' then ' ' | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.Contractor' and atr."BigIntValue" is not null and coalesce(atr."Value",'') <> '' then coalesce(atr."Value",' ') | ||||
|  | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.Department' and atr."BigIntValue" is null and coalesce(atr."Value",'') = '' then ' ' | ||||
| 				when coalesce(dca."AttributeType",'') = 'Base.Department' and atr."BigIntValue" is not null and coalesce(atr."Value",'') <> '' then coalesce(atr."Value",' ') | ||||
|  | ||||
| 				when coalesce(dca."AttributeType",'') = 'money' and atr."MoneyValue"  is not null then cast(atr."MoneyValue" as varchar(255)) | ||||
| 				when coalesce(dca."AttributeType",'') = 'money' and atr."MoneyValue"  is  null then ' ' | ||||
|  | ||||
| 				when coalesce(dca."AttributeType",'') = 'Date' and atr."DateValue"  is not null then to_char(atr."DateValue", 'DD.MM.YYYY') | ||||
| 				when coalesce(dca."AttributeType",'') = 'Date' and atr."DateValue"  is null then ' ' | ||||
|  | ||||
|         		when coalesce(dca."AttributeType",'') = 'DateTime' and atr."DateTimeValue"  is not null then to_char(atr."DateValue", 'DD.MM.YYYY') | ||||
| 				when coalesce(dca."AttributeType",'') = 'DateTime' and atr."DateTimeValue"  is null then ' ' | ||||
| 			 | ||||
| 				when coalesce(dca."AttributeType",'')  = 'double' and atr."DoubleValue"  is not null then cast(atr."DoubleValue" as varchar(255)) | ||||
| 				when coalesce(dca."AttributeType",'')  = 'double' and atr."DoubleValue"  is null then ' ' | ||||
|  | ||||
| 				when coalesce(dca."AttributeType",'')  = 'ServiceWord' and coalesce(atr."Value",'') <> '' then coalesce(atr."Value",' ')  | ||||
| 				when coalesce(dca."AttributeType",'')  = 'ServiceWord' and coalesce(atr."Value",'') = '' then ' ' | ||||
|  | ||||
|        	 		when coalesce(dca."AttributeType",'')  = 'bool' and coalesce("BigIntValue"::integer,0) = 0 then substring(coalesce("Value",'|'),	position('|' in coalesce("Value",'|'))+1,char_length(coalesce("Value",'|'))) | ||||
| 				when coalesce(dca."AttributeType",'')  = 'bool' and coalesce("BigIntValue"::integer,0) = 1 then substring(coalesce("Value",'|'),0,	position('|' in coalesce("Value",'|'))) | ||||
| 								 | ||||
| 			end), '; ') AS "x" | ||||
| 				    from   "DocumentAdditionalAttribute" atr  | ||||
|           			    join "DocumentCategoryAttributeType" dca on atr."CategoryAttributeType" = dca."VCode" | ||||
| 				    where  t."DocCode" = atr."PCode" and dca."ColumnName" not in ('#bdate#', '#edate#', '#kolvo#'))  | ||||
| */ null as "AnyColumnI", | ||||
| null/*sii."Name"*/, | ||||
| case  when coalesce(t."RouteStatusId",0) = 2 and exists (select 1 from "RouteStage" rs  | ||||
|                                                                                 where rs."PCode" = t."RouteVCode" and rs."StageNumber" = 1 and rs."Status" = 2  ) then 'Не запущен' | ||||
|   when coalesce(t."RouteStatusId",0) = 2  and t."StageItemStatus"= 2  and t."StageNumber" > 1  | ||||
| 	              and exists (select 1 from  "RouteStage" rs  | ||||
| 				where  rs."PCode" = t."RouteVCode"  | ||||
| 				and isnull(rs."IsMarked",0) = 1 | ||||
| 				and rs."StageName"  in ( 'Исполнить') | ||||
|                            and rs."Status"=1) then 'На согласовании / на согл у рук-ля' | ||||
|             when coalesce(t."RouteStatusId",0) =  3   | ||||
|                        and not exists (select 1 from  "RouteStage" rs  | ||||
| 				                  join "StageItem" si on rs."VCode" = si."PCode" | ||||
| 				                   where  rs."PCode" = t."RouteVCode"  | ||||
| 				                    and si."DocumentStatus" in (19,23))  then 'Завершен' | ||||
|            when coalesce(t."RouteStatusId",0) =  3  and       exists (select 1 from  "RouteStage" rs  | ||||
| 				                  join "StageItem" si on rs."VCode" = si."PCode" | ||||
| 				                   where  rs."PCode" = t."RouteVCode"  | ||||
| 				                    and si."DocumentStatus" in (19,23)) then 'Отклонен' | ||||
| end as "AnyColumnK", | ||||
| /*( SELECT DISTINCT string_agg(u."Initials"|| '(' || ds."Name"|| ')' , '; ')  AS "x" | ||||
|          FROM "RouteStage" as rs | ||||
|            join  "StageItem" AS i on i."PCode" = rs."VCode" | ||||
|            join "VUserMeta" AS u ON u."VCode" = i."StageUser" | ||||
|           join "DocumentStatus" AS ds ON ds."VCode" = i."DocumentStatus" | ||||
|          WHERE rs."PCode" = t."RouteVCode" | ||||
|            AND i."StageItemStatus" = 3 | ||||
|           and coalesce(i."DocumentStatus",0) <> 0 | ||||
|      ) */ '' as "AnyColumnL", | ||||
|  | ||||
| case when  t."DocType"  in ('UniversalDocument','DocumentForSigning')  then  (select top 1  w."NumTab"  from "DocumentCategoryAttributeType" bd  | ||||
|                                                                         join "DocumentAdditionalAttribute" daa1 on t."DocCode" = daa1."PCode" and daa1."CategoryAttributeType" = bd."VCode" and bd."ColumnName" = '#Worker#' | ||||
|                                                                       join "RP_Worker" w on w."VCode" = daa1."BigIntValue" | ||||
|                                                                         where  t."DocumentCategory" = bd."PCode") | ||||
|             else (select r."NumTab" from "RP_Worker" as r where r."VCode" = t."IdWorker")  end as "AnyColumnM", | ||||
|  | ||||
| case when  t."DocType"  in ('UniversalDocument','DocumentForSigning')  then  (select top 1 w."NameFull"  from "DocumentCategoryAttributeType" bd  | ||||
|                                                                         join "DocumentAdditionalAttribute" daa1 on t."DocCode" = daa1."PCode" and daa1."CategoryAttributeType" = bd."VCode" and bd."ColumnName" = '#Worker#' | ||||
|                                                                       join "RP_Worker" w on w."VCode" = daa1."BigIntValue" | ||||
|                                                                         where  t."DocumentCategory" = bd."PCode" ) | ||||
|             else (select r."NameFull" from "RP_Worker" as r where r."VCode" = t."IdWorker")  end as "AnyColumnN", | ||||
| (select  top 1 wr."VCode" from "RP_Worker" wr join "RP_PersonContact" pc on wr."IdPerson"= pc."Pcode" and pc."IdTypeContact" = 6 and pc."Code" = t."StageUser" where wr."COrg" = 4 order by wr."DateBeg" ) as "EmailRecipient", | ||||
| (select  top 1 wr."VCode" from "RP_Worker" wr join "RP_PersonContact" pc on wr."IdPerson"= pc."Pcode" and pc."IdTypeContact" = 6 and pc."Code" = t."StageUser" where wr."COrg" = 4 order by wr."DateBeg" ) as "AnyColumnO" | ||||
| , 2 | ||||
| from #tmp_preresult t | ||||
|    where  t."DocType" not in ('ServiceDesk')  and  | ||||
|  ( | ||||
|   t."DocumentDate" IS NULL OR t."DocumentDate" BETWEEN @_bdate AND @_edate | ||||
| ) | ||||
|    and t."DocType" not in ('ServiceDesk') ; | ||||
| 					comdoc."dfwcGetDuration"(t."eDate", COALESCE(t."ActionDate", _now), false, t."orgId", 1, _dayoff1, _dayoff2, null) ,  | ||||
| 				t."StageNumber"  	   , t."BeginDate"     , t."ActionDate"     | ||||
| 								, t."DocumentAction" , t."DocumentStatus"  , t."FromMessage"      , t."eDate", t."Department" | ||||
| 	   							, t."StageUser"           , t."StageItemStatus"  , t."StageStatus"      , t."StageItemAction", t."DocumentSubtype", | ||||
|               t."DocTypeName"  as "AnyColumnA" ,   | ||||
|                p."Family" || ' '|| p."Name" || ' '|| p."Father" as "AnyColumnB" ,   | ||||
|               t."DocCode" as "AnyColumnC", t."AnyColumnD" 	, t."AnyColumnE"  | ||||
| from "tmp_preresult" t | ||||
| 	inner join comdoc."Route" r on t."RouteVCode" = r."VCode" | ||||
| 	inner join comdoc."RouteStage" rs on r."VCode" = rs."PCode" and t."StageNumber"= rs."StageNumber" | ||||
| left join rp."RP_PersonContact" pc on pc."Code" = t."StageUser"  and  pc."IdTypeContact" = 6 | ||||
| 	left join rp."RP_Person" p on pc."Pcode" = p."VCode" | ||||
| where coalesce(t."RouteStatusId",0) in (2) and t."StageItemStatus"= 2 and t."IsMarked" is not true | ||||
|      and rs."StageName" ilike '%работник%' | ||||
|     and coalesce(t."ActionDate",t."DocumentDate") BETWEEN  _bdate AND _edate  | ||||
|   ; | ||||
| ``` | ||||
|  | ||||
| **Договоры и доп. соглашения** | ||||
|  | ||||
| Основной запрос: | ||||
| ```sql | ||||
| do $newQ$ | ||||
| declare _str text; | ||||
| begin | ||||
| _str := ' | ||||
| INSERT INTO "tmp_calcWithBaseParams_for_documentStatusJournalProc"( | ||||
|         "DocCode", "DocType", "DocForm", "DocTypeName", "SettingsId", "orgId", "DocumentDate", "DocumentNumber",  | ||||
|     "VirtualCUser", "Department", "IdWorker" | ||||
|   )a | ||||
|   SELECT e."VCode" AS "DocCode", s."DocType", s."DocForm", s."DocName" AS "DocTypeName", s."VCode" AS "SettingsId", e."COrg" AS "orgId", e."DateContract", e."VhodNumber" | ||||
|       , e."CUser", e."CuratorDepartmentSpr", e."Manager" | ||||
|   FROM contract."Contract" AS e | ||||
|     JOIN comdoc."DocflowDocumentSettings" AS s ON s."DocType" = e."TypeName" | ||||
|   WHERE 1 = 1 | ||||
|   '||case when coalesce("orgParam",-1111)=-1111 then '' else ' and e."COrg" = '||_orgid::text end ||' | ||||
|    and EXISTS( SELECT 1 FROM "tmp_docTypes_for_documentStatusJournalProc" AS t WHERE t."DocType" = e."TypeName" )  | ||||
|   '|| case when _contractor is null then '' else ' and e."Contractor" = '||_contractor::text end  | ||||
|    || case when _contract is null then '' else ' and e."VCode" = '||_contract::text end | ||||
|    || case when _manager is null then '' else ' and e."Manager" = '||_manager::text end | ||||
|    || ' and e."DateContract" between '_bdate' and '_edate' | ||||
|    union all | ||||
|   SELECT e."VCode" AS "DocCode", s."DocType", s."DocForm", s."DocName" AS "DocTypeName", s."VCode" AS "SettingsId", e."COrg" AS "orgId", e."DateContract", e."Number" | ||||
|       , e."CUser", e."CuratorDepartmentSpr", e."Manager" | ||||
|   FROM contract."AdditionalContract" AS e | ||||
|     JOIN comdoc."DocflowDocumentSettings" AS s ON s."DocType" = e."TypeName" | ||||
|   WHERE 1= 1 | ||||
|    '||case when coalesce("orgParam",-1111)=-1111 then '' else ' and e."COrg" = '||_orgid::text end ||' | ||||
|     and EXISTS( SELECT 1 FROM "tmp_docTypes_for_documentStatusJournalProc" AS t WHERE t."DocType" = e."TypeName" )  | ||||
|   '|| case when _contractor is null then '' else ' and e."Contractor" = '||_contractor::text end  | ||||
|    || case when _contract is null then '' else ' and e."Contract" = '||_contract::text end  | ||||
|    || case when _addcontract is null then '' else ' and e."VCode" = '||_addcontract::text end  | ||||
|    || case when _manager is null then '' else ' and e."Manager" = '||_manager::text end  | ||||
|    || ' and e."DateContract" between '_bdate' and '_edate';'; | ||||
|  | ||||
|  execute (_str); | ||||
| end; | ||||
| $newQ$; | ||||
| ```  | ||||
|  | ||||
| Итоговая выборка: | ||||
| ```sql | ||||
|  | ||||
| do | ||||
| $$ | ||||
| begin | ||||
|    | ||||
|   --CREATE INDEX IF NOT EXISTS "idx_tr1_tmp_CategoryAttributeType" ON "tmp_CategoryAttributeType"("PCode" ); | ||||
|   | ||||
|  if not comdoc."isTableExists"('tmp_UserRole','temp') then | ||||
| 			 create temp table "tmp_UserRole" (  | ||||
| 			 "login" character varying(255), "Role" character varying(255) | ||||
| 			 )  | ||||
|  --on commit drop  | ||||
| ; | ||||
| end if; | ||||
|  | ||||
| insert into "tmp_UserRole" ("login", "Role") | ||||
| select  distinct au."UserName" as login,"Role" | ||||
| FROM lex."UserMeta" au | ||||
|      JOIN lex."OrganizationUser" ou ON au."Id" = ou."User" | ||||
|  	 left join lex."OrganizationUserRole" ur on ou."Id" = ur."OrganizationUser" | ||||
| where "Role" in ('bh_purchasing_department', 'bh_legal_department', 'bh_contract_administrator', 'bh_financial_services') | ||||
| or "Role" like '%ddc%' | ||||
| ; | ||||
|  | ||||
|  if not comdoc."isTableExists"('tmp_CuserChief','temp') then | ||||
| 			 create temp table "tmp_CuserChief" (  | ||||
| 			 "VirtualCUser" character varying(255), "chief" character varying(255) | ||||
| 			 )  | ||||
|  --on commit drop  | ||||
| ; | ||||
| end if; | ||||
|  | ||||
| insert into "tmp_CuserChief" ("VirtualCUser","chief") | ||||
|   select "VirtualCUser", chief."chief" | ||||
|   from (select distinct t."DocCode",t."DocType" , t."orgId", t."VirtualCUser"  from  "tmp_preresult" t where t."DocType" in ('Base.Contract','Base.AdditionalContract')) t | ||||
|   	left join lateral  comdoc."getProjectTemplateMember"(t."DocCode",t."DocType" , t."orgId", t."VirtualCUser", 'Service.Chief') chief on true | ||||
|  ; | ||||
|    | ||||
|  if not comdoc."isTableExists"('tmp_ExpiredRole','temp') then | ||||
| 			 create temp table "tmp_ExpiredRole" (  | ||||
| 			 "DocCode" bigint, "Role" character varying(255), "maxexpired" int | ||||
| 			 )  | ||||
|  --on commit drop  | ||||
| ; | ||||
| end if; | ||||
|  | ||||
|  insert into "tmp_ExpiredRole" ("DocCode","Role", "maxexpired") | ||||
| select a."DocCode",   a."Role",  max(a."expired")  as "maxexpired" | ||||
|  from | ||||
|  ( | ||||
|  select  t."DocCode", t."StageUser",  -- ur."Role", 	coalesce(ch.ф"chief",'') as "chief", | ||||
| 	 case when coalesce(ch."chief",'') <>'' then 'chief_role' else ur."Role" end as "Role", | ||||
| round(comdoc."dfwcGetDuration"(t."eDate", COALESCE(t."ActionDate", _now::date), false, t."orgId", null, _dayoff1, _dayoff2, null)/60.0/60.0/9, 0)    as  "expired" | ||||
|  | ||||
|  from (select distinct "DocCode", t."StageUser", t."eDate", t."ActionDate",t."orgId"  from  "tmp_preresult" t where t."DocType"  in ('Base.Contract','Base.AdditionalContract')) t | ||||
|  	left join "tmp_UserRole" ur on t."StageUser"= ur."login" | ||||
| 	left join "tmp_CuserChief" ch on t."StageUser" = ch."chief" | ||||
|   | ||||
|  ) a  | ||||
|  where coalesce(a."expired", 0) > 0   | ||||
|  group by a."DocCode",  a."Role"; | ||||
|   | ||||
|  | ||||
|  end; | ||||
|  $$; | ||||
|  | ||||
|  | ||||
| insert into "tmp_finresult"( "DocCode"   , "DocType"   , "DocForm"  , "DocTypeName"    , "SettingsId"      | ||||
|   							   , "orgId" , "DocumentDate" , "DocumentNumber"  , "VirtualCUser"  , "DateOfExecution"  | ||||
| 							   , "DateControl"     , "RouteVCode"  , "RouteStatusId"   , "RouteStatusName"  , "DocName"      | ||||
| 							    , "DocSubject"  	  , "expired" , "StageNumber"  	   , "BeginDate"     , "ActionDate"     | ||||
| 								, "DocumentAction" , "DocumentStatus"  , "FromMessage"      , "eDate", "Department" | ||||
| 	   							, "StageUser"           , "StageItemStatus"  , "StageStatus"      , "StageItemAction" , "DocumentSubtype" | ||||
| , "AnyColumnA" , "AnyColumnB" , "AnyColumnC" 	, "AnyColumnD" 	, "AnyColumnE"  | ||||
| , "AnyColumnF" , "AnyColumnG" , "AnyColumnH" 	, "AnyColumnI" 	, "AnyColumnJ"  | ||||
| , "AnyColumnK" , "AnyColumnL" , "AnyColumnM" 	, "AnyColumnN" 	, "AnyColumnO"  | ||||
| ,  "AnyColumnP", "AnyColumnQ" , "AnyColumnR" , "AnyColumnS" 	, "AnyColumnT" 	 | ||||
| , "AnyColumnU" , "AnyColumnV" , "AnyColumnW" , "AnyColumnX" , "AnyColumnY"  | ||||
| , "AnyColumnZ" , "AnyColumnAA" , "AnyColumnAB" , "AnyColumnAC" , "AnyColumnAD" , "AnyColumnAE" , "AnyColumnAF"  | ||||
|  , "AnyColumnAG"  , "AnyColumnAH"  , "AnyColumnAI"  , "AnyColumnAJ" , "AnyColumnAK" , "AnyColumnAL"  , "AnyColumnAM"  | ||||
| , "Colors", "attFilter" | ||||
| ) | ||||
|  	  | ||||
| select distinct t."DocCode"   , t."DocType"   , t."DocForm"  , t."DocTypeName"    , t."SettingsId"      | ||||
|   	, t."orgId" , t."DocumentDate" , t."DocumentNumber"  , t."VirtualCUser"  , t."DateOfExecution"  | ||||
| 	, t."DateControl", t."RouteVCode"  , t."RouteStatusId"   , t."RouteStatusName"  , t."DocName"      | ||||
| 	, t."DocSubject",   	null::bigint ,  	null::int as  "StageNumber"  	   , null::date as  "BeginDate"     , null::date as "ActionDate"     | ||||
| 	, null::int as  "DocumentAction" ,null::int as  "DocumentStatus"  , null as"FromMessage"      , null::date as "eDate", t."Department" | ||||
| 	, null as "StageUser", null::int  as "StageItemStatus"  , null::int  as "StageStatus", null::int  as "StageItemAction", t."DocumentSubtype", | ||||
| "Number" as "AnyColumnA",  | ||||
| "VhodNumber" as "AnyColumnB", | ||||
| to_char("DateContract", 'DD.MM.YYYY' ) as "AnyColumnC", | ||||
| to_char("DateBegin", 'DD.MM.YYYY' ) as "AnyColumnD", | ||||
| to_char("DateEnd", 'DD.MM.YYYY' ) as  "AnyColumnE", | ||||
| null as  "AnyColumnF", | ||||
| case when coalesce("IsDocument",false) = true then 'Да' else 'Нет' end as  "AnyColumnG", | ||||
| "StatusOfContract" as  "AnyColumnH",  | ||||
| "Contractor" as  "AnyColumnI",  | ||||
| "VTypeContract" as  "AnyColumnJ", | ||||
| "ContractKind1" as  "AnyColumnK", | ||||
| null as  "AnyColumnL", | ||||
| "SumContract" as  "AnyColumnM", | ||||
| "TypePayment" as  "AnyColumnN", | ||||
| "SubjectOfContract" as  "AnyColumnO", | ||||
| null as  "AnyColumnP",  | ||||
| to_char("DateAutolong", 'DD.MM.YYYY' ) as  "AnyColumnQ", | ||||
| null as  "AnyColumnR",  | ||||
| null as  "AnyColumnS", | ||||
| null as  "AnyColumnT", | ||||
| COALESCE(rst."RouteStatusNm", 'Не запущен')  as  "AnyColumnU" | ||||
| , ( SELECT string_agg(r_info."x", ';') FROM | ||||
| 		( SELECT 'Этап '||s."StageNumber"||' '||du."Initials"||COALESCE(' '||ds."Name", '')||COALESCE(' '||i."FromMessage", '') AS "x" | ||||
|          FROM comdoc."Route" AS r | ||||
|            JOIN comdoc."RouteStage" AS s ON s."PCode" = r."VCode" | ||||
|            JOIN comdoc."StageItem" AS i ON i."PCode" = s."VCode" | ||||
|            JOIN comdoc."VUserMeta" AS du ON du."VCode" = i."StageUser" | ||||
|            LEFT JOIN comdoc."DocumentStatus" AS ds ON ds."VCode" = i."DocumentStatus" | ||||
|          WHERE r."DocCode" = t."DocCode" | ||||
|            AND r."DocType" = t."DocType" | ||||
|            AND r."RouteStatus" <> 4 | ||||
|          ORDER BY s."StageNumber" ASC, i."VCode" ASC | ||||
|        ) as r_info )  as "AnyColumnV", | ||||
| null as "AnyColumnW", --бренд | ||||
| null as "AnyColumnX", --парал импорт | ||||
| null as "AnyColumnY", -- с НДС | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role"='chief_role')   as "AnyColumnZ",--просрочено рук | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role"='bh_financial_services')  as "AnyColumnAA",--просрочено фин | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role"='bh_legal_department')  as "AnyColumnAB",--просрочено прав деп | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role"='bh_purchasing_department')  as "AnyColumnAC",--просрочено закупки | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role" like '%ddc%')  as "AnyColumnAD", --просрочено ДДЦ | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role"='bh_contract_administrator') as "AnyColumnAE", --просрочен админ дог | ||||
| t."DocCode" as "AnyColumnAF"  | ||||
|  | ||||
| --надо найти зама | ||||
| , (SELECT DISTINCT string_agg(x."UserName", ',') FROM  | ||||
| 			(select  | ||||
| 			m."LastName" || ' ' || m."FirstName" || ' ' || m. "MiddleName"	as "UserName"   | ||||
| --m."UserName", m1."UserName" as "UserName1" | ||||
| 			from lex."UserMeta" as m | ||||
| 			join lex."OrganizationUser" as ou on m."Id" = ou."User" and coalesce(ou."IsBlocked",false) = false  | ||||
| 			join lex."Replacement" as rep on ou."Id" = rep."Replacer"  | ||||
| 					--AND now() between coalesce(rep."BeginDate",now()) AND coalesce(rep."EndDate",now()) | ||||
| 			and  coalesce(rep."BeginDate",now())::date<= "DateEnd"::date and coalesce(rep."EndDate",now())::date>= "DateBegin"::date  | ||||
| 			join lex."OrganizationUser" as ou1 on rep."Replaceable" = ou1."Id" --and coalesce(ou1."IsBlocked",false) = false | ||||
| 			join lex."UserMeta" as m1 on ou1."User" = m1."Id" | ||||
| 			where m1."UserName" = t."VirtualCUser" | ||||
| 			group by m."LastName" || ' ' || m."FirstName" || ' ' || m. "MiddleName"	  | ||||
| -- m."UserName", m1."UserName" | ||||
| 			) as x )  ::character varying(1000) AS  "AnyColumnAG" | ||||
| --надо найти руководителя по штатке  | ||||
| 	, | ||||
| 	 | ||||
|  (select  um."LastName" || ' ' ||um."FirstName" || ' ' ||um."MiddleName"	as "UserName"  | ||||
|   from comdoc."Department" dep  | ||||
|      join rp."RP_Worker" w on dep."Manager" = w."VCode" | ||||
| 	 join rp."RP_PersonContact" pers on w."IdPerson" = pers."Pcode" and pers."IdTypeContact" = 6 | ||||
| join lex."UserMeta" um on um."UserName" = pers."Code" | ||||
| where dep."VCode" = (select "Department" from comdoc."DocflowExists" where "VCode" = t."DocCode"  and "TypeName" = t."DocType"  limit 1) ) | ||||
| AS  "AnyColumnAH" | ||||
| , wi."Dpost" AS  "AnyColumnAI", wi."Duvl" AS  "AnyColumnAJ" | ||||
|  ,  c."PaymentMethod" as "AnyColumnAK"  ,  null as "AnyColumnAL"  ,  | ||||
| case when coalesce(c."DateAutolong",c."DateEnd",'20701231')::date between now()::date and now()::date + 30::integer | ||||
| then 'yellow' | ||||
| when coalesce(c."DateAutolong",c."DateEnd",'20701231')<now()::date   | ||||
| then 'violet' | ||||
| end as  "AnyColumnAM"  | ||||
| ,    case when coalesce(c."DateAutolong",c."DateEnd",'20701231')::date between now()::date and now()::date + 30::integer | ||||
| then 3  | ||||
| when coalesce(c."DateAutolong",c."DateEnd",'20701231')<now()::date   | ||||
| then 7  | ||||
| end | ||||
|  as "Colors" | ||||
| , ' and "OrigPriznak" is true ' as "attFilter" | ||||
|  | ||||
| /*цвета 1 -  colors.gray  | ||||
| 2 - colors.orange | ||||
| 3 - colors.yellow | ||||
| 4 - colors.green | ||||
| 5 - colors.blue | ||||
| 6 - colors.indigo | ||||
| 7 -colors.violet*/ | ||||
|  | ||||
|   from  (select distinct t."DocCode"   , t."DocType"   , t."DocForm"  , t."DocTypeName"    , t."SettingsId"      | ||||
|   	, t."orgId" , t."DocumentDate" , t."DocumentNumber"  , t."VirtualCUser"  , t."DateOfExecution"  | ||||
| 	, t."DateControl", t."RouteVCode"  , t."RouteStatusId"   , t."RouteStatusName"  , t."DocName"      | ||||
| 	, t."DocSubject", t."Department",  t."DocumentSubtype", t."DocumentCategory" | ||||
| from "tmp_preresult" t  | ||||
| where t."DocType" in ('Base.Contract') | ||||
|   )  t | ||||
| inner join  contract."VContractRegistry" c on t."DocCode" = c."VCode" | ||||
|    LEFT JOIN ( SELECT w."VCode", w."lexLogin", dep."VCode" AS "DepartmentVCode", dep."Name" AS "Department", pos."Name" AS "Position" ,to_char(w."DateBeg",'DD.MM.YYYY') as "Dpost",to_char(w."DateEnd",'DD.MM.YYYY') as "Duvl" | ||||
|   FROM rp."VLookupWorker" AS w | ||||
|     JOIN rp."RP_WorkerMove" AS m ON m."IdWorker" = w."VCode" | ||||
|     LEFT JOIN comdoc."Department" AS dep ON dep."VCode" = m."IdDepartment" | ||||
|     LEFT JOIN rp."RP_Post" AS pos ON pos."VCode" = m."IdPost" | ||||
|   WHERE w."lexLogin" IS NOT NULL | ||||
|   ORDER BY ROW_NUMBER() OVER( | ||||
|     PARTITION BY w."lexLogin" | ||||
|     ORDER BY   COALESCE(m."DateEnd", w."DateEnd", '2070-01-01'::date) DESC, m."VCode" DESC | ||||
|   ) | ||||
|   FETCH FIRST 1 ROWS WITH TIES ) --as  "workers"  | ||||
|   AS wi ON wi."lexLogin" = t."VirtualCUser"  | ||||
|  LEFT JOIN LATERAL comdoc."getDocRouteCurrentStatus"(t."DocCode", t."DocType") AS rst ON true | ||||
|  --where c."DateContract"  BETWEEN _bdate AND _edate | ||||
| /*union all  | ||||
| select distinct t."DocCode"   , t."DocType"   , t."DocForm"  , t."DocTypeName"    , t."SettingsId"      | ||||
|   	, t."orgId" , t."DocumentDate" , t."DocumentNumber"  , t."VirtualCUser"  , t."DateOfExecution"  | ||||
| 	, t."DateControl", t."RouteVCode"  , t."RouteStatusId"   , t."RouteStatusName"  , t."DocName"      | ||||
| 	, t."DocSubject",   	null::bigint ,  	null::int as  "StageNumber"  	   , null::date as  "BeginDate"     , null::date as "ActionDate"     | ||||
| 	, null::int as  "DocumentAction" ,null::int as  "DocumentStatus"  , null as"FromMessage"      , null::date as "eDate", t."Department" | ||||
| 	, null as "StageUser", null::int  as "StageItemStatus"  , null::int  as "StageStatus", null::int  as "StageItemAction", t."DocumentSubtype", | ||||
| ds."Number" as "AnyColumnA",  | ||||
| c."VhodNumber"as "AnyColumnB", | ||||
| to_char(c."DateContract", 'DD.MM.YYYY' ) as "AnyColumnC", | ||||
| to_char(ds."DateBegin", 'DD.MM.YYYY' ) as "AnyColumnD", | ||||
| to_char(ds."DateEnd", 'DD.MM.YYYY' ) as  "AnyColumnE", | ||||
| to_char(ds."DateSignUp", 'DD.MM.YYYY' ) as  "AnyColumnF", | ||||
| case when coalesce(ds."IsDocument",false) = true then 'Да' else 'Нет' end as  "AnyColumnG", | ||||
| ds."StatusOfContractName" as  "AnyColumnH",  | ||||
| ds."ContractorName" as  "AnyColumnI",  | ||||
| c."VTypeContract" as  "AnyColumnJ", | ||||
| c."ContractKind1" as  "AnyColumnK", | ||||
| c."ContractCategory" as  "AnyColumnL", | ||||
| ds."SumWithVAT" as  "AnyColumnM", | ||||
| c."TypePayment" as  "AnyColumnN", | ||||
| ds."SubjectOfContract" as  "AnyColumnO", | ||||
| c."Autolong" as  "AnyColumnP",  | ||||
| to_char(c."DateAutolong", 'DD.MM.YYYY' ) as  "AnyColumnQ", | ||||
| c."TypicalForm" as  "AnyColumnR",  | ||||
| c."ContractBasis" as  "AnyColumnS", | ||||
| c."CompanyListName" as  "AnyColumnT", | ||||
| COALESCE(rst."RouteStatusNm", 'Не запущен')  as  "AnyColumnU" | ||||
| , ( SELECT string_agg(r_info."x", ';') FROM | ||||
| 		( SELECT 'Этап '||s."StageNumber"||' '||du."Initials"||COALESCE(' '||ds."Name", '')||COALESCE(' '||i."FromMessage", '') AS "x" | ||||
|          FROM comdoc."Route" AS r | ||||
|            JOIN comdoc."RouteStage" AS s ON s."PCode" = r."VCode" | ||||
|            JOIN comdoc."StageItem" AS i ON i."PCode" = s."VCode" | ||||
|            JOIN comdoc."VUserMeta" AS du ON du."VCode" = i."StageUser" | ||||
|            LEFT JOIN comdoc."DocumentStatus" AS ds ON ds."VCode" = i."DocumentStatus" | ||||
|          WHERE r."DocCode" = t."DocCode" | ||||
|            AND r."DocType" = t."DocType" | ||||
|            AND r."RouteStatus" <> 4 | ||||
|          ORDER BY s."StageNumber" ASC, i."VCode" ASC | ||||
|        ) as r_info )  as "AnyColumnV", | ||||
| c."BrendName" as "AnyColumnW", --бренд | ||||
| c."ParalelImportName" as "AnyColumnX", --парал импорт | ||||
| case when coalesce(c."WithNDS",false) = true then 'С НДС' else 'Без НДС' end as "AnyColumnY", -- с НДС | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role"='chief_role')   as "AnyColumnZ",--просрочено рук | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role"='chief_role')  as "AnyColumnAA",--просрочено фин | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role"='bh_legal_department')  as "AnyColumnAB",--просрочено прав деп | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role"='chief_role')  as "AnyColumnAC",--просрочено закупки | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role"='chief_role')  as "AnyColumnAD", --просрочено ДДЦ | ||||
| (select  "maxexpired" from "tmp_ExpiredRole"  er where t."DocCode" = er."DocCode" and "Role"='bh_contract_administrator') as "AnyColumnAE", --просрочен админ дог | ||||
| t."DocCode" as "AnyColumnAF"  | ||||
|  --надо найти зама | ||||
| , (SELECT DISTINCT string_agg(x."UserName", ',') FROM  | ||||
| 			(select  | ||||
| 			m."LastName" || ' ' || m."FirstName" || ' ' || m. "MiddleName"	as "UserName"   | ||||
| --m."UserName", m1."UserName" as "UserName1" | ||||
| 			from lex."UserMeta" as m | ||||
| 			join lex."OrganizationUser" as ou on m."Id" = ou."User" and coalesce(ou."IsBlocked",false) = false  | ||||
| 			join lex."Replacement" as rep on ou."Id" = rep."Replacer"  | ||||
| 					--AND now() between coalesce(rep."BeginDate",now()) AND coalesce(rep."EndDate",now()) | ||||
| 			and  coalesce(rep."BeginDate",now())::date<= c."DateEnd"::date and coalesce(rep."EndDate",now())::date>=  c."DateBegin"  | ||||
| 			join lex."OrganizationUser" as ou1 on rep."Replaceable" = ou1."Id" --and coalesce(ou1."IsBlocked",false) = false | ||||
| 			join lex."UserMeta" as m1 on ou1."User" = m1."Id" | ||||
| 			where m1."UserName" = t."VirtualCUser" | ||||
| 			group by m."LastName" || ' ' || m."FirstName" || ' ' || m. "MiddleName"	  | ||||
| -- m."UserName", m1."UserName" | ||||
| 			) as x )  ::character varying(1000) AS  "AnyColumnAG" | ||||
| --надо найти руководителя по штатке  | ||||
| 	, | ||||
| 	 | ||||
|  (select  um."LastName" || ' ' ||um."FirstName" || ' ' ||um."MiddleName"	as "UserName"  | ||||
|   from comdoc."Department" dep  | ||||
|      join rp."RP_Worker" w on dep."Manager" = w."VCode" | ||||
| 	 join rp."RP_PersonContact" pers on w."IdPerson" = pers."Pcode" and pers."IdTypeContact" = 6 | ||||
| join lex."UserMeta" um on um."UserName" = pers."Code" | ||||
| where dep."VCode" = (select "Department" from comdoc."DocflowExists" where "VCode" = t."DocCode"  and "TypeName" = t."DocType"  limit 1) ) | ||||
| AS  "AnyColumnAH" | ||||
| , wi."Dpost" AS  "AnyColumnAI", wi."Duvl" AS  "AnyColumnAJ" | ||||
|   ,  c."PaymentMethod" as "AnyColumnAK"  ,  c."SumAddContractWithoutVAT" as "AnyColumnAL"  ,  | ||||
| null as  "AnyColumnAM"  | ||||
| ,  null as "Colors" | ||||
| from  (select distinct t."DocCode"   , t."DocType"   , t."DocForm"  , t."DocTypeName"    , t."SettingsId"      | ||||
|   	, t."orgId" , t."DocumentDate" , t."DocumentNumber"  , t."VirtualCUser"  , t."DateOfExecution"  | ||||
| 	, t."DateControl", t."RouteVCode"  , t."RouteStatusId"   , t."RouteStatusName"  , t."DocName"      | ||||
| 	, t."DocSubject", t."Department",  t."DocumentSubtype", t."DocumentCategory" | ||||
| from "tmp_preresult" t  | ||||
| 		 where t."DocType" in ('Base.AdditionalContract') | ||||
|   )  t | ||||
| 	inner join contract."VAdditionalContractRegistry" ds on t."DocCode" =ds."VCode" | ||||
| 	inner join contract."VContractRegistry" c on ds."Contract" = c."VCode" | ||||
|    LEFT JOIN ( SELECT w."VCode", w."lexLogin", dep."VCode" AS "DepartmentVCode", dep."Name" AS "Department", pos."Name" AS "Position" ,to_char(w."DateBeg",'DD.MM.YYYY') as "Dpost",to_char(w."DateEnd",'DD.MM.YYYY') as "Duvl" | ||||
|   FROM rp."VLookupWorker" AS w | ||||
|     JOIN rp."RP_WorkerMove" AS m ON m."IdWorker" = w."VCode" | ||||
|     LEFT JOIN comdoc."Department" AS dep ON dep."VCode" = m."IdDepartment" | ||||
|     LEFT JOIN rp."RP_Post" AS pos ON pos."VCode" = m."IdPost" | ||||
|   WHERE w."lexLogin" IS NOT NULL | ||||
|   ORDER BY ROW_NUMBER() OVER( | ||||
|     PARTITION BY w."lexLogin" | ||||
|     ORDER BY   COALESCE(m."DateEnd", w."DateEnd", '2070-01-01'::date) DESC, m."VCode" DESC | ||||
|   ) | ||||
|   FETCH FIRST 1 ROWS WITH TIES ) --as  "workers"  | ||||
|   AS wi ON wi."lexLogin" = t."VirtualCUser"  | ||||
|  	LEFT JOIN LATERAL comdoc."getDocRouteCurrentStatus"(t."DocCode", t."DocType") AS rst ON true | ||||
| -- where c."DateContract"  BETWEEN _bdate AND _edate | ||||
|  | ||||
| */ | ||||
| ``` | ||||
		Reference in New Issue
	
	Block a user