1с ут дополнительные реквизиты номенклатуры в запросе

Помогите с запросом… Доп реквизиты Номенклатуры

Я
   m1_1976

29.06.21 — 13:11

Всем добрый день.

Подскажите в тупике.

1С Розница.

Справочник Номенклатура.

У номенклатуры 8 доп реквизитов. (Важно что их конечное число).

Хочу найти запросом все товары у которых 7 известных мне конкретных реквизитов совпадают. (допустим мне известен один товар — из него эти 7 доп.реквизитов беру).

Все доп.реквизиты  обязательны к заполнению…

  

Партнерская программа EFSOL Oblako

   m1_1976

1 — 29.06.21 — 13:14

Верно понимаю что должно быть 7 уровней вложенных запросов.

Первым нахожу все товары у которых совпадает Доп.свойство 1

Второым нахожу все товары среди результатов 1 запроса у которых совпадает Доп.свойство 2

и т.д.

????

   m1_1976

2 — 29.06.21 — 13:14

Че-то мне кажется какой-то огород горожу…

   RomanYS

3 — 29.06.21 — 13:17

соединить по равенству свойств, а потом сгруппировать по ссылке. <!>Имеющие<!> 7 совпадений — искомые элементы

   H A D G E H O G s

4 — 29.06.21 — 13:18

«ВЫБРАТЬ

|    НоменклатураДополнительныеРеквизиты.Ссылка КАК Ссылка,

|    МАКСИМУМ(ВЫБОР

|            КОГДА НоменклатураДополнительныеРеквизиты.Свойство = &Реквизит1

|                ТОГДА НоменклатураДополнительныеРеквизиты.Значение

|        КОНЕЦ) КАК Реквизит1,

|    МАКСИМУМ(ВЫБОР

|            КОГДА НоменклатураДополнительныеРеквизиты.Свойство = &Реквизит2

|                ТОГДА НоменклатураДополнительныеРеквизиты.Значение

|        КОНЕЦ) КАК Реквизит2

|ПОМЕСТИТЬ Реквизиты

|ИЗ

|    Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты

|

|СГРУППИРОВАТЬ ПО

|    НоменклатураДополнительныеРеквизиты.Ссылка

|;

|

|////////////////////////////////////////////////////////////////////////////////

|ВЫБРАТЬ РАЗЛИЧНЫЕ

|    Реквизиты.Ссылка КАК Ссылка

|ИЗ

|    Реквизиты КАК Реквизиты

|        ВНУТРЕННЕЕ СОЕДИНЕНИЕ Реквизиты КАК Реквизиты1

|        ПО Реквизиты.Реквизит1 = Реквизиты1.Реквизит1

|            И Реквизиты.Реквизит2 = Реквизиты1.Реквизит2″

   m1_1976

5 — 29.06.21 — 13:18

так решил…

ВЫБРАТЬ

    ВложенныйЗапрос.Ссылка КАК Ссылка,

    СУММА(ВложенныйЗапрос.Поле1) КАК Поле1

ИЗ

    (ВЫБРАТЬ

        НоменклатураДополнительныеРеквизиты.Ссылка КАК Ссылка,

        1 КАК Поле1

    ИЗ

        Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты

    ГДЕ

        НоменклатураДополнительныеРеквизиты.Значение = &ЗначениеТовар

    
    ОБЪЕДИНИТЬ ВСЕ

    
    ВЫБРАТЬ

        НоменклатураДополнительныеРеквизиты.Ссылка,

        1

    ИЗ

        Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты

    ГДЕ

        НоменклатураДополнительныеРеквизиты.Значение = &ЗначениеБренд

    
    ОБЪЕДИНИТЬ ВСЕ

    
    ВЫБРАТЬ

        НоменклатураДополнительныеРеквизиты.Ссылка,

        1

    ИЗ

        Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты

    ГДЕ

        НоменклатураДополнительныеРеквизиты.Значение = &ЗначениеБренд

    
    ОБЪЕДИНИТЬ ВСЕ

    
    ВЫБРАТЬ

        НоменклатураДополнительныеРеквизиты.Ссылка,

        1

    ИЗ

        Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты

    ГДЕ

        НоменклатураДополнительныеРеквизиты.Значение = &ЗначениеСостав

    
    ОБЪЕДИНИТЬ ВСЕ

    
    ВЫБРАТЬ

        НоменклатураДополнительныеРеквизиты.Ссылка,

        1

    ИЗ

        Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты

    ГДЕ

        НоменклатураДополнительныеРеквизиты.Значение = &ЗначениеЦвет

    
    ОБЪЕДИНИТЬ ВСЕ

    
    ВЫБРАТЬ

        НоменклатураДополнительныеРеквизиты.Ссылка,

        1

    ИЗ

        Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты

    ГДЕ

        НоменклатураДополнительныеРеквизиты.Значение = &ЗначениеСостав

    
    ОБЪЕДИНИТЬ ВСЕ

    
    ВЫБРАТЬ

        НоменклатураДополнительныеРеквизиты.Ссылка,

        1

    ИЗ

        Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты

    ГДЕ

        НоменклатураДополнительныеРеквизиты.Значение = &ЗначениеАртикул) КАК ВложенныйЗапрос

СГРУППИРОВАТЬ ПО

    ВложенныйЗапрос.Ссылка

УПОРЯДОЧИТЬ ПО

    Поле1 УБЫВ

   m1_1976

6 — 29.06.21 — 13:19

Добавил доп поле = 1 в каждом.

Потом выбираю только те у которых Поле1 = 8

   RomanYS

7 — 29.06.21 — 13:26

(4) с одной стороны прикольно, с другой стороны: почему тогда не просто 2 (или N) левых соединения? Вроде методически более верно и не сильно более громоздко

   apdate by

8 — 29.06.21 — 13:42

а так не правильно? (я плохо знаю запросы знаю mysql Но и там задумался (

Запрос = Новый Запрос;

    Запрос.Текст =

        «ВЫБРАТЬ

        |    Номенклатура.Ссылка

        |ИЗ

        |    Справочник.Номенклатура КАК Номенклатура

        |ГДЕ

        |    Номенклатура.Артикул = Номенклатура.Артикул

        |    И Номенклатура.АлкогольнаяПродукция = Номенклатура.АлкогольнаяПродукция

        |    И Номенклатура.Наименование = Номенклатура.Наименование»;

   apdate by

9 — 29.06.21 — 13:47

+(8) у меня сработало

Запрос = Новый Запрос;

    Запрос.Текст =

        «ВЫБРАТЬ

        |    Тест.Ссылка КАК Ссылка,

        |    Тест.ВерсияДанных КАК ВерсияДанных,

        |    Тест.ПометкаУдаления КАК ПометкаУдаления,

        |    Тест.Код КАК Код,

        |    Тест.Наименование КАК Наименование,

        |    Тест.А КАК А,

        |    Тест.Б КАК Б,

        |    Тест.С КАК С,

        |    Тест.Д КАК Д,

        |    Тест.Предопределенный КАК Предопределенный,

        |    Тест.ИмяПредопределенныхДанных КАК ИмяПредопределенныхДанных

        |ИЗ

        |    Справочник.Тест КАК Тест

        |ГДЕ

        |    Тест.А = Тест.А

        |    И Тест.Б = Тест.А

        |    И Тест.С = Тест.А

        |    И Тест.Д = Тест.А»;

    
    РезультатЗапроса = Запрос.Выполнить();

    
    ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать();

    
    Пока ВыборкаДетальныеЗаписи.Следующий() Цикл

        а = «»;

    КонецЦикла;

   RomanYS

10 — 29.06.21 — 13:48

(8) у тебя все условия заведомо Истина (для не групп)

   apdate by

11 — 29.06.21 — 13:48

+(9) выдало все элементы у которых в реквизитах

А, Б, С, Д одинаковые значения

   apdate by

12 — 29.06.21 — 13:51

(10) а что у меня не верно? то?

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

   Classic

13 — 29.06.21 — 13:53

ВЫБРАТЬ

     СравниваемаяНоменклатура.Ссылка КАК Номенклатура

ПОМЕСТИТЬ НесовпадающиеНоменклатуры    

ИЗ Справочник.Номенклатура.ДополнительныеРеквизиты КАК ОсновнаяНоменклатура

    ВНУТРЕННЕЕ СОЕДИНЕНИЕ Справочник.Номенклатура КАК СравниваемаяНоменклатура

    ПО ОсновнаяНоменклатура.Ссылка <> СравниваемаяНоменклатура.Ссылка

    ЛЕВОЕ СОЕДИНЕНИЕ Справочник.Номенклатура.ДополнительныеРеквизиты КАК ДанныеСравниваемойНоменклатуры

    ПО СравниваемаяНоменклатура.Ссылка = ДанныеСравниваемойНоменклатуры.Ссылка

       И ОсновнаяНоменклатура.Свойство = ДанныеСравниваемойНоменклатуры.Свойство

       И ОсновнаяНоменклатура.Значение = ДанныеСравниваемойНоменклатуры.Значение

ГДЕ

   ОсновнаяНоменклатура.Ссылка = &НашаНоменклатура

   И ДанныеСравниваемойНоменклатуры.Ссылка ЕСТЬ NULL

;

ВЫБРАТЬ

   СпрНоменклатура.Ссылка

ИЗ Справочник.Номенклатура КАК СпрНоменклатура

   ЛЕВОЕ СОЕДИНЕНИЕ НесовпадающиеНоменклатуры  КАК НесовпадающиеНоменклатуры

   ПО СпрНоменклатура.Ссылка = НесовпадающиеНоменклатуры.Номенклатура

ГДЕ

  НесовпадающиеНоменклатуры.Номенклатура ЕСТЬ NULL

   Classic

14 — 29.06.21 — 13:53

(13)

Как-то так. Идея я думаю ясна

   lodger

15 — 29.06.21 — 13:54

(5)

а если так?

ВЫБРАТЬ

        НоменклатураДополнительныеРеквизиты.Ссылка КАК Ссылка,

        СУММА(1) КАК Поле1

    ИЗ

        Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты

    ГДЕ

        НоменклатураДополнительныеРеквизиты.Значение В (&СписокЗначений)

СГРУППИРОВАТЬ ПО

    НоменклатураДополнительныеРеквизиты.Ссылка

ИМЕЮЩИЕ СУММА(1) = 8

   RomanYS

16 — 29.06.21 — 13:54

(12) У ТСа совсем другая задача

   apdate by

17 — 29.06.21 — 13:55

(16) да я видимо не понял задачу :-(

   RomanYS

18 — 29.06.21 — 14:06

(13) возможно сработает.

Только есть нюансы:

1. прикладной: у ТСа свойств всего 8, а совпадать должно 7

2. более принципиальный: что будет если у элемента не будет допреквизита? Есть подозрение, что он попадёт в выборку

   m1_1976

19 — 29.06.21 — 14:09

(18) 2) Будет. Заполнение доп.реквизита обязательно!

Сделал по своему…

Только долго работает запрос…

   Classic

20 — 29.06.21 — 14:14

(18)

Как задача стоит?

Любые 7? Тогда да, мой подход неправильный. Но тогда (6) вообще непонятно к чему

Конкретные 7? Ставим отбор в первой таблице на свойство

У номенклатуры всего 7 из 8? Тогда все правильно.

Я думаю, что задача стоит получить все номенклатуры с такими же свойствами, как и у заданной. Такая задача логична. Единственный вопрос. Если у заданной будет 4 свойства, а у какой-то 5, эта какая-то должна в выборку попадать?

   RomanYS

21 — 29.06.21 — 14:16

(19) Заполнение доп.реквизита обязательно!

Ага и у групп и услуг?

(20) Если у номенклатуры не будет ни одной записи ДР (например у групп) — она попадёт в твою выборку?

   Classic

22 — 29.06.21 — 14:17

(21)

Нет, она попадет в первую таблицу

   RomanYS

23 — 29.06.21 — 14:24

(22) ОК.

И даже 8 раз)) Имеет смысл «различные» добавить, а может и не повлияет ни на что.

   Classic

24 — 29.06.21 — 14:27

(23)

Не повлияет. Во втором запросе проверка на нулл. Туда только те, что не в первой таблице.

Можно поставить конечно. Можно и на один запрос переписать, только тогда следующий программист вообще не поймет как это работает :)

   m1_1976

25 — 29.06.21 — 14:37

(21) А причем тут Группы?

У них нет ТЧ «ДополнительныеРеквизиты».

Да и групп у меня нет и не будем в этой базе.. Все живет в доп.реквзитах замечтаельно. Еще и по группам их раскладывать??? :)

(20) У доп.свойства в рознице есть признак обязательности заполнения. У меня все заполнены. 100%

Спасибо всем за помощь.

Процентов на 60% помогли.  Самое важно — натолкнули на мысль! За это СПАСИБО!

   Classic

26 — 29.06.21 — 14:45

(25)

Покажи, что налабал. А то терзают смутные сомнения

   m1_1976

27 — 29.06.21 — 14:56

см (5)

через задницу… но

   Classic

28 — 29.06.21 — 15:10

(27)

Это очень мягко сказано.

В общем случае, если типы свойств будут разные, то твой запрос будет выдавать непонятные значения

   m1_1976

29 — 29.06.21 — 15:18

(28) Типы свойств всегда справочник «Дополнительные свойства».

Одно плохо = долго работает.

Несколько секунд (5-7) запрос выполняется.

потом переделаю…

   Classic

30 — 29.06.21 — 15:41

(29)

Смотри, например у тебя есть свойства (условно) «длина» и «ширина»

У твоей номенклатуры длина 10, ширина 5

У другой номенклатуры ширина 10, длина 5

Что выдаст твой запрос?

   m1_1976

31 — 29.06.21 — 16:22

(30) С ума сойти…  Меня пытаетесь запутать? Зачем? Пишите правильно:

Ш10 Д5

Ш5 Д10

Прчием тут мой запрос. У меня в запросе строго будет

(ШИРИНА = &ВыбШИРИНА)

(ДЛИНА = &ВыбДлина)

И не важно в каком порядоке Вы их в своем вопросе написали :))))))

У меня строго 8 доп.реквизитов

У меня есть товар, в котором у меня все известно (БРЕНД,СОСТАВ,ТИПТОВАРА,ЦВЕТ, МОДЕЛЬ и т.д)

Восьмое свойство РАЗМЕР.

Я своим запросом зная, эти 7 доп.реквизитов (из одного товара) — нахожу все такие же товары всех размеров!

Задачу я решил.

   Eiffil123

32 — 29.06.21 — 16:36

наиболее логично сделать 7 внутренних соединений с основой таблицей номенклатур и далее на закладке отборов наложить фильтр на эти реквизиты

   acanta

33 — 29.06.21 — 16:37

А если это не доп.реквизиты, а части одного реквизита, подстроки?

   Жан Пердежон

34 — 29.06.21 — 16:59

(30) там разные ссылки будут, так как (29)

(5) для общего случая — в каждый подзапрос отбор по свойству добавить (если не только доп.свойства),

если только допсвойства, то и (15) должно работать

и зачем у тебя сортировка вместо  ИМЕЮЩИЕ СУММА(Поле1) = 7?

   Classic

35 — 29.06.21 — 17:09

(31)

У тебя в (5) ничего такого не написано.

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

   Garykom

36 — 29.06.21 — 17:12

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

   m1_1976

37 — 29.06.21 — 17:21

(34) Сортировка это пережиток КонсолиЗапросов (отладка) — так вывел себе наверх в результате наиболее часто встречающиеся. Попробовал на десятке разных наборов. Понял что работает… и переделал на ИМЕЮЩИЕ.

Тут поспешил…

   m1_1976

38 — 29.06.21 — 17:22

(35) Так не может быть! так как (29)

  

m1_1976

39 — 29.06.21 — 17:23

Еще раз спасибо.

тему можно закрыть.

Опубликовано в Статьи по 1С 27.10.2018

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

Отличие дополнительного реквизита от дополнительного сведения в том, что

  • Дополнительные реквизиты – список реквизитов, доступных в форме документа или справочника; причем эти реквизиты хранятся в табличной части объекта, к которому они добавлены;
  • Дополнительные сведения – список значений доступных по дополнительной кнопке; причем доп. сведения  хранятся в  отдельном регистре.

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

Как получить 1С дополнительные реквизиты и сведения программно:

Для получения дополнительных данных используем запрос, в котором получим значение дополнительных реквизитов и сведений:

////
Запрос = Новый Запрос;
Запрос.Текст =
«ВЫБРАТЬ РАЗРЕШЕННЫЕ
| ДополнительныеСведения.Свойство,
| ДополнительныеСведения.Значение
|ИЗ
| РегистрСведений.ДополнительныеСведения КАК ДополнительныеСведения
|ГДЕ
| ДополнительныеСведения.Объект = &Объект»;
Запрос.УстановитьПараметр(«Объект», СсылкаДокумент);
////

Для получения дополнительного реквизита использую код вида:

////
Запрос = Новый Запрос;
Запрос.Текст =
«ВЫБРАТЬ
| НоменклатураДополнительныеРеквизиты.Свойство,
| НоменклатураДополнительныеРеквизиты.Значение
|ИЗ
| Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты
|ГДЕ
| НоменклатураДополнительныеРеквизиты.Свойство = &Свойство
| И НоменклатураДополнительныеРеквизиты.Ссылка = &Ссылка»;
Запрос.УстановитьПараметр(«Ссылка», СсылкаДокумент);
Запрос.УстановитьПараметр(«Свойство», ПланыВидовХарактеристик.ДополнительныеРеквизитыИСведения.НайтиПоНаименованию(«Коэффициент бруто»));
////

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

Содержание:

1.       Настройки 1С УТ 11

2.       Как добавить новый реквизит в 1С

3.       Реквизиты 1С УТ с общим списком

4.       Общие реквизиты в 1С

5.       Отображение реквизитов в отчетах 1С и списках

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

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

Далее разберем примеры добавления и работы с дополнительными реквизитами в 1С УТ 11.

В первую очередь необходимо включить настройки. 

1.   Настройки 1С УТ 11

Первый флаг (см. скриншот) отвечает в целом за доступность ведения в базе 1С 8.3 УТ 11 дополнительных реквизитов.

Второй флаг отвечает за возможность ведения реквизитов с общим список значений. Данную настройку можно включить, например, если в справочник «Клиенты» необходимо добавить реквизит «Регион клиента», в справочник «Поставщики» – «Регион поставщика», при этом для обоих дополнительных реквизитов должен использоваться единый список значений – Федеральные округа РФ.

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

Настройки использования реквизитов в 1С 8.3 УТ 11 могут быть различными. Использовать ли общие наборы, общие списки и, если да, то как именно – зависит от потребностей пользователя и банального удобства работы. Примеры, которые будут описаны далее, приведены для общего понимания работы с возможностями конфигурации в части использования реквизитов.

Добавление новых реквизитов выполняется из справочника. Открыть его можно там же, где включается настройка использования доп. реквизитов.  

2.   Как добавить новый реквизит в 1С

Добавим новый реквизит в 1С, не связанный с другими реквизитами и посмотрим, какие данные можно указать в нем. Например, в справочник «Физические лица» добавим реквизит «Подразделение».

В левой части окна программы надо выбрать объект системы, к которому добавляется реквизит (в нашем случае это «Физические лица») и нажать кнопку «Добавить → Новый».

В открывшемся окне заполняем «Наименование» и «Тип значения».

Тип значения определяет тип используемых данных в новом реквзите 1С. Типы данных могут быть различными. Из можно распределить по группам:

·                    дата, строка, число – точные заполняемые значения;

·                    булево в 1С – значение «Да» или «Нет» (в форме представляет собой поле для установки флажка);

·                    дополнительное значение – используется для ввода списка нужных значений;

·                    Организация, Партнер, Статья доходов и т.д – используется для выбора значения из действующих справочников.

Здесь же можно использовать сразу несколько типов данных, установив флаг «Составной тип данных».

В нашем примере нам надо выбрать тип данных «Подразделения». Тогда в карточке физического лица будет доступны к выбору данные справочника «Структура педприятия».

После записи реквизита 1С, он отобразится в соответствующем справочнике, и в нем будет доступен указанный тип данных.

При необходимости для реквизита можно внести дополнительные настройки:

·                    если установить флаг «Выводить в виде гиперссылки», то после заполнения реквизита значение будет представлено в ввиде ссылки;

·                    возможно сделать настройку критериев видимости и доступности реквизита по форме в зависимости от выполнения условий;

·                    можно установить обязательность заполнения данного реквизита в целом или при выполнении каких-либо условий;

·                    для поля можно установить всплывающую подсказку о его назначении.

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

В этом случае у нас задействован один объект системы («Договоры с контрагентами») и два реквизита: «согласовано» (да/нет) и «дата согласования».

Создадим реквизиты.

Реквизит 1 – тип данных «булево в 1С».

Реквизит 2 – тип даннх «дата». Здесь также надо указать состав даты.

Сохраним реквизиты и проверим результат – в карточке договора должен появиться раздел с этими реквизитами.

Добавление нового реквизита и его заполнение рассмотрели. Перейдем к более сложному варианту.  

3.   Реквизиты 1С УТ с общим списком

Допустим, для покупателей надо добавить реквизит «Регион клиента», для поставщиков реквизит «Регион поставщика». Названия реквизитов разные, но список значений един – Федеральные округа РФ.

Удобство этого варианта заключается в том, что нет необходимости дважды заполнять перечень значений. При создании списка в одном реквизите он тотчас будет доступен и для второго, а при добавлении/редактировании/удалении данных в одном реквизите все изменения также отразятся в списке второго.

Добавим реквизит для клиентов. Создаем новый, указываем тип «Дополнительные значения» и вносим список значений. Заполнять его на этом этапе не обязательно. Позже список значений можно будет дополнить непосредственно из объекта системы. Но сейчас внесем его, чтобы наглядно увидеть отражение общего списка и во втором реквизите.

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

Нажимаем «Добавить → Из другого набора». В открывшемся окне находим и выделяем созданный ранее реквизит для клиента и нажимаем «Далее».

Выбираем вариант «Сделать копию реквизита по образцу (с общим списком значений)» и нажимаем «Далее».

В созданном реквизите уже определен тип данных и заполнен перечень значений. Остается только присвоить наименование.

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

4.   Общие реквизиты в 1С

Сделать реквизиты общими (единое название и единый список значений для нескольких объектов) можно следующим образом:

ввести реквизит для одного объекта;

добавить реквизит из набора первого объекта и сделать его общим.

Все добавленные реквизиты после их записи становятся доступными в соответствующих объектах системы.  

5.   Отображение реквизитов в отчетах 1С и списках

Для удобства работы реквизиты можно вывести в список объектов и добавить в настройки отчетов.

Например, выведем реквизит «Согласовано», описанный выше, в справочник.

Открываем меню «Еще → Изменить форму». В списке полей выделяем строку «Ссылка» и нажимаем кнопку «Добавить поле». В предложенном списке выбираем «Согласовано (Договоры с контрагентами)» и нажимаем «ОК».

В списке полей добавится выбранный реквизит. Перемещаем его вверх, меняем заголовок и нажимаем «ОК».

Колонка добавлена в список, теперь по ней можно осуществлять поиск.

Также для примера выведем дополнительный реквизит в отчет 1С «Задолженность клиентов» – категорию клиента.

Открываем «Настройки», выбираем вид «Расширенный» и добавляем новое поле. В окне выбора поля разворачиваем поле «Клиент», после чего разворачиваем список «Дополнительные реквизиты» и выбираем «Категория».

Поле добавлено в отчет. Также это поле можно включить в отборы или в общую структуру отчета.

Специалист компании ООО «Кодерлайн»

Косьяненко Зоя Владимировна

Примеры работы с дополнительными реквизитами.

Как получить значение дополнительного реквизита:

Пример: мы делаем печатную форму документа «Заказ клиента» и хотим вывести на неё значение определённого дополнительного реквизита — «Должность покупателя».

Используем вложенный запрос, в котором соединяем левым соединением таблицу «Дополнительные реквизиты» документа «Заказ клиента» с Планом видов характеристик «Дополнительные реквизиты и сведения». Устанавливаем условие: заголовок дополнительного реквизита должен быть таким – «Должность покупателя». Таблицы соединяем по ссылке на «Заказ клиента».

Получается вот такой запрос:

Также можно использовать метод НайтиПоНаименованию ( «***» ) .

Переменная Ссылка – это ссылка на «Договор контрагента».

Проверка на предмет того, что дополнительный реквизит заполнен:

Как изменить значения дополнительных реквизитов:

Задействуем общий модуль УправлениеСвойствами , который входит в состав БСП.

  • Дополнительные реквизиты и сведения
  • План видов характеристик
  • Программирование 1С
Комментарии

У вас ошибка в коде:
МассивСтруктур.Добавить(Новый Структура(«Свойство, Значение», ДопРеквизитДатаОтправки, ТекущаяДата());

Не хватает закрывающей скобки.

У вас ошибка в коде:
МассивСтруктур.Добавить(Новый Структура(«Свойство, Значение», ДопРеквизитДатаОтправки, ТекущаяДата());

Условие в запросе 1с как допреквизит

Рассматриваемая задача может быть актуальна, когда требуется соединить данные двух регистров, причем набор условий соединения не полностью идентифицирует строку регистра, т.е. в результате соединения по данному условию в выборке может быть несколько «одинаковых» строк.
Допустим, есть две таблицы:

Реквизит 1 Реквизит 2
а 1
а 2
б 34
в 10
в 15

Требуется присоединить Реквизит 2 к Таблице 1, не размножая при этом строки, взяв случайным образом (т.е. любое) значение Реквизита 2 по условию равенства Реквизитов 1 таблицы 1 и 2.

Если написать запрос с Левым соединением:

, то строки исходной таблицы «размножатся».

ВЫБРАТЬ РАЗЛИЧНЫЕ тут тоже не поможет, т.к. значения Реквизит 2 различные.

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

Чтобы решить эту задачу, можно использовать получение максимального значения «Реквизита 2». Метод подходит не только для числового значения этого реквизита, а и для любого другого. Но получим мы при этом, конечно не случайное значение из множества, а то, что система вычислит как макимальное. В большинстве случаев такое решение задачи полностью удовлетворит.

Вот запрос, решающий эту задачу:

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

Запоминаем Таблицу 2 в ее копии, затем Таблицу 2 сворачиваем по Реквизиту 1 и затем перебором строк свернутой таблицы 2 и ее копии выбираем Реквизит2:

Пишите, если найдете другой интересный метод решения. С удовольствием посмотрим.

1с запрос дополнительные реквизиты

Пример: мы делаем печатную форму документа «Заказ клиента» и хотим вывести на неё значение определённого дополнительного реквизита — «Должность покупателя».

Используем вложенный запрос, в котором соединяем левым соединением таблицу «Дополнительные реквизиты» документа «Заказ клиента» с Планом видов характеристик «Дополнительные реквизиты и сведения». Устанавливаем условие: заголовок дополнительного реквизита должен быть таким – «Должность покупателя». Таблицы соединяем по ссылке на «Заказ клиента».

Получается вот такой запрос:

Также можно использовать метод НайтиПоНаименованию ( «***» ) .

Переменная Ссылка – это ссылка на «Договор контрагента».

Проверка на предмет того, что дополнительный реквизит заполнен:

Как изменить значения дополнительных реквизитов:

Задействуем общий модуль УправлениеСвойствами , который входит в состав БСП.

Юзайте на здоровья!

3 thoughts on “Получить значение дополнительных реквизитов 1С 8”

Спасибо, очень помогло.

К сожалению, на строчке
Запрос.УстановитьПараметр(«Объект», Объект);
спотыкается и отказывается дальше работать

Как редактировать доп реквизиты:

редактировать их состав можно тут:

хранятся они тут:

где типы реквизитов:

получить их в запросе можно так:

НоменклатураДополнительныеРеквизиты.Ссылка КАК Ссылка,

НоменклатураДополнительныеРеквизиты.Ссылка.Код КАК Код,

НоменклатураДополнительныеРеквизиты.Свойство КАК Свойство,

НоменклатураДополнительныеРеквизиты.Значение КАК Значение

Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты

Разберем что откуда берется.

Дополнительные реквизиты заводятся в «ПланВидовХарактеристик.ДополнительныеРеквизитыИСведения» и там же указан тип значений допРеквизитов:

ДополнительныеРеквизитыИСведения.Ссылка КАК Ссылка,

ДополнительныеРеквизитыИСведения.ТипЗначения КАК ТипЗначения

ПланВидовХарактеристик.ДополнительныеРеквизитыИСведения КАК ДополнительныеРеквизитыИСведения

Для справки: Кроме ссыка и типЗначения в «ПланВидовХарактеристик.ДополнительныеРеквизитыИСведения» хранится куча свойств этих реквизитов

Если указан типЗначеня «ДополнительноеЗначение», то виды этих доп значений можем посмотреть тут:

ЗначенияСвойствОбъектов.Владелец КАК Владелец,

ЗначенияСвойствОбъектов.Ссылка КАК Ссылка,

ЗначенияСвойствОбъектов.Владелец.ТипЗначения КАК ВладелецТипЗначения

Справочник.ЗначенияСвойствОбъектов КАК ЗначенияСвойствОбъектов

а сами значения дополнительных реквизитов хранятся тут:

На чтение 2 мин. Просмотров 635 Опубликовано 15.12.2019

Примеры работы с дополнительными реквизитами.

Как получить значение дополнительного реквизита:

Пример: мы делаем печатную форму документа «Заказ клиента» и хотим вывести на неё значение определённого дополнительного реквизита — «Должность покупателя».

Используем вложенный запрос, в котором соединяем левым соединением таблицу «Дополнительные реквизиты» документа «Заказ клиента» с Планом видов характеристик «Дополнительные реквизиты и сведения». Устанавливаем условие: заголовок дополнительного реквизита должен быть таким – «Должность покупателя». Таблицы соединяем по ссылке на «Заказ клиента».

Получается вот такой запрос:

Также можно использовать метод НайтиПоНаименованию ( «***» ) .

Переменная Ссылка – это ссылка на «Договор контрагента».

Проверка на предмет того, что дополнительный реквизит заполнен:

Как изменить значения дополнительных реквизитов:

Задействуем общий модуль УправлениеСвойствами , который входит в состав БСП.

Юзайте на здоровья!

3 thoughts on “Получить значение дополнительных реквизитов 1С 8”

Спасибо, очень помогло.

К сожалению, на строчке
Запрос.УстановитьПараметр(«Объект», Объект);
спотыкается и отказывается дальше работать

Как редактировать доп реквизиты:

редактировать их состав можно тут:

хранятся они тут:

где типы реквизитов:

получить их в запросе можно так:

НоменклатураДополнительныеРеквизиты.Ссылка КАК Ссылка,

НоменклатураДополнительныеРеквизиты.Ссылка.Код КАК Код,

НоменклатураДополнительныеРеквизиты.Свойство КАК Свойство,

НоменклатураДополнительныеРеквизиты.Значение КАК Значение

Справочник.Номенклатура.ДополнительныеРеквизиты КАК НоменклатураДополнительныеРеквизиты

Разберем что откуда берется.

Дополнительные реквизиты заводятся в «ПланВидовХарактеристик.ДополнительныеРеквизитыИСведения» и там же указан тип значений допРеквизитов:

ДополнительныеРеквизитыИСведения.Ссылка КАК Ссылка,

ДополнительныеРеквизитыИСведения.ТипЗначения КАК ТипЗначения

ПланВидовХарактеристик.ДополнительныеРеквизитыИСведения КАК ДополнительныеРеквизитыИСведения

Для справки: Кроме ссыка и типЗначения в «ПланВидовХарактеристик.ДополнительныеРеквизитыИСведения» хранится куча свойств этих реквизитов

Если указан типЗначеня «ДополнительноеЗначение», то виды этих доп значений можем посмотреть тут:

ЗначенияСвойствОбъектов.Владелец КАК Владелец,

ЗначенияСвойствОбъектов.Ссылка КАК Ссылка,

ЗначенияСвойствОбъектов.Владелец.ТипЗначения КАК ВладелецТипЗначения

Справочник.ЗначенияСвойствОбъектов КАК ЗначенияСвойствОбъектов

а сами значения дополнительных реквизитов хранятся тут:

Google+

  • © 2019 Услуги 1С программиста. Доработка и обслуживание 1С. Удаленное программирование по всей России. Платформы 7.7 8.2 8.3 , битрикс.
  • 2 / 2 / 0

    Регистрация: 21.11.2011

    Сообщений: 57

    1

    Создание запроса на доп. реквизиты

    19.07.2012, 12:03. Показов 11039. Ответов 5


    Добрый день!
    Подскажите пожалуйста, как решить данную проблему:

    Создал небольшой запрос. Который выводит необходимую информацию по документам и дополнительные реквизиты данного документа. Беда заключается в том, что если дополнительных реквизитов по документу несколько, то он дублирует этот документ на следующие строки. А мне бы хотелось, чтобы эти доп. реквизиты выводились в одну строку. Подозреваю, что нужно воспользоваться группировкой и создать несколько реквизитов, которые бы присваивали к себе значения свойств при переборе, но не имею представления как их создать. Может есть образцы, или кто-нить подскажет как решить данную проблему? Вот код запроса:

    1C
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    
    ВЫБРАТЬ
        РеализацияТоваровУслуг.Ссылка,
        РеализацияТоваровУслуг.Дата,
        РеализацияТоваровУслуг.Контрагент,
        ЗначенияСвойствОбъектов.Свойство,
        ЗначенияСвойствОбъектов.Значение
    ИЗ
        Документ.РеализацияТоваровУслуг КАК РеализацияТоваровУслуг
            ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.ЗначенияСвойствОбъектов КАК ЗначенияСвойствОбъектов
            ПО РеализацияТоваровУслуг.Ссылка = ЗначенияСвойствОбъектов.Объект

    Платформа: 8.2.15.318
    Конфигурация: Бухгалтерия
    Заранее благодарен!

    Добавлено через 20 часов 23 минуты
    Смог чуток разобраться, удалось в запросе создать два поля с условиями отбора, но не удалось сгрупировать полученные данные в одну строку, подскажите плз

    Вот код:

    1C
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    
    ВЫБРАТЬ
        РеализацияТоваровУслуг.Ссылка КАК Ссылка,
        ЗначенияСвойствОбъектов.Значение,
        ВЫБОР
            КОГДА ЗначенияСвойствОбъектов.Свойство.Наименование = "Сдан акт"
                ТОГДА ЕСТЬNULL(ЗначенияСвойствОбъектов.Значение, "нет")
        КОНЕЦ КАК АктСдан,
        ВЫБОР
            КОГДА ЗначенияСвойствОбъектов.Свойство.Наименование = "Сдан лурв"
                ТОГДА ЕСТЬNULL(ЗначенияСвойствОбъектов.Значение, "нет")
        КОНЕЦ КАК ЛурвСдан,
        ЗначенияСвойствОбъектов.Свойство.Наименование
    ИЗ
        Документ.РеализацияТоваровУслуг КАК РеализацияТоваровУслуг
            ВНУТРЕННЕЕ СОЕДИНЕНИЕ РегистрСведений.ЗначенияСвойствОбъектов КАК ЗначенияСвойствОбъектов
            ПО РеализацияТоваровУслуг.Ссылка = ЗначенияСвойствОбъектов.Объект
    ГДЕ
        РеализацияТоваровУслуг.Ссылка = &Документ
     
    СГРУППИРОВАТЬ ПО
        РеализацияТоваровУслуг.Ссылка,
        ЗначенияСвойствОбъектов.Значение,
        ЗначенияСвойствОбъектов.Свойство.Наименование



    0



    Понравилась статья? Поделить с друзьями:

    Другие крутые статьи на нашем сайте:

    0 0 голоса
    Рейтинг статьи
    Подписаться
    Уведомить о
    guest

    0 комментариев
    Старые
    Новые Популярные
    Межтекстовые Отзывы
    Посмотреть все комментарии