Мобильная версия

Поиск пропусков в нумерации документов запросом

24.12.2015

Поиск пропусков в нумерации документов запросом

Предлагается отчет на основе системы компоновки данных для выявления нарушений последовательности нумерации документов. Применяются методы из статей "Выразить строку как число и строку как дату в запросе" [http://infostart.ru/public/170336/] и "Быстрое определение интервалов в запросе" [http://infostart.ru/public/402534/]. Это позволяет решить задачу быстро и непосредственно в запросе.

Идея решения заключается в том, что сначала строковые номера документов выбранного вида преобразуется в числовые номера. Метод из статьи "Выразить строку как число и строку как дату в запросе" позволяет игнорировать префиксы, так как нечисловые символы номера автоматически заменяются нулями. Затем на множестве числовых номеров определяются интервалы между соседними номерами. Как нарушение выводятся все интервалы, величина которых больше единицы.

Интервалы определяются методом из статьи "Быстрое определение интервалов в запросе". За счет этого достигается гибкость и высокое быстродействие отчета.

Приводятся две версии отчета. Один для обычных форм, а второй - для управляемых. Они построены на основе СКД и содержат минимум вспомогательного кода. Настройки отчета содержат только период выборки документов. Запрос выбирает данные по всем организациям информационной базы и всем видам документов, которые определены в метаданных конфигурации.

Основой всего является запрос:

ВЫБРАТЬ    "0" КАК Цифра, 0 КАК Позиция, 1 КАК Вес
ПОМЕСТИТЬ СистемаСчисления
ОБЪЕДИНИТЬ ВЫБРАТЬ "1", 1, 10
ОБЪЕДИНИТЬ ВЫБРАТЬ "2", 2, 100
ОБЪЕДИНИТЬ ВЫБРАТЬ "3", 3, 1000
ОБЪЕДИНИТЬ ВЫБРАТЬ "4", 4, 10000
ОБЪЕДИНИТЬ ВЫБРАТЬ "5", 5, 100000
ОБЪЕДИНИТЬ ВЫБРАТЬ "6", 6, 1000000
ОБЪЕДИНИТЬ ВЫБРАТЬ "7", 7, 10000000
ОБЪЕДИНИТЬ ВЫБРАТЬ "8", 8, 100000000
ОБЪЕДИНИТЬ ВЫБРАТЬ "9", 9, 1000000000
ОБЪЕДИНИТЬ ВЫБРАТЬ "10",10,10000000000
;
ВЫБРАТЬ РАЗРЕШЕННЫЕ    "РеализацияТоваровУслуг" КАК ТипДокумента, Организация КАК Организация, Ссылка, Номер
ПОМЕСТИТЬ Документы
ИЗ Документ.РеализацияТоваровУслуг
ГДЕ Дата МЕЖДУ &НачалоПериода И &КонецПериода
;
ВЫБРАТЬ    ТипДокумента, Ссылка, Организация, СУММА(СтепениДесяти.Вес * Цифры.Позиция) / МИНИМУМ(СтепениДесяти.Вес) КАК Номер
ПОМЕСТИТЬ Дано
ИЗ Документы
СОЕДИНЕНИЕ СистемаСчисления КАК СтепениДесяти ПО (ИСТИНА)
СОЕДИНЕНИЕ СистемаСчисления КАК Цифры ПО (ПОДСТРОКА(Номер, 11 - СтепениДесяти.Позиция, 1) = Цифры.Цифра)
СГРУППИРОВАТЬ ПО ТипДокумента, Ссылка, Организация
;
ВЫБРАТЬ ТипДокумента, Организация, Номер + 1 КАК НомерПары, Номер КАК НижняяГраница, Номер КАК ВерхняяГраница
ПОМЕСТИТЬ Тур0
ИЗ Дано
;
ВЫБРАТЬ    ТипДокумента, Организация, ВЫРАЗИТЬ(НомерПары / 2 КАК ЧИСЛО(15, 0)) КАК НомерПары
    , МИНИМУМ(НижняяГраница) КАК НижняяГраница,    МАКСИМУМ(ВерхняяГраница) КАК ВерхняяГраница, МИНИМУМ(ВерхняяГраница) КАК НачалоИнтервала, МАКСИМУМ(НижняяГраница) КАК КонецИнтервала
ПОМЕСТИТЬ Тур1
ИЗ Тур0
СГРУППИРОВАТЬ ПО ТипДокумента, Организация, ВЫРАЗИТЬ(НомерПары / 2 КАК ЧИСЛО(15, 0))
;
ВЫБРАТЬ ТипДокумента, Организация, НачалоИнтервала, КонецИнтервала
ПОМЕСТИТЬ Интервалы
ИЗ Тур1
ГДЕ НачалоИнтервала + 1 < КонецИнтервала
;
ВЫБРАТЬ    Интервалы.ТипДокумента, Интервалы.Организация, Дано1.Ссылка КАК Документ1, Дано2.Ссылка КАК Документ2
ИЗ Интервалы КАК Интервалы 
ВНУТРЕННЕЕ СОЕДИНЕНИЕ Дано КАК Дано1 ПО Интервалы.ТипДокумента = Дано1.ТипДокумента И Интервалы.Организация = Дано1.Организация И Интервалы.НачалоИнтервала = Дано1.Номер
ВНУТРЕННЕЕ СОЕДИНЕНИЕ Дано КАК Дано2 ПО Интервалы.ТипДокумента = Дано2.ТипДокумента И Интервалы.Организация = Дано2.Организация И Интервалы.КонецИнтервала = Дано2.Номер

Перед компоновкой текст данного запроса "распаковывается" для обработки всех видов документов и для выполнения необходимого числа "итераций" определения интервалов. Для 11-значных номеров требуется 37 итераций.

Целью создания отчетов было расширение области применения методов из указанных статей и демонстрация их практической полезности.


Текст публикации

Все новости



ИНТЕХ

купить, программ, 1С, 1, С, в, Егорьевске, Московской, бухгалтерия, предприятие, продукт, 2, 3, 8, 7, 10, 11, 5, 0, торговля, склад, зарплата, кадры, управление, персонал, настроить, обучение, на, курсы, компьютерный, центр, ООО, ИНТЕХ, учет, производство, ERP, УПП, УТ, ЗУП, упрощенка,  документооборот, розница, небольшая, фирма, деньги, скачать, сопровождение, внедрить, обновить, обучить, франчайзи, организация, поддержка, сертифицированный, аттестованный, компьютер, Егорьевск, Москва, область, Воскресенск, Шатура, Ликино, Коломна, Рошаль, Бронницы, Шувое, Куровское, Луховицы, ЭЦП, отчетность, ИТС, электронный, архив, автоматизация, оперативный, техподдержка, телефон, Интернет, аренда, автосервис, магазин, бухфон, горячая, линия, битрикс, версия, лицензия, линк, релиз, сайт, фреш, ЦСО, ЭДО, яндекс, карта. купить, программ, 1С, 1, С, в, Егорьевске, Московской, бухгалтерия, предприятие, продукт, 2, 3, 8, 7, 10, 11, 5, 0, торговля, склад, зарплата, кадры, управление, персонал, настроить, обучение, на, курсы, компьютерный, центр, ООО, ИНТЕХ, учет, производство, ERP, УПП, УТ, ЗУП, упрощенка,  документооборот, розница, небольшая, фирма, деньги, скачать, сопровождение, внедрить, обновить, обучить, франчайзи, организация, поддержка, сертифицированный, аттестованный, компьютер, Егорьевск, Москва, область, Воскресенск, Шатура, Ликино, Коломна, Рошаль, Бронницы, Шувое, Куровское, Луховицы, ЭЦП, отчетность, ИТС, электронный, архив, автоматизация, оперативный, техподдержка, телефон, Интернет, аренда, автосервис, магазин, бухфон, горячая, линия, битрикс, версия, лицензия, линк, релиз, сайт, фреш, ЦСО, ЭДО, яндекс, карта,

Обновление 1С, управленческий учет, бухгалтерский учет

Наша компания также занимается разработкой собственных программных продуктов на платформе «1С:Предприятие 8». 

В нашей компании работают сертифицированные фирмой «1С» специалисты, которые постоянно совершенствуют свои знания и навыки. Они помогут качественно и оперативно решить задачи по автоматизации управления и учета на вашем предприятии.
Наша компания опирается в своей работе на знание и повседневное применение стандартов качества, проектных методов в управлении, процессного подхода в организации нашей деятельности.
Компания хорошо организована, в ней четко распределены обязанности, процедуры, соблюдается технология работы, имеются оперативные инструкции, документированные и известные всему персоналу, существуют отработанные процедуры контроля выполняемых работ и, конечно, профессиональный и хорошо обученный персонал, способный качественно выполнять свою работу.