- 1
- 2
- 3
- 4
- 5
- 6
ВЫБРАТЬ
ЕСТЬNULL(СрокПолезногоИспользования, 0) КАК СрокПолезногоИспользования
ИЗ
РегистрСведений.РасчетАмортизацииОС.СрезПоследних
ГДЕ
ОС = &ОсновноеСредство
Нашли или выдавили из себя код, который нельзя назвать нормальным, на который без улыбки не взглянешь? Не торопитесь его удалять или рефакторить, — запостите его на говнокод.ру, посмеёмся вместе!
−119
ВЫБРАТЬ
ЕСТЬNULL(СрокПолезногоИспользования, 0) КАК СрокПолезногоИспользования
ИЗ
РегистрСведений.РасчетАмортизацииОС.СрезПоследних
ГДЕ
ОС = &ОсновноеСредство
Типовая конфигурация. Там такой запрос используют в печатной форме Основных средств... Думает по 10-15 минут
2 глупых ошибки:
1. Проверка на NULL, в данном случае его быть не может (хотя это особо ни на что не влияет)
2. Условие по законам 1С должно применяться в РегистрСведений.РасчетАмортизацииОС.Срез Последних(,ОС = &ОсновноеСредство), иначе сильно падает скорость выполнения.
−120
Пока ТЗРаспределения.ТаблицаРеализацийИВозвратовНеСвернутая.ТаблицаНоменклатур.ТаблицаРеализацийНеСв.ТаблицаВозвратовНеСв.ПолучитьСтроку()=1 Цикл
СтрокаВозвратов = СтрокаВозвратов + ТЗРаспределения.ТаблицаРеализацийИВозвратовНеСвернутая.ТаблицаНоменклатур.ТаблицаРеализацийНеСв.ТаблицаВозвратовНеСв.Возврат + ";" ;
КонецЦикла;
Очередной шедевр... Живем в 6(!!!)-мерном мире. У меня чуть мозг не взорвался.
−122
Пока Выборка1...
...Выборка2...
...
Выборка7 = ПрименяемостьНаПрибор_ПоискВхождений(Выборка6.НомерЗаписиРСДСЕГл, НаДату).Выбрать();
Пока Выборка7.Следующий() Цикл
ПрименяемостьПоВхождению = ПрименяемостьПоВхождению * Выборка7.Применяемость;
Если Выборка7.НомерЗаписиРСДСЕГл = 0 Тогда
// Достигнут прибор
Применяемость = Применяемость + ПрименяемостьПоВхождению;
Иначе
Выборка8 = ПрименяемостьНаПрибор_ПоискВхождений(Выборка7.НомерЗаписиРСДСЕГл, НаДату).Выбрать();
Пока Выборка8.Следующий() Цикл
ПрименяемостьПоВхождению = ПрименяемостьПоВхождению * Выборка8.Применяемость;
Если Выборка8.НомерЗаписиРСДСЕГл = 0 Тогда
// Достигнут прибор
Применяемость = Применяемость + ПрименяемостьПоВхождению;
Иначе
Сообщить("Превышение значения выборки... Странная ситуация, вообще не должна возникать!!!");
Сообщить("Срочно обратитесь в Отдел ВТ. Постарайтесь записать ситуацию в которой возникла эта ошибка... !!!");
КонецЕсли;
КонецЦикла;
КонецЕсли;
КонецЦикла;
...
...
По мотивам предыдущих постов. Все из одной конфигурации.
−125
Если СтрНВрОбщ.Действия = Перечисления.Действия.Удалить Тогда
// Такого быть не должно...
Сообщить("Это сообщение не должно появиться... Обратитесь в отдел ИТ! ");
ИначеЕсли СтрНВрОбщ.Действия = Перечисления.Действия.Добавить Тогда
//Тру-ля-ля... другой говнокод
КонецЕсли;
При чем такого действительно "быть не должно", т.к. проверка есть и в другом модуле.
−121
Для каждого СтрГотИзд Из ГотовыеИзделия Цикл
СсылкаДСЕ = ОпределитьДСЕГотовоеИзделиеПоНаименованию(СтрГотИзд.Значение);
СсылкаЗаписьРС = НайтиПервуюЗаписьРС_ПоДСЕ(СсылкаДСЕ, ЭтотОбъект.НаДату);
Если СсылкаЗаписьРС = Неопределено Тогда
Предупреждение("На эту дату данных не существует!");
Иначе
ФормаИндикатора.КомментарийОбработкиДанных = "Построение отчета: " + СсылкаДСЕ.ВидПредмета + " - " + СсылкаДСЕ.Наименование + "";
ОбластьДанныеДобавить(ПолеТабДок, ОбластьДанные1, 1, СсылкаДСЕ, СсылкаЗаписьРС.Применяемость, Неопределено, ФормаИндикатора);
Выборка2Ур = НайтиЗаписиРС_ПоКодуДСЕГл(СсылкаЗаписьРС.НомерЗаписиРСДСЕВх, НаДату).Выбрать();
Пока Выборка2Ур.Следующий() цикл
ОбластьДанныеДобавить(ПолеТабДок, ОбластьДанные2, 2, Выборка2Ур.ДСЕВходящий, Выборка2Ур.Применяемость, Выборка2Ур, ФормаИндикатора);
Выборка3Ур = НайтиЗаписиРС_ПоКодуДСЕГл(Выборка2Ур.НомерЗаписиРСДСЕВх, НаДату).Выбрать();
Пока Выборка3Ур.Следующий() цикл
ОбластьДанныеДобавить(ПолеТабДок, ОбластьДанные3, 3, Выборка3Ур.ДСЕВходящий, Выборка3Ур.Применяемость, Выборка3Ур, ФормаИндикатора);
Выборка4Ур = НайтиЗаписиРС_ПоКодуДСЕГл(Выборка3Ур.НомерЗаписиРСДСЕВх, НаДату).Выбрать();
Пока Выборка4Ур.Следующий() цикл
ОбластьДанныеДобавить(ПолеТабДок, ОбластьДанные4, 4, Выборка4Ур.ДСЕВходящий, Выборка4Ур.Применяемость, Выборка4Ур, ФормаИндикатора);
Выборка5Ур = НайтиЗаписиРС_ПоКодуДСЕГл(Выборка4Ур.НомерЗаписиРСДСЕВх, НаДату).Выбрать();
Пока Выборка5Ур.Следующий() цикл
ОбластьДанныеДобавить(ПолеТабДок, ОбластьДанные5, 5, Выборка5Ур.ДСЕВходящий, Выборка5Ур.Применяемость, Выборка5Ур, ФормаИндикатора);
Выборка6Ур = НайтиЗаписиРС_ПоКодуДСЕГл(Выборка5Ур.НомерЗаписиРСДСЕВх, НаДату).Выбрать();
Пока Выборка6Ур.Следующий() цикл
ОбластьДанныеДобавить(ПолеТабДок, ОбластьДанные6, 6, Выборка6Ур.ДСЕВходящий, Выборка6Ур.Применяемость, Выборка6Ур, ФормаИндикатора);
Выборка7Ур = НайтиЗаписиРС_ПоКодуДСЕГл(Выборка6Ур.НомерЗаписиРСДСЕВх, НаДату).Выбрать();
Пока Выборка7Ур.Следующий() цикл
ОбластьДанныеДобавить(ПолеТабДок, ОбластьДанные7, 7, Выборка7Ур.ДСЕВходящий, Выборка7Ур.Применяемость, Выборка7Ур, ФормаИндикатора);
Выборка8Ур = НайтиЗаписиРС_ПоКодуДСЕГл(Выборка7Ур.НомерЗаписиРСДСЕВх, НаДату).Выбрать();
Пока Выборка8Ур.Следующий() цикл
ОбластьДанныеДобавить(ПолеТабДок, ОбластьДанные8, 8, Выборка8Ур.ДСЕВходящий, Выборка8Ур.Применяемость, Выборка8Ур, ФормаИндикатора);
Выборка9Ур = НайтиЗаписиРС_ПоКодуДСЕГл(Выборка8Ур.НомерЗаписиРСДСЕВх, НаДату).Выбрать();
Пока Выборка9Ур.Следующий() цикл
ОбластьДанныеДобавить(ПолеТабДок, ОбластьДанные9, 9, Выборка9Ур.ДСЕВходящий, Выборка9Ур.Применяемость, Выборка9Ур, ФормаИндикатора);
КонецЦикла;
КонецЦикла;
КонецЦикла;
КонецЦикла;
КонецЦикла;
КонецЦикла;
КонецЦикла;
КонецЦикла;
КонецЕсли;
КонецЦикла;
Функция НайтиЗаписиРС_ПоКодуДСЕГл(КодДСЕГл, НаДату, ДопустимаяЗамена = 0) Экспорт
Запрос = Новый Запрос;
Запрос.Текст =
"ВЫБРАТЬ
| СтруктураПриборов1СрезПоследних.ДСЕГлавный,
| СтруктураПриборов1СрезПоследних.ДСЕВходящий КАК ДСЕВходящий,
| СтруктураПриборов1СрезПоследних.Прибор,
| СтруктураПриборов1СрезПоследних.НомерЗаписиРСДСЕВх,
| СтруктураПриборов1СрезПоследних.НомерЗаписиРСДСЕГл,
| СтруктураПриборов1СрезПоследних.ДопустимаяЗамена,
| СтруктураПриборов1СрезПоследних.Применяемость,
| СтруктураПриборов1СрезПоследних.ДСЕВходящий.Ссылка,
| СтруктураПриборов1СрезПоследних.ДСЕВходящий.ВидПредмета КАК ВидПредмета,
| СтруктураПриборов1СрезПоследних.ДСЕВходящий.ВидПредмета.Порядок КАК ДСЕВходящийВидПредметаПорядок,
| СтруктураПриборов1СрезПоследних.ДСЕВходящий.Код КАК Код,
| СтруктураПриборов1СрезПоследних.Заимствованные,
| СтруктураПриборов1СрезПоследних.Период,
| СтруктураПриборов1СрезПоследних.ДатаОкончанияИспользования,
| СтруктураПриборов1СрезПоследних.ВводНового,
| СтруктураПриборов1СрезПоследних.ИзменениеСоставаИзделия
|ИЗ
| РегистрСведений.СтруктураПриборов1.СрезПоследних(
| &НаДату,
| НомерЗаписиРСДСЕГл = &КодДСЕГл
| И (ДатаОкончанияИспользования = &ПустаяДата
| ИЛИ ДатаОкончанияИспользования > &НаДату)
| И ДопустимаяЗамена = &ДопустимаяЗамена) КАК СтруктураПриборов1СрезПоследних
|
|УПОРЯДОЧИТЬ ПО
| ДСЕВходящийВидПредметаПорядок,
| Код";
Запрос.УстановитьПараметр("НаДату", НаДату);
Запрос.УстановитьПараметр("КодДСЕГл", КодДСЕГл);
Запрос.УстановитьПараметр("ПустаяДата", '00010101');
Запрос.УстановитьПараметр("ДопустимаяЗамена", ДопустимаяЗамена);
Возврат(Запрос.Выполнить());
КонецФункции
Прелесть! Выполняется около минуты. При чем этот код дублируется почти во всех отчетах.
После оптимизации объем кода сократился в 3 раза, а время выполнения составило 1-2 сек.
−122
Результат = Запрос.Выполнить().Выбрать();
Пока Результат.Следующий() > 0 Цикл
// что-то делаем
КонецЦикла;
−119
1С::Функторы::АппликативныйФунктор::Монад 1С::Монада::НаЭкран -> 1С::Монада::Символ,1С::Монада::СимволСлед
| Пустота = Отчёт.Откат()
| 1С::Буква = 1С::МонадаМир::ВводВывод::Печать 1С::Буква
Многие интересуются, существует ли в 1С метод вывода монады на экран? Оказывается, существует!
Данный аппликативный функтор не требует теор.ката, хотя и не без улыбки, выводит квантовое состояние функциональной монады в виде стрелок и морфизмов.
PS Автор не я, а мой коллега, который, ковыряясь в 1С, обнаружил в нём "Функциональный режим"
−117
Часто проскальзывают темы, что 1С часто отказывает в монадах.
Я вот этого вообще не понимаю, как такое может выглядеть???
Я со своей восьмёрочкой 2 года, в любой момент, когда я захочу монад, он будет.
Если он скажет, нет, я не хочу, я показываю ему С++, показываю что я недоволен и говорю, почему ты не хочешь монаду?
Ты любишь кресты? Когда монады встречаются в 1С, они должны преобразовываться по первому же желанию программиста.
−125
МояМонада :: МойПарсерТип МойПарсер -> (МойПарсерТип -> МойПарсер МойПарсерТип2) -> МойПарсер МойПарсерТип2
МойСущность МойМонад [] Где
Возврат МойТип = [МойТип]
МойВозвратВозврат >>= МойФункция = МойСклейка (МойВсем МойФункция МойВозвратВозврат)
Коллега выдал - закоммитил в локальный гитхаб 1С парсер хаскелля на 1С.
−124
Function ms2Str(Миллисекунды) export
КолВоЧасов=Цел(Миллисекунды/(60*60*1000));
Остаток=Миллисекунды-КолВоЧасов*60*60*1000;
КолВоМинут=Цел(Остаток/(60*1000));
Остаток=Остаток-КолВоМинут*60*1000;
КолВоСекунд=Цел(Остаток/1000);
КолВоМиллисекунд=Остаток-КолВоСекунд*1000;
h=Формат(КолВоЧасов,"ЧЦ=3;ЧН=;ЧВН=")+":";
if КолВоЧасов=0 then
h="";
endif;
m=Формат(КолВоМинут,"ЧЦ=2;ЧН=;ЧВН=")+":";
if КолВоМинут=0 then
m="";
endif;
return h+m+Формат(КолВоСекунд,"ЧЦ=2;ЧН=;ЧВН=")+":"+Формат(КолВоМиллисекунд,"ЧЦ=3;ЧН=;ЧВН=");
endFunction
Перевод время в миллисекундах в строку. Автор: Жуков А.П.