Об общих реквизитах

Публикация № 1144154

Разработка - Практика программирования

общие реквизиты разработка обслуживание метаданные разделение данных производительность планы запросов

69
Общие реквизиты. Что за ними скрывается?

Предисловие

Начиная с версии платформы 8.2.14.x и до последних актуальных релизов, в дереве метаданных конфигурации имеется такой объект как "Общие реквизиты". Подобный функционал предоставляла еще платформа 7.7, но в восьмой ветке эти возможности стали доступны далеко не сразу.

Сегодня мы рассмотрим нюансы использования данного объекта при разработке конфигураций, а также проанализируем структуру его хранения на стороне базы данных.

Возможности

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

Рассмотрим пример. В некоторой тестовой конфигурации, которой на самом деле не существует :), создадим четыре документа с именами "Doc1", "Doc2", "Doc3" и "Doc4". В каждый из документов нам необходимо добавить комментарий, причем он должен отображаться в форме списка каждого из документов.

Для этого создадим новый объект конфигурации в ветке "Общие -> Общие реквизиты"  и назовем его "Комментарий". Тип значения укажем "Строка" длинной 255 символов. Также включим многострочный режим. Результат описанных действий Вы можете видеть на скриншоте "Настройки общего реквизита" ниже.

Все настройки аналогичны настройкам любого реквизита документа, за исключением раздела "Использование". Здесь нас интересует опция "Состав", в которой определяется состав объектов конфигурации. Именно здесь и будет определяться список тех объектов, для которых будет использоваться этот общий реквизит. Включим использование для первых трех документов.

Отметим, что режим использования "Автоматически" ориентируется на настройку "Автоиспользование" общего реквизита. В нашем примере свойство "Автоиспользование" для реквизита установлено в "Не использовать". Значит для документа "Doc4" общий реквизит не будет задействован, пока не включить использование явно.

 
 Настройка общего реквизита

В режиме конфигуратора сделаны все необходимые настройки. Запустим режим предприятия и откроем форму списка "Doc1". Мы увидим, что реквизит доступен как в списке, так и в форме документа.

То есть появился новый реквизит "Комментарий", имеющий строковой тип и многострочный режим редактирования. Такую же картину мы будем наблюдать для документов "Doc2" и "Doc3". 

Для общих реквизитов доступны стандартные возможности отбора, а в режиме конфигуратора работа с ними в форме документа никак не отличается от работы с обычными реквизитами.

Например, если создать запрос к документу "Doc3", то в доступных полях будет общий реквизит "Комментарий".

Единственное, чем функционал общего реквизита отличается от обычного, так это отсутствием возможности добавить его в графу журнала документов. В остальном же с ними можно работать стандартным образом.

Что там внутри

Для ответа на этот вопрос проанализируем как платформа 1С работает с общими реквизитами на стороне базы данных, а также каким образом к ним строятся запросы на выборку данных.

Сразу скажу, что для хранения значений общих реквизитов не используется отдельная таблица в базе данных. Если бы это было так, то использование данного объекта конфигураций отрицательно сказалось на общей производительности системы, так как запросы к реквизитам документа усложнились за счет использования дополнительного соединений. Общие реквизиты сохраняются в дополнительной колонке, добавляемой для таблиц документов, включенных в их состав. То есть также, как если бы реквизит был добавлен непосредственно в самом объекте.

Обратимся к документу "Doc4", который не был включен в общий реквизит "Комментарий". Чтобы показать, как изменяется таблица документа в SQL-базе при добавлении его в состав общего реквизита, обратимся к следующему скриншоту.

Был добавлен общий реквизит с типом "Булево", в состав которого мы включили документ "Doc4". В итоге, при обновлении структуры информационной базы, в исходную таблицу "_Document10" было добавлено поле "_Fld17" булевого типа. Отсюда следует, что общие реквизиты добавляют к таблицам БД как дополнительные поля, аналогично тому, если бы мы создали вручную реквизиты для каждого документа.

Соответственно, запросы к таблицам SQL-базы будут в точности повторять запросы к полям, если бы они были созданы обычным способом. Делаем вывод, что явное отрицательное влияние на производительность отсутствует.

Но все ли так

Как обычно, не все так идеально. У общих реквизитов есть один существенный минус, как и у любого универсального подхода - это отсутствие возможности гибкой настройки этого реквизита для отдельных таблиц. На то он и общий, не так ли?

Например, в той же конфигурации, включив индексирование для общего реквизита "Комментарий", этот индекс будет создан в таблице каждого документа. Даже если индекс для конкретного документа будет не нужен, то отключить его средствами платформы 1С не будет возможности. Вот так индекс был добавлен в 3 документа, в которые мы добавляли общий реквизит "Комментарий".

 
 Индексы по общему реквизиту

Зачем отключать этот индекс? Обычно индексы добавляются для конкретных ситуаций. Добавляя их заранее для всех объектов, скорее всего некоторые из них будут избыточными (не всегда конечно же). С использованием общего реквизита Вы просто не сможете отключать индекс там, где он не используется.

Если сильно захотеть, то индекс удалить все же можно, воспользовавшись этим подходом, ведь где индекс можно добавить своими скриптами, такими же скриптами его можно и удалить. Там же в статье описаны все плюсы и минусы такого способа.

Кроме настройки индексирования Вы также лишаетесь возможности делать другие точечные настройки общего реквизита для объектов:

  • Использование в полнотекстовом поиске
  • Историю данных
  • Заполнение из данных заполнения
  • Проверку заполнения
  • И др.

Таким образом, использование общего реквизита обосновано, если все перечисленные проблемы не относятся к поставленной задаче разработки.

А как обстоят дела с использованием этого механизма в типовых конфигурациях?

В типовых конфигурациях

В типовых решениях Вы не часто встретите использование общих реквизитов, за одним большим исключением - это разделение данных из подсистемы "Работа в модели сервиса" из БСП. Подсистема позволяет разделить все хранимые данные в базе на изолированные части, чтобы в одной базе данных могли работать несколько компаний. Все это было сделано для облачной работы решений на платформе 1С.

По моему мнению, общие реквизиты как раз и были изначально созданы разработчиками платформы, чтобы реализовать разделение данных в конфигурациях. Но это, конечно, не точно :)

 
 Небольшая цитата с ИТС

Разделение данных можно найти во всех популярных решениях. На стороне базы данных они также отражены дополнительным полем, но за важным отличием - это поле добавляется во все индексы объекта с разделением на первую позицию. Не важно, используйте Вы разделение данных или нет - разделитель у Вас есть в базе и платформа использует его для построения запросов. В 100% случаев это числовое поле. Если разделение данных не включено, то оно заполняется значением "0" и по этому же значению устанавливается фильтр во всех запросах.

Есть интересный момент в анализе планов запросов при наличии разделителя в индекса. Как известно, операция "Table scan" или "Index scan" (сканирование, просмотр таблицы / индекса) обычно не очень хороший признак выполняемых запросов на больших таблицах. Взгляните на такой случай.

ВЫБРАТЬ
	РеализацияТоваровУслуг.Ссылка КАК Ссылка
ИЗ
	Документ.РеализацияТоваровУслуг КАК РеализацияТоваровУслуг

Уже из текста можно понять, что запрос скорее всего написан с ошибкой, т.к. выбирать всю таблицу реализаций - это последнее дело на больших базах. Если в базе разделителей нет (например, если у Вас старая и добрая УТ 10.3), то план запроса будет с операцией сканирования индекса.

 
 Запрос и его план (без разделения данных)

Теперь выполним примерно такой же запрос на "Бухгалтерии предприятия 3.0", где разделитель данных уже присутствует. И вот результат.

 
 Запрос и его план (с разделением данных

Что все это значит? А то, что не нужно смотреть в плане запроса на выполняемые операции и ожидать, что если выполняется "Index Seek" (Поиск в индексе), то значит с запросом все хорошо. Поиск в индексе бывает разный, и не всегда оптимальный. Рекомендую отличную статью по работе с планами запросов "Планы запросов - это просто!" от Андрея Овсянкина.

Еще одним моментом, связанным с разделением данных, является падение производительности для тех пользователей, которые могут работать со всеми областями данных. В этом случае платформа 1С не ставит явный отбор по разделителю и практически все запросы превращаются в сканирование таблиц и индексов. Подробнее об этом Вы можете прочитать в статье "Управление доступом: роли, права, профили, группы доступа, функциональные опции, RLS" от Евгении Карук.

А Вы использовали когда-либо разделение данных? Есть чем дополнить материал?

Жизнь обычного разработчика

В самом начале статьи Вы видели пример добавления общего реквизита, но он не имеет ничего общего с практическими задачами. За весь опыт работы с платформой и различными конфигурациями мне известны лишь несколько кейсов, когда разработчики их применяли:

  1. Добавление реквизита для объекта в типовой конфигурации, чтобы не затрагивать основной объект. Вроде как сделано, чтобы обновлять конфигурацию было проще.
  2. Создание общих атрибутов для объектов в виде общих реквизитов (даты создания и изменения, ответственный и другие произвольные атрибуты).
  3. Просто бездумное добавление полей, чтобы меньше "кликать" в конфигурации.

В отраслевых решениях можно встретить различного рода общие реквизиты, в отличии от решений фирмы "1С".

Использовать?

Все зависит от конкретной ситуации. Если в один прекрасный момент Вам понадобиться создать для всех документов конфигурации один и тот же реквизит с одинаковыми свойствами, то использования общего реквизита поможет сэкономить Вам время. Есть моменты, которые могут помешать использовать его возможности - это невозможность его использования в графе журнала документов и отсутствие гибкой настройки для каждого документа отдельно в дереве метаданных. Думаю, что в следующих версиях платформы станет возможным использовать общие реквизиты в журналах документов, но кто знает.

В завершении скажу, что за все время работы с платформой 1С:Предприятие 8.x, мне не приходилось использовать общие реквизиты для решения практических задач. В типовых конфигурациях, с которыми имел дело, также не находил их применения, за исключением редких отраслевых конфигураций. Поэтому 100 раз подумайте, прежде чем добавлять их в конфигурацию.

Выводы делать только Вам!

Другие ссылки

69

Специальные предложения

Комментарии
Избранное Подписка Сортировка: Древо
1. AlX0id 28.10.19 11:30 Сейчас в теме
Использовал общие реквизиты и стал Королем Севера %)
(по мотивам картинки публикации)
Shmell; YPermitin; +2 Ответить
2. YPermitin 5739 28.10.19 11:36 Сейчас в теме
7. timeforlive 11 29.10.19 04:42 Сейчас в теме
(2) Отсылка к игре престолов, видимо.
YPermitin; +1 Ответить
9. YPermitin 5739 29.10.19 06:50 Сейчас в теме
(7) мне уже объяснили, то я особый мем использовал.

Сам не смотрел.
timeforlive; +1 Ответить
3. Dach 284 28.10.19 14:33 Сейчас в теме
Есть чем дополнить про разделение данных.

Помимо того, что в кластерный индекс каждой таблицы каждого объекта добавляется колонка с общим реквизитом, можно еще отметить:

1. Если в состав общего реквизита - разделителя данных включить ссылочный объект данных, то уникальность кода/номера данного объекта применима только к конкретной области данных. То есть, если в базе есть разделение по Организации, то в ней может быть несколько одинаковых документов с одним и тем же номером и годом. Это необходимо учитывать, используя методы НайтиПоКоду, НайтиПоНомеру.

2. Корректная работа в Предприятии возможно только под пользователем с разделением данных. Кстати, НайтиПоКоду и НайтиПоНомеру будут корректно работать, если установлены параметры сеанса "Значение разделителя данных" и "Использование разделения данных".

3. Зайти в Конфигуратор и непосредственно Конфигурировать возможно только под пользователем без разделения данных. Это накладывает необходимость постоянно запускать отладку под пользователем С разделением.

4. Когда Вы пишете код - Вы постоянно должны помнить, где он будет работать - с разделением данных или без. Например, программируя фоновое задание, об этом нужно думать отдельно. Для фоновых заданий, которые должны работать с разделением данных - нужно заботиться отдельно об установке нужного параметра сеанса. И наоборот.

5. Если Ваше регламентное задание входит в состав общего реквизита - в общем случае в базе будет создано столько экземпляров регламентных заданий, сколько областей данных существует. Увидеть все РЗ можно только под пользователем БЕЗ разделения. После обновления ИБ – все эти экземпляры РЗ будут включены (если в конфигурации у РЗ свойство «используется» - включено). В общем случае разработчик должен не взводить флаг «использование» при добавлении нового РЗ. Администратор БД затем сам включит только нужный экземпляр РЗ.
chembulatov76; user666919_budulau; JohnyDeath; muwa_; dsdred; vv2; json; Алексей_mir2mb; AlX0id; acanta; YPermitin; +11 Ответить
4. YPermitin 5739 28.10.19 15:16 Сейчас в теме
(3) тот момент, когда информация про разделители в комментарии более ценная, чем в статье!

Вижу, что у Вас большой опыт работы с этим. Обслуживаете Fresh? :)
5. Dach 284 28.10.19 16:53 Сейчас в теме
(4)

Нет. У нас "элегантное, превращающееся в брюки" решение.... (тут можно радоваться, а можно и поплакать xD)

Есть РИБ. Каждый узел - это конкретная организация. И есть центральная база, куда мигрируют часть данных из каждого узла (и наоборот, соответственно). Во всем пространстве РИБ включено разделение данных. Получается, в центральной базе есть консолидированная и в то же время разделенная по областям сводная информация. Плюс появляется возможность из центральной базы, после общего анализа эффективности и сравнения областей-узлов между собой, "рулить" всякими показателями, влияющими на ценообразование и т.д.

Еще, кстати, про разделение и индексы. Как я уже заметил, если включить любой объект в состав реквизита - во все таблицы объекта будет добавлена колонка общего реквизита в кластерный индекс, в самое его начало.

Тоже самое касается таблиц итогов регистров накопления и бухгалтерии.

Так вот, если режим использования общего реквизита стоит "Независимо и совместно" (то есть, есть объекты, которые разделяются, есть которые нет) и есть желание использовать регистр накопления, общий для всех областей данных, то в такой регистр обязательно надо добавить измерение с типом = общий реквизит. Иначе, как легко догадаться, возникнут трудности в разборе таких данных...
SeiOkami; dalgaso2010; PowerBoy; vv2; YPermitin; acanta; +6 Ответить
6. YPermitin 5739 28.10.19 17:21 Сейчас в теме
(5) звучит монструозно, но круто!

Снимаю шляпу! :)
23. SeiOkami 1217 02.11.19 09:38 Сейчас в теме
(5) тоже используем "Независимо и совместно". И даже свою систему разрабатываем, где пользователь работает под несколькими разделителями сразу.

А особенно интересную оптимизацию открыли для себя, когда стали в неразделенных сеансах во всех запросах использовать использовать обязательное условие:

РазделительУчета В (&ВсеРазделителиУчета)

Индексы нормально заработали, всё отчёты взлетели. Конечно, посмотрев на состав индексов, можно было догадаться изначально - всё гениальное просто
YPermitin; +1 Ответить
24. SeiOkami 1217 02.11.19 09:42 Сейчас в теме
(23) а ещё делал специальный общий модуль, в который передаешь СКД с настройками, а внутри:
1. Вычленяется запрос СКД
2. Разными фоновыми выполняется запрос под всеми разделителями учёта
3. Собирается общий результат
4. В СКД подменяется набор данных запрос на набор данных объект
5. Выполняется СКД с полученными параллельно данными

Для разработки несложных СКД самое то. Делаешь обычный запрос, а при компоновки данных просто вызываешь метод общего модуля.
YPermitin; +1 Ответить
25. SeiOkami 1217 02.11.19 09:50 Сейчас в теме
(24) ну и всё это базируется на другом общем модуле для распараллеливания выполнение произвольного метода под разделителями учёта. Заметно облегчает жизнь, когда нужен очередной инструмент по массовой загрузки или изменению данных
26. SeiOkami 1217 02.11.19 09:54 Сейчас в теме
(25) ну и в дополнение. Когда подключаешь регистр к разделителю, нужно учитывать, что и итоги теперь раздельные. И пересчет итогов нужно выполнять под каждым разделителем . И для этого тоже описали инструмент.

Но, как вариант, на копиях используем свой SQL скрипт. Точнее, отредактированный отловленный. Тот, что выполняет платформа. Единственное изменение - платформа в запрос зашивает отбор по одному разделителю. Просто убираем его и делаем пересчет сразу по всей базе. Очень удобно, когда у вас несколько десятков областей данных и не приходится контролировать итоги под каждой областью.
8. timeforlive 11 29.10.19 04:49 Сейчас в теме
Спасибо за статью. Очень полезная информация.
Никогда не применял общий реквизит и дальше (надеюсь) не буду ^_^
РИБ зло.
YPermitin; +1 Ответить
10. dsdred 1241 29.10.19 13:39 Сейчас в теме
Сам не использую, но встречал как то года 3 назад общий реквизит в конфигурации в которую прилетали данные из разных мест.
Собственно он хранил некий уникальный идентификатор. Помню что именно из-за него какой то был косяк... Но уже не помню какой.
11. nicxxx 236 30.10.19 11:00 Сейчас в теме
"Очень неоптимально. Но какой запрос - такой и план." Стесняюсь спросить, а что тут неоптимального?
PS. Для непосвященных - чтобы выбрать всю таблицу, как раз и надо ее всю просканировать.
YPermitin; +1 Ответить
12. YPermitin 5739 30.10.19 11:05 Сейчас в теме
(11) дело не в этом.

Имеется ввиду, что если идет сканирование индекса, то ожидаешь в плане увидеть эту операцию (index scan).
Но т.к. есть отбор по разделителю, то все равно будет поиск по индексу в плане, а не сканирование (index seek).
Это может вводить в заблуждение при чтении планов и это стоит учитывать.

Ну а выбирать данные из большой таблицы, это явно не регулярный запрос :)
А если регулярный, то нужно 100 раз подумать "Зачем?".
13. nicxxx 236 30.10.19 11:08 Сейчас в теме
(12) А, с этим да, согласен. Раздражает. Кстати, если разделители мешают жить, их не так уж и сложно выпилить из конфигурации. Конечно, при условии, что не нужна поддержка от вендора.
YPermitin; +1 Ответить
14. YPermitin 5739 30.10.19 14:18 Сейчас в теме
(13) был опыт отказа. Подводных камней много собралось:
1. На больших таблицах ждут реструктуризации еще большего размера :)
2. При удалении разделителя некоторые данные теряются, например в константах, настройках подключения внешних источников и др.
3. Непонятные ошибки реструктуризации на уровне SQL Server.

Вообщем, не всегда все просто.
15. nicxxx 236 30.10.19 14:21 Сейчас в теме
(14) Реструктуризацию можно обойти, если перед началом таблицу переименовать и создать пустую таблицу с этим именем.
А вот про потерю данных - интересно.
17. jenyach 30.10.19 19:02 Сейчас в теме
Разделение данных можно найти во всех популярных решениях. На стороне базы данных они также отражены дополнительным полем, но за важным отличием - это поле добавляется во все индексы объекта с разделением на первую позицию. Не важно, используйте Вы разделение данных или нет - разделитель у Вас есть в базе и платформа использует его для построения запросов. В 100% случаев это числовое поле. Если разделение данных не включено, то оно заполняется значением "0" и по этому же значению устанавливается фильтр во всех запросах. - выходит, что если разделитель не используется, то все индексы в принципе не работают, т.к. для всех записей в индексе первым стоит максимально не селективное поле? и будет, по сути, всегда скан
18. YPermitin 5739 30.10.19 19:11 Сейчас в теме
(17)
начению устанавливается фильтр во всех запросах. - выходит, что если разделитель не используется, то все индексы в принципе не работают, т.к. для всех записей в индексе первым стоит максимально не селективное поле? и будет, по сути, всегда скан


Скана не будет, если остальные отборы будут корректны.
Fox-trot; +1 Ответить
19. jenyach 30.10.19 19:18 Сейчас в теме
(18) например? какая разница, какое значение будет у остальных полей, если у первого поля в индексе всегда 0, т.е. всё равно сиквелу придется перебрать все записи, разве может работать индекс, начиная со второго поля?
20. YPermitin 5739 30.10.19 19:22 Сейчас в теме
(19) есть статистика по распределению значений, да и мне кажется Вы что-то путаете в работе индекса. Сканирование будет только в том случае, если согласно статистике отборы будут неселективные. Все отборы.

Возьмите любой регистр, где первое измерение - это организация. Если бы Вы были правы, а там ведь могут 90% записей быть по одной организации, то этот регистр бы всегда почти сканировался.

Тогда вообще бы смысла в индекса не было, в том числе и для баз 1С.

Вообщем, главное статистика и селективность для всего отбора, а не отдельного поля.
21. acanta 74 30.10.19 19:24 Сейчас в теме
Вероятно скан будет при запросе по выборочно нескольким или всем областям разделения данных?
По одной должно быть всегда быстро.
22. tormozit 5613 02.11.19 00:21 Сейчас в теме
Применял общие реквизиты с самого их появления и продолжаю применять и не планирую от них отказываться. Вот самые ходовые общие реквизиты:
- автор создания (только для ссылочных)
- дата создания (только для ссылочных)
- автор изменения
- дата изменения
Чем больше в конфигурации типов объектов данных, тем сильнее экономия от добавления общих реквизитов по сравнению с размножением аналогичных реквизитов по метаданным, особенно если в формах есть вызов общей процедуры ПриСозданииНаСервере. Тогда в большинстве случаев даже не придется менять объекты метаданных для таких типов данных, т.к. вывести их в формы списков/объектов можно будет в этой одной процедуре динамически.
YPermitin; +1 Ответить
27. newdigger 10.11.19 15:15 Сейчас в теме
Писал конфигурацию на обычных формах с использованием общих реквизитов для документов: Автор, Комментарий. Все было хорошо. Потом для журнала одного из документов потребовался функционал, который легко реализовывался через управляемые формы. Но столкнулся с тем, что в динамических списках не отображаются колонки общих реквизитов, хотя в запросе они есть и никаких ошибок или предупреждений конфигуратор не выдает.
YPermitin; +1 Ответить
28. acanta 74 10.11.19 19:30 Сейчас в теме
В 7ке для риб всегда добавляла справочник базы, рабочие места и общий реквизит место создания обычно типа ИБ . В рознице 8 есть нечто подобное, все что связано с подключением торгового оборудования может понадобиться и для администрирования, например участвовать в РЛС, отбор всех объектов для регистрации обмена. Все тоже самое нашлось в 8ке в виде регистров сведений.
Оставьте свое сообщение

См. также

Полезные процедуры и функции для программиста 140

Статья Программист Нет файла v8 1cv8.cf Россия Бесплатно (free) Практика программирования Универсальные функции

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

07.10.2019    8956    HostHost    23       

Агрегатные функции СКД, о которых мало кто знает 342

Статья Программист Нет файла v8 v8::СКД 1cv8.cf Бесплатно (free) Практика программирования

Пользуетесь ли Вы всеми возможными агрегатными функциями, которые предоставляет система компоновки данных? Если Вы используете только: СУММА, КОЛИЧЕСТВО, МИНИМУМ, МАКСИМУМ, СРЕДНЕЕ, то эта статья для Вас.

05.09.2019    13029    ids79    44       

Три костыля. Сказ про фокусы в коде 123

Статья Программист Нет файла v8 Бесплатно (free) Практика программирования Разработка

Три интересных (или странных) костыля в коде, которые могут помочь в повседневных и не очень задачах.

03.09.2019    9210    YPermitin    68       

Отслеживание выполнения фонового задания 141

Статья Программист Нет файла v8 1cv8.cf Бесплатно (free) Практика программирования Универсальные функции Разработка

Запуск фонового задания из модуля внешней обработки. Отслеживание выполнения задания в виде прогресса, расположенного на форме.

17.08.2019    10444    ids79    16       

Функции СКД: ВычислитьВыражение, ВычислитьВыражениеСГруппировкойМассив 253

Статья Программист Нет файла v8 v8::СКД 1cv8.cf Бесплатно (free) Практика программирования

Подробное описание и использование внутренних функций системы компоновки данных: Вычислить, ВычислитьВыражение, ВычислитьВыражениеСГруппировкойМассив, ВычислитьВыражениеСГруппировкойТаблицаЗначений.

08.08.2019    14110    ids79    30       

Фоновое выполнение кода в 1С - это просто 120

Статья Программист Нет файла v8 1cv8.cf Бесплатно (free) Практика программирования Разработка

Как легко запускать выполнение в фоне, не прибегая к долгому описанию фоновых процедур.

02.08.2019    11400    avalakh    21       

СКД - наборы данных и связи между ними, создание собственной иерархии, вложенные отчеты 131

Статья Программист Нет файла v8 v8::СКД 1cv8.cf Бесплатно (free) Практика программирования

Набор данных объект. Использование в схеме компоновки нескольких наборов данных. Различные варианты связи наборов: объединение, соединение. Использование иерархии в отчетах на СКД. Создание собственной иерархии, иерархия детальных записей. Использование вложенных схем в отчетах на СКД.

26.07.2019    12689    ids79    6       

СКД - использование расширений языка запросов, секция ХАРАКТЕРИСТИКИ 146

Статья Программист Нет файла v8 v8::СКД Бесплатно (free) Инструментарий разработчика Практика программирования

Автоматическое и не автоматическое заполнение полей компоновки данных. Использование расширений языка запросов для СКД «{…}», секция ВЫБРАТЬ, секция ГДЕ, параметры виртуальных таблиц. Автоматизированное использование дополнительных данных в запросе: секция ХАРАКТЕРИСТИКИ.

17.07.2019    11192    ids79    27       

Регистры сведений. За кулисами 129

Статья Программист Нет файла v8 1cv8.cf Бесплатно (free) Практика программирования Разработка

Небольшие заметки по внутреннему устройству регистров сведений.

09.07.2019    8730    YPermitin    12       

"Меньше копипаста!", или как Вася универсальную процедуру писал 183

Статья Программист Стажер Нет файла v8 v8::СКД 1cv8.cf Бесплатно (free) Практика программирования Разработка

Программист Вася разбирает подход создания универсальных методов на примере программного вывода СКД.

04.07.2019    7902    SeiOkami    49       

Создание отчетов с помощью СКД - основные понятия и элементы 208

Статья Программист Нет файла v8 v8::СКД Бесплатно (free) Практика программирования Математика и алгоритмы

Основные принципы работы СКД. Понятия схемы компоновки и макета компоновки. Описание основных элементов схемы компоновки: наборы данных, поля, вычисляемые поля, ресурсы, параметры.

25.06.2019    21000    ids79    17       

Многопоточное ускорение однопользовательских нагрузок в 1С + Microsoft SQL Server 2017 179

Статья Программист Нет файла v8 v8::Запросы Бесплатно (free) Практика программирования Разработка

Взаимодействие с Microsoft SQL Server нередко вызывает трудности у 1С-ников, а потому интересны любые моменты, связанные с его использованием. О своем опыте работы с новым SQL Server 2017 участникам конференции Infostart-2018 рассказал директор ООО «Аналитика софт» Дмитрий Дудин.

11.06.2019    12712    dmurk    134       

Регистры накопления. Структура хранения в базе данных 176

Статья Программист Нет файла v8 1cv8.cf Бесплатно (free) Практика программирования Разработка

Структура хранения регистров накопления в базе данных для платформы 1С:Предприятие 8.x. Первая часть в серии публикаций.

16.05.2019    18983    YPermitin    27       

Выполнение внешней обработки в фоновом задании 149

Статья Программист Нет файла v8 1cv8.cf Бесплатно (free) Практика программирования Разработка

Подробное описание подхода к созданию длительной операции на основе внешней обработки. Реализация протестирована на 1С 8.3.12.1714 (x64).

11.05.2019    11259    Eret1k    23       

Выгрузка документа по условию 5

Статья Программист Нет файла v8 Бесплатно (free) Практика программирования Разработка

Что делать, если документы нужно выгружать не все подряд, а по какому-то фильтру: статусу, дате, набору условий... А что если он соответствовал этим условиям, а потом перестал? А если потом опять начал? Такие ситуации заставили попотеть не одного программиста.

25.04.2019    6038    m-rv    2       

Как прикрутить ГУИД к регистру сведений 23

Статья Программист Нет файла v8 Бесплатно (free) Практика программирования Перенос данных из 1C8 в 1C8 Разработка

... и немного теории обмена данными. В частности, разберем боль всех, кто пишет небанальные обмены данными: как набору записей регистра сведений назначить гуид и далее использовать его в обмене для идентификации этого набора.

16.04.2019    8667    m-rv    16       

О расширениях замолвите слово... 193

Статья Программист Стажер Нет файла v8 Бесплатно (free) Практика программирования Разработка

О чём стоит задуматься при принятии решения о создании расширения конфигурации…

07.04.2019    17840    ellavs    122       

Git-репозитории для 1С-кода (опыт использования при небольших проектах) 202

Статья Программист Стажер Нет файла v8 Windows Бесплатно (free) Практика программирования Разработка

Инструкции по взаимодействию с Git-репозиторием, которые писались для тех наших программистов, которые вообще никогда не работали с Git (руководства в духе "Как получить код из git-репозитория?", "Как отправить код в git-репозиторий")...

28.03.2019    13928    ellavs    83       

Трюки с внешними источниками данных 166

Статья Программист Нет файла v8 1cv8.cf Бесплатно (free) Практика программирования Разработка

Некоторые трюки для преодоления ограничений внешних источников данных.

14.03.2019    14222    YPermitin    52       

Возможности типовых шаблонов ограничения доступа на уровне записей (RLS) 166

Статья Программист Нет файла v8 v8::Права Бесплатно (free) Практика программирования БСП (Библиотека стандартных подсистем) Роли и права

Краткий обзор применения типовых шаблонов ограничения доступа на уровне записей в конфигурациях, созданных на базе БСП: #ПоЗначениям, #ПоНаборамЗначений, #ПоЗначениямРасширенный, #ПоЗначениямИНаборамРасширенный

03.02.2019    17319    ids79    9       

EnterpriseData – часть 2. Процесс выгрузки данных 127

Статья Программист Нет файла v8 v8::УФ Россия Бесплатно (free) Практика программирования Обмен через XML

Основные этапы выгрузки данных через ED, обработчики событий выгрузки, правила обработки данных, правила конвертации объектов, конвертация свойств первого и второго этапов, процедуры БСП, используемые при выгрузке данных, структура «КомпонентыОбмена».

26.12.2018    13777    ids79    27       

Новый подход к обмену данными EnterpriseData 207

Статья Программист Нет файла v8 v8::УФ Россия Бесплатно (free) Практика программирования Обмен через XML

Хочу предложить Вашему вниманию цикл статей, посвященных обмену данными через универсальный формат (EnterpriseData или ED).

14.12.2018    23146    ids79    72       

Программное заполнение пользовательских параметров и отборов СКД 136

Статья Программист Нет файла v8 v8::СКД 1cv8.cf Бесплатно (free) Практика программирования

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

13.11.2018    22152    Unk92    19       

Автоматические и управляемые блокировки применительно к типовым конфигурациям 1С 127

Статья Программист Нет файла v8 v8::blocking 1cv8.cf Бесплатно (free) Математика и алгоритмы Практика программирования

Основные принципы работы с режимами автоматических и управляемых блокировок в 1С Предприятие 8. Теория и применение в типовых конфигурациях: БП, УТ, ЕРП

10.11.2018    22254    ids79    40       

Создаем свои индексы для баз 1С. Со своей структурой и настройками! 128

Статья Системный администратор Программист Нет файла Бесплатно (free) Производительность и оптимизация (HighLoad)

Поговорим о неплатформенных индексах для информационных баз 1С. Об особенностях их использования, целесообразности и подводных камнях.

05.11.2018    12792    YPermitin    31       

Вспомогательные инструкции в коде 1С 105

Статья Программист Нет файла v8 1cv8.cf Бесплатно (free) Практика программирования

Помогаем редактору кода 1С помогать нам писать и анализировать код.

15.10.2018    21517    tormozit    100       

Произвольный код в фоновом режиме 165

Статья Программист Нет файла v8 1cv8.cf Бесплатно (free) Практика программирования

Задача: реализовать выполнение произвольного кода в фоновом режиме без изменения конфигурации, т.е. во внешней обработке.

03.09.2018    15729    nikita0832    42       

Основные понятия и механизмы оптимизации клиент-серверного взаимодействия в 1C 147

Статья Программист Нет файла v8 Россия Бесплатно (free) Математика и алгоритмы Практика программирования

У многих начинающих 1С программистов часто возникают вопросы про клиент-серверное взаимодействие в 1С и чтобы разобраться в непростых механизмах платформы, необходимо понять, что же такое контекст, для чего предназначены директивы компиляции, что представляют собой контекстные/внеконтекстные вызовы и как наиболее оптимально описывать прикладные задачи в модулях управляемых форм.

23.08.2018    22878    Rain88    42       

Повышаем эффективность разработки правил обмена 124

Статья Программист Нет файла v8 КД ОС Бесплатно (free) Практика программирования Перенос данных из 1C8 в 1C8

Как повысить скорость и качество разработки правил обмена? Как вести групповую разработку правил обмена? Как облегчить сопровождение правил обмена после передачи в эксплуатацию? Об этом и многом другом вы можете узнать из этой статьи.

25.06.2018    20212    olegtymko    47       

Введение в механизм представлений в ЗУП ред. 3 156

Статья Программист Нет файла v8 v8::СПР ЗУП3.x Бесплатно (free) Практика программирования

В нашей организации на первом же телефонном собеседовании на должность разработчика по ЗУП ред. 3 вас обязательно спросят о том, что такое "Представления".

04.06.2018    25597    xrrg    82       

Как сделать запрос на изменение данных 75

Статья Программист Нет файла v8 v8::Запросы 1cv8.cf Бесплатно (free) Практика программирования

В статье приведены особенности внутренней архитектуры и примеры работы с расширением языка запросов 1С.

01.06.2018    22133    m-rv    21       

Строим графы средствами 1С (без GraphViz) 43

Статья Программист Нет файла v8 Бесплатно (free) Практика программирования

Множество статей на Инфостарте описывают, как работать с компонентой GraphViz, чтобы построить ориентированный граф. Но практически нет материалов, как работать с такими графами средствами 1С. Сегодня я расскажу, как красиво строить графы с минимальным пересечением. Нам этот метод пригодился для отрисовки алгоритмов в БИТ.Финансе, т.к. типовой механизм не устраивал. Еще это может быть полезно для визуализации различных зависимостей: расчета себестоимости, графы аффилированности компаний и т.д. Надеюсь, эта статья поможет сделать мир 1С красивее и гармоничней:) Итак, поехали...

23.05.2018    17920    slozhenikin_com    19       

Распределение расходов пропорционально продажам 9

Статья Программист Пользователь Нет файла v8 v8::ОУ УТ10 УУ Финансовый учет и бюджетирование (FRP) Учет доходов и расходов Бесплатно (free) Практика программирования

Финансовая модель. Распределение административных расходов по подразделениям пропорционально продажам за месяц. Дополнительные реквизиты против бизнес-процессов!

13.05.2018    12031    Rustig    9       

Просмотр временных таблиц запроса в отладчике без изменения кода 129

Статья Программист Нет файла v8 v8::Запросы 1cv8.cf Бесплатно (free) Практика программирования

Данный способ можно использовать для просмотра содержимого временных таблиц запросов (менеджеров временных таблиц) без внесения изменений в код.

24.04.2018    26501    avfed@rambler.ru    19       

Минимализмы 3 355

Статья Программист Нет файла v8 Бесплатно (free) Практика программирования Универсальные функции

Очередная серия "минимализмов" [http://infostart.ru/public/306536/, https://infostart.ru/public/460935/]. Также, как и в предыдущих статьях, здесь приведена подборка коротких оригинальных авторских решений некоторых задач. Ранее эти решения были разбросаны по моим комментариям к чужим публикациям.

19.02.2018    37106    ildarovich    44       

Этюды по программированию. Взаимодействие с Microsoft Word 109

Статья Программист Нет файла v8 Бесплатно (free) Практика программирования

Часто приходится заниматься созданием сложных документов Word с таблицами, вложенными фрагментами, хитрым оформлением и прочими радостями жизни. Это - попытка как-то структурировать полученный опыт, чтобы не приходилось перерывать ворох старых обработок в поисках крупиц истины. Надеюсь, эта статья будет полезна и Вам.

11.12.2017    26544    milkers    23       

Метод формирования движений в типовых регистрах нетиповыми регистраторами 31

Статья Программист Нет файла v8 1cv8.cf Бесплатно (free) Практика программирования

Вариант решения задач с проведением по типовым регистрам нетиповыми регистраторами. Зачем - чтобы при сравнении конфигурации не обращать внимание на свойства регистров и исключить вероятность допущения горькой оплошности при обновлении информационных баз, заменив типы регистраторов основной конфигурации типами конфигурации поставщика. Для программных продуктов, имеющих в своем составе метаданных документ "Корректировка регистров"("Корректировка записей регистров").

05.12.2017    21971    itriot11    34       

1С: Конвертация данных 3. Инструкции и примеры. EnterpriseData (универсальный формат обмена) 737

Статья Программист Нет файла v8 КД Бесплатно (free) Перенос данных из 1C8 в 1C8 Практика программирования Обмен через XML

Что такое КД3? Как начать использовать? Полезные дополнения к документации. Что нужно исправить в типовых обработках и конфигурации. Как изменить правила обмена не снимая конфигурацию с поддержки. Как отлаживать правила обмена?

19.11.2017    142793    MaxS    251       

Заполнение данных по ИНН контрагента с помощью альтернативного сервиса огрн.онлайн 131

Статья Программист Нет файла v8 Бесплатно (free) Практика программирования

Код для заполнения данных по ИНН контрагента из ЕГРЮЛ с сайта огрн.онлайн.

01.11.2017    23704    slava_1c    49       

Программные перечисления, ч.2: приемы кэширования при разработке 67

Статья Программист Нет файла v8 Бесплатно (free) Практика программирования

Все знают, что такое кэш, и зачем он нужен. Но в 1С разработчик обычно использует кэширование только на уровне конфигурации, а в какой-нибудь обработке скорее ломает голову над запросом - как получить все данные за один заход... Хочется рассказать о том, как можно добиться хороших результатов с стратегией "разделяй и властвуй".

30.10.2017    22026    unichkin    18       

Разбираемся с настройками компоновки данных 161

Статья Программист Нет файла v8 v8::СКД 1cv8.cf Бесплатно (free) Практика программирования

Краткая шпаргалка по программной работе с настройками СКД

29.10.2017    25103    json    9       

Работа с Excel 298

Статья Программист Нет файла v8 Бесплатно (free) Практика программирования Загрузка и выгрузка в Excel

Собрал различные полезности для работы с Excel из 1С. Иногда приходится форматировать документ Excel программно из 1С. Так вот, чтобы не искать постоянно на просторах интернета как сделать левое выравнивание в ячейке Excel из 1С и т.п. решил опубликовать это...

23.10.2017    27102    arakelyan    39       

Управление доступом: роли, права, профили, группы доступа, функциональные опции, RLS 232

Статья Системный администратор Программист Нет файла v8::Права Бесплатно (free) Роли и права

В 1С достаточно много механизмов, отвечающих за доступ к данным. Группы доступа, профили групп доступа, роли, права доступа, функциональные опции, RLS. Иногда сложно сразу понять, зачем все это нужно, как эти элементы друг с другом связаны и как ими пользоваться.

11.10.2017    68244    ekaruk    14