Inheritance: ДокументСсылка, IСериализаторProtoBuf, IСериализаторJson
        public static V82.ДокументыСсылка.ЗаданиеНаПроизводство ВзятьИзКэша(byte[] УникальныйИдентификатор)
        {
            var УИ = new Guid(УникальныйИдентификатор);

            if (Кэш.ContainsKey(УИ))
            {
                return((V82.ДокументыСсылка.ЗаданиеНаПроизводство)Кэш[УИ]);
            }
            var Ссылка = new V82.ДокументыСсылка.ЗаданиеНаПроизводство(УникальныйИдентификатор);

            Кэш.Add(УИ, Ссылка);
            return(Ссылка);
        }
 public static ДокументыВыборка.ЗаданиеНаПроизводство Выбрать()
 {
     using (var Подключение = new SqlConnection(СтрокаСоединения))
     {
         Подключение.Open();
         using (var Команда = Подключение.CreateCommand())
         {
             Команда.CommandText = @"Select top 1000
             _IDRRef [Ссылка]
             ,_Version [Версия]
             ,_Marked [ПометкаУдаления]
             ,_Fld4225RRef [ВидЗадания]
             ,_Fld4226 [ДатаЗадания]
             ,_Fld4227 [Комментарий]
             ,_Fld4228RRef [Ответственный]
             ,_Fld4229RRef [Подразделение]
             ,_Fld4230RRef [Смена]
             From _Document254(NOLOCK)";
             var Выборка = new V82.ДокументыВыборка.ЗаданиеНаПроизводство();
             using (var Читалка = Команда.ExecuteReader())
             {
                 while (Читалка.Read())
                 {
                     var Ссылка = new ДокументыСсылка.ЗаданиеНаПроизводство();
                     //ToDo: Читать нужно через GetValues()
                     Ссылка.Ссылка = new Guid((byte[])Читалка.GetValue(0));
                     var ПотокВерсии = ((byte[])Читалка.GetValue(1));
                     Array.Reverse(ПотокВерсии);
                     Ссылка.Версия =  BitConverter.ToInt64(ПотокВерсии, 0);
                     Ссылка.ВерсияДанных =  Convert.ToBase64String(ПотокВерсии);
                     Ссылка.ПометкаУдаления = ((byte[])Читалка.GetValue(2))[0]==1;
                     Ссылка.ВидЗадания = V82.Перечисления/*Ссылка*/.ВидыЗаданийНаПроизводство.ПустаяСсылка.Получить((byte[])Читалка.GetValue(3));
                     Ссылка.ДатаЗадания = Читалка.GetDateTime(4);
                     Ссылка.Комментарий = Читалка.GetString(5);
                     Выборка.Add(Ссылка);
                 }
                     return Выборка;
             }
         }
     }
 }
        public ОтчетПроизводстваЗаСмену(byte[] УникальныйИдентификатор)
        {
            using (var Подключение = new SqlConnection(СтрокаСоединения))
            {
                Подключение.Open();
                using (var Команда = Подключение.CreateCommand())
                {
                    Команда.CommandText = @"Select top 1 
					_IDRRef [Ссылка]
					,_Version [Версия]
					,_Marked [ПометкаУдаления]
					,_Number [Номер]
					,_Fld7463 [АвтораспределениеВозвратныхОтходов]
					,_Fld7464 [АвтораспределениеМатериалов]
					,_Fld7465 [АвтораспределениеПрочихЗатрат]
					,_Fld7466 [АвтораспределениеТехнологическихОпераций]
					,_Fld7467 [ВводитьСтатьиЗатратПоСтрокам]
					,_Fld7468RRef [ЗаданиеНаПроизводство]
					,_Fld7469 [Комментарий]
					,_Fld7470RRef [Организация]
					,_Fld7477RRef [Склад]
					,_Fld7472 [ОтражатьВБухгалтерскомУчете]
					,_Fld7476RRef [ПодразделениеОрганизации]
					,_Fld7474 [ОтражатьВУправленческомУчете]
					,_Fld7475RRef [Подразделение]
					,_Fld7473 [ОтражатьВНалоговомУчете]
					,_Fld7471RRef [Ответственный]
					,_Fld7478RRef [СтатьяЗатрат]
					,_Fld7479 [ИспользоватьВозвратныеОтходы]
					,_Fld7480 [ИспользоватьЗаданияНаПроизводство]
					,_Fld7481 [ИспользоватьЗаказы]
					,_Fld7482 [ИспользоватьЗаказыНаОбслуживаниеОС]
					,_Fld7483 [ИспользоватьМатериалы]
					,_Fld7484 [ИспользоватьНаправленияВыпуска]
					,_Fld7485 [ИспользоватьНаработку]
					,_Fld18997 [ИспользоватьПодразделенияНЗП]
					,_Fld7486 [ИспользоватьПрочиеЗатраты]
					,_Fld7487 [ИспользоватьТехнологическиеОперации]
					,_Fld7488 [РазрешитьПревышениеЛимита]
					,_Fld7489RRef [СкладОтходов]
					,_Fld18998 [ИспользоватьАналитикуНЗП]
					,_Fld21806 [УчитыватьТариф]
					,_Fld21807 [УчитыватьКТУ]
					From _Document357(NOLOCK)
					Where _IDRRef=@УникальныйИдентификатор"                    ;
                    Команда.Parameters.AddWithValue("УникальныйИдентификатор", УникальныйИдентификатор);
                    using (var Читалка = Команда.ExecuteReader())
                    {
                        if (Читалка.Read())
                        {
                            //ToDo: Читать нужно через GetValues()
                            Ссылка = new Guid((byte[])Читалка.GetValue(0));
                            var ПотокВерсии = ((byte[])Читалка.GetValue(1));
                            Array.Reverse(ПотокВерсии);
                            Версия          = BitConverter.ToInt64(ПотокВерсии, 0);
                            ВерсияДанных    = Convert.ToBase64String(ПотокВерсии);
                            ПометкаУдаления = ((byte[])Читалка.GetValue(2))[0] == 1;
                            Номер           = Читалка.GetString(3);
                            АвтораспределениеВозвратныхОтходов       = ((byte[])Читалка.GetValue(4))[0] == 1;
                            АвтораспределениеМатериалов              = ((byte[])Читалка.GetValue(5))[0] == 1;
                            АвтораспределениеПрочихЗатрат            = ((byte[])Читалка.GetValue(6))[0] == 1;
                            АвтораспределениеТехнологическихОпераций = ((byte[])Читалка.GetValue(7))[0] == 1;
                            ВводитьСтатьиЗатратПоСтрокам             = ((byte[])Читалка.GetValue(8))[0] == 1;
                            ЗаданиеНаПроизводство               = new V82.ДокументыСсылка.ЗаданиеНаПроизводство((byte[])Читалка.GetValue(9));
                            Комментарий                         = Читалка.GetString(10);
                            ОтражатьВБухгалтерскомУчете         = ((byte[])Читалка.GetValue(13))[0] == 1;
                            ОтражатьВУправленческомУчете        = ((byte[])Читалка.GetValue(15))[0] == 1;
                            ОтражатьВНалоговомУчете             = ((byte[])Читалка.GetValue(17))[0] == 1;
                            ИспользоватьВозвратныеОтходы        = ((byte[])Читалка.GetValue(20))[0] == 1;
                            ИспользоватьЗаданияНаПроизводство   = ((byte[])Читалка.GetValue(21))[0] == 1;
                            ИспользоватьЗаказы                  = ((byte[])Читалка.GetValue(22))[0] == 1;
                            ИспользоватьЗаказыНаОбслуживаниеОС  = ((byte[])Читалка.GetValue(23))[0] == 1;
                            ИспользоватьМатериалы               = ((byte[])Читалка.GetValue(24))[0] == 1;
                            ИспользоватьНаправленияВыпуска      = ((byte[])Читалка.GetValue(25))[0] == 1;
                            ИспользоватьНаработку               = ((byte[])Читалка.GetValue(26))[0] == 1;
                            ИспользоватьПодразделенияНЗП        = ((byte[])Читалка.GetValue(27))[0] == 1;
                            ИспользоватьПрочиеЗатраты           = ((byte[])Читалка.GetValue(28))[0] == 1;
                            ИспользоватьТехнологическиеОперации = ((byte[])Читалка.GetValue(29))[0] == 1;
                            азрешитьПревышениеЛимита            = ((byte[])Читалка.GetValue(30))[0] == 1;
                            ИспользоватьАналитикуНЗП            = ((byte[])Читалка.GetValue(32))[0] == 1;
                            УчитыватьТариф                      = ((byte[])Читалка.GetValue(33))[0] == 1;
                            УчитыватьКТУ                        = ((byte[])Читалка.GetValue(34))[0] == 1;
                            //return Ссылка;
                        }
                        else
                        {
                            //return null;
                        }
                    }
                }
            }
        }
 public static V82.ДокументыСсылка.ЗаданиеНаПроизводство ВзятьИзКэша(byte[] УникальныйИдентификатор)
 {
     var УИ = new Guid(УникальныйИдентификатор);
     if (Кэш.ContainsKey(УИ))
     {
         return (V82.ДокументыСсылка.ЗаданиеНаПроизводство)Кэш[УИ];
     }
     var Ссылка = new V82.ДокументыСсылка.ЗаданиеНаПроизводство(УникальныйИдентификатор);
     Кэш.Add(УИ, Ссылка);
     return Ссылка;
 }
 public ОтчетПроизводстваЗаСмену(byte[] УникальныйИдентификатор)
 {
     using (var Подключение = new SqlConnection(СтрокаСоединения))
     {
         Подключение.Open();
         using (var Команда = Подключение.CreateCommand())
         {
             Команда.CommandText = @"Select top 1
             _IDRRef [Ссылка]
             ,_Version [Версия]
             ,_Marked [ПометкаУдаления]
             ,_Number [Номер]
             ,_Fld7463 [АвтораспределениеВозвратныхОтходов]
             ,_Fld7464 [АвтораспределениеМатериалов]
             ,_Fld7465 [АвтораспределениеПрочихЗатрат]
             ,_Fld7466 [АвтораспределениеТехнологическихОпераций]
             ,_Fld7467 [ВводитьСтатьиЗатратПоСтрокам]
             ,_Fld7468RRef [ЗаданиеНаПроизводство]
             ,_Fld7469 [Комментарий]
             ,_Fld7470RRef [Организация]
             ,_Fld7477RRef [Склад]
             ,_Fld7472 [ОтражатьВБухгалтерскомУчете]
             ,_Fld7476RRef [ПодразделениеОрганизации]
             ,_Fld7474 [ОтражатьВУправленческомУчете]
             ,_Fld7475RRef [Подразделение]
             ,_Fld7473 [ОтражатьВНалоговомУчете]
             ,_Fld7471RRef [Ответственный]
             ,_Fld7478RRef [СтатьяЗатрат]
             ,_Fld7479 [ИспользоватьВозвратныеОтходы]
             ,_Fld7480 [ИспользоватьЗаданияНаПроизводство]
             ,_Fld7481 [ИспользоватьЗаказы]
             ,_Fld7482 [ИспользоватьЗаказыНаОбслуживаниеОС]
             ,_Fld7483 [ИспользоватьМатериалы]
             ,_Fld7484 [ИспользоватьНаправленияВыпуска]
             ,_Fld7485 [ИспользоватьНаработку]
             ,_Fld18997 [ИспользоватьПодразделенияНЗП]
             ,_Fld7486 [ИспользоватьПрочиеЗатраты]
             ,_Fld7487 [ИспользоватьТехнологическиеОперации]
             ,_Fld7488 [РазрешитьПревышениеЛимита]
             ,_Fld7489RRef [СкладОтходов]
             ,_Fld18998 [ИспользоватьАналитикуНЗП]
             ,_Fld21806 [УчитыватьТариф]
             ,_Fld21807 [УчитыватьКТУ]
             From _Document357(NOLOCK)
             Where _IDRRef=@УникальныйИдентификатор";
             Команда.Parameters.AddWithValue("УникальныйИдентификатор", УникальныйИдентификатор);
             using (var Читалка = Команда.ExecuteReader())
             {
                 if (Читалка.Read())
                 {
                     //ToDo: Читать нужно через GetValues()
                     Ссылка = new Guid((byte[])Читалка.GetValue(0));
                     var ПотокВерсии = ((byte[])Читалка.GetValue(1));
                     Array.Reverse(ПотокВерсии);
                     Версия =  BitConverter.ToInt64(ПотокВерсии, 0);
                     ВерсияДанных =  Convert.ToBase64String(ПотокВерсии);
                     ПометкаУдаления = ((byte[])Читалка.GetValue(2))[0]==1;
                     Номер = Читалка.GetString(3);
                     АвтораспределениеВозвратныхОтходов = ((byte[])Читалка.GetValue(4))[0]==1;
                     АвтораспределениеМатериалов = ((byte[])Читалка.GetValue(5))[0]==1;
                     АвтораспределениеПрочихЗатрат = ((byte[])Читалка.GetValue(6))[0]==1;
                     АвтораспределениеТехнологическихОпераций = ((byte[])Читалка.GetValue(7))[0]==1;
                     ВводитьСтатьиЗатратПоСтрокам = ((byte[])Читалка.GetValue(8))[0]==1;
                     ЗаданиеНаПроизводство = new V82.ДокументыСсылка.ЗаданиеНаПроизводство((byte[])Читалка.GetValue(9));
                     Комментарий = Читалка.GetString(10);
                     ОтражатьВБухгалтерскомУчете = ((byte[])Читалка.GetValue(13))[0]==1;
                     ОтражатьВУправленческомУчете = ((byte[])Читалка.GetValue(15))[0]==1;
                     ОтражатьВНалоговомУчете = ((byte[])Читалка.GetValue(17))[0]==1;
                     ИспользоватьВозвратныеОтходы = ((byte[])Читалка.GetValue(20))[0]==1;
                     ИспользоватьЗаданияНаПроизводство = ((byte[])Читалка.GetValue(21))[0]==1;
                     ИспользоватьЗаказы = ((byte[])Читалка.GetValue(22))[0]==1;
                     ИспользоватьЗаказыНаОбслуживаниеОС = ((byte[])Читалка.GetValue(23))[0]==1;
                     ИспользоватьМатериалы = ((byte[])Читалка.GetValue(24))[0]==1;
                     ИспользоватьНаправленияВыпуска = ((byte[])Читалка.GetValue(25))[0]==1;
                     ИспользоватьНаработку = ((byte[])Читалка.GetValue(26))[0]==1;
                     ИспользоватьПодразделенияНЗП = ((byte[])Читалка.GetValue(27))[0]==1;
                     ИспользоватьПрочиеЗатраты = ((byte[])Читалка.GetValue(28))[0]==1;
                     ИспользоватьТехнологическиеОперации = ((byte[])Читалка.GetValue(29))[0]==1;
                     РазрешитьПревышениеЛимита = ((byte[])Читалка.GetValue(30))[0]==1;
                     ИспользоватьАналитикуНЗП = ((byte[])Читалка.GetValue(32))[0]==1;
                     УчитыватьТариф = ((byte[])Читалка.GetValue(33))[0]==1;
                     УчитыватьКТУ = ((byte[])Читалка.GetValue(34))[0]==1;
                     //return Ссылка;
                 }
                 else
                 {
                     //return null;
                 }
             }
         }
     }
 }