helpf.pro
Регистрация
 +1 
Распечатать

1С 8.2 УП : Запрос к Таблице Значений

Код 1C v 8.х
 Таблица = Новый ТаблицаЗначений;
//Опишем тип создаваемой колонки
Массив = Новый Массив;
КЧ = Новый КвалификаторыЧисла(10, 2);
Массив.Добавить(Тип("Число"));
ОписаниеТиповЧ = Новый ОписаниеТипов(Массив, , ,КЧ);
Таблица.Колонки.Добавить("КодУслуги",ОписаниеТиповЧ);

//... выборки из справочника и заполнение ТЗ
Пока ВыборкаСпр.Следующий() Цикл
НоваяСтрока = Таблица.Добавить();
НоваяСтрока.КодУслуги = ВыборкаСпр.Код;
КонецЦикла;

Запрос = Новый Запрос;
МенеджерВТ = Новый МенеджерВременныхТаблиц;
Запрос.МенеджерВременныхТаблиц = МенеджерВТ;
// Текст запроса для построения временной таблицы
Запрос.Текст = "ВЫБРАТЬ
| Таб.КодУслуги КАК Код
|ПОМЕСТИТЬ ВТДанные
|ИЗ
| &Данные КАК Таб";
Запрос.УстановитьПараметр("Данные",Таблица);
Результат = Запрос.Выполнить();


Пример Заполнения колонки одной таблицы по колонке другой, по типу ЛЕВОЕ СОЕДИНЕНИЕ
Это удобно когда например надо заполнить колонку не одним фиксированным значением, а в зависимости от значений в других колонках
Код 1C v 8.х
 
ТЗН1 = Новый ТаблицаЗначений;//Колонки Кол1,кол2,кол3,ИД
ТЗН2 = Новый ТаблицаЗначений;//Колонки Кол4,кол5,кол6,ИД

Запрос.УстановитьПараметр("ТЗН1",Отправления);
Запрос.УстановитьПараметр("ТЗН2",ЛотыКСписанию);
МВТ = Новый МенеджерВременныхТаблиц;
Запрос.МенеджерВременныхТаблиц = МВТ;
//Запрос 1 Помещаем ТЗН1 в МенеджерВременныхТаблиц в таблицу ТЗН1

Запрос.Текст =
"ВЫБРАТЬ
| ТЗН1.Кол1 КАК Кол1,
| ТЗН1.Кол2 КАК Кол2,
| ТЗН1.Кол3 КАК Кол3,
| ТЗН1.ИД КАК ИД
|ПОМЕСТИТЬ
| ТЗН1
|ИЗ
| &ТЗН1 КАК ТЗН1";
Запрос.Выполнить();
//Запрос 2 Помещаем ТЗН2 в МенеджерВременныхТаблиц в таблицу ТЗН2

Запрос.Текст =
"ВЫБРАТЬ
| ТЗН2.Кол1 КАК Кол4,
| ТЗН2.Кол2 КАК Кол5,
| ТЗН2.Кол3 КАК Кол6,
| ТЗН2.ИД КАК ИД
|ПОМЕСТИТЬ
| ТЗН2
|ИЗ
| &ТЗН2 КАК ТЗН2";
//Получаем результирующую таблицу

Запрос.Выполнить();
Запрос.Текст =
"ВЫБРАТЬ
| ТЗН1.Кол1 КАК Кол1,
| ТЗН1.Кол2 КАК Кол2,
| ТЗН1.Кол3 КАК Кол3,
| ТЗН1.ИД КАК ИД,
| ТЗН2.Кол1 КАК Кол4,
| ТЗН2.Кол2 КАК Кол5,
| ТЗН2.Кол3 КАК Кол6,
|ИЗ
| ТЗН1 КАК ТЗН1
| ВНУТРЕННЕЕ СОЕДИНЕНИЕ ТЗН2 КАК ТЗН2
| ПО ТЗН1.ИД = ТЗН2.ИД";
тзн3 = Запрос.Выполнить().Выгрузить();


Запрос к таблице делается в 2 этапа:
Сначала она запросом помещается в МенеджерВременныхТаблиц, а затем вторым запросом к ней делается запрос!

В 8.0 к ТЗ можно работать только построителем запроса!
Примерно так:
Код 1C v 8.х
 ПостроительЗапроса = Новый ПостроительЗапроса;
ПостроительЗапроса.ИсточникДанных = Новый ОписаниеИсточникаДанных(ТЗ);

СтрокаОтбора = ПостроительЗапроса.Отбор.Добавить("Реквизит");
СтрокаОтбора.Значение = Истина;
СтрокаОтбора.ВидСравнения = ВидСравнения.Равно;
СтрокаОтбора.Использование = Истина;

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



Как в запросе, в качестве источника данных, использовать таблицу значений?
Разместил:   Версии: | 8.x | 8.2 УП |  Дата:   Прочитано: 142100
 +1 
Распечатать
Возможно, вас также заинтересует
Как заполнить табличную часть формы программно? 8
Нужно по кнопке Заполнить - сформировать данные для заполнения табличных частей и заполнить их. Форма имеет вид: Рядом с кнопкой Записать и закрыть добавлена кнопка Заполнить документ , код ее команды: // Код заполнения ТЧ НаСервере П
17 правил для составления оптимального ЗАПРОСа к данным базы 1С 50
Для формирования и выполнения запросов к таблицам базы данных в платформе 1С используется специальный объект языка программирования Запрос . Создается этот объект вызовом конструкции Новый Запрос . Запрос удобно использовать, когда требуется получ
1C и Google Maps 21
была поставлена задача отображения на географической карте медицинских учреждений. После обзора предлагаемых решений был выбран сервис google. Но так же подобного рода подход будет работать и с картами сервиса yandex. Во время решения задачи было реш
COM-подключение к базе 7.7 из 8.2 1С 7
Если код выполняется на стороне клиента, то необходимо наличие базы 7.7 на локальной машине. Пример (На форме объекта присутствует реквизит Таблица(ТаблицаЗначений)): НаКлиенте Процедура Загрузки() ПутьКБазе=" D:ВашаБаза1с77" ; Пользователь=
Cодержимое указанного ниже веб-сайта в этом приложении блокируется... Aboutsecurity_1cv8c.exe 1
Проблема: После обновления на 1С:Бухгалтерию предприятия 3-й версии, при нажатии на закладку командного интерфейса 1С:предприятие, выскакивает ошибка: Aboutsecurity_1cv8c.exe или Aboutsecurity_1cv8.exe «Содержимое указанного ниже веб-узла в э
Посмотреть все результаты поиска похожих
Вы не можете отправить комментарий анонимно, пожалуйста войдите или зарегистрируйтесь.