Логические операции (1с предприятие). Логические операции (1с предприятие) Автоматическое преобразование типов












1. Введение

Язык программы 1С является структурно-объектным. Этот язык можно назвать как промежуточный язык между языками высокого уровня и языками скриптов, напрмиер такми как VBA.
По своей сути приложение 1С работает как бы с двумя модулями. Первый модуль - это ядро или движек. По сути это компилятор, который переводит код а также описание печатных и графических форм на экран или принтер. Второй модуль - база данных, с которой работет первый модуль. Оба модуля взаимосвязаны и работать самомтсоятельно не могут. Второй модуль отвечает за доступ к базе, а также за манипуляцию с ифнормацией в базе.
В 1С версии 7.7 существет 1 встроенных механизм доступа к базам данных и один механизм, который использует внешний интерфейс доступа к базам данных.
Первый механизм - доступ к базе формата dbf (по сути доступ не к базе а к каждому отдельному файлу). Используемая версия dbf - DBASE II, с соответсвующими ограничениями и недостаткатками этой старой версии.
Второй механизм - доступ к базе в формате MS SQL Server используя соединение через ODBC (так называемый ODBC провайдер доступа к MS SQL Server), который поставляется вместе с MS SQL Server. Изначально версия 7.7 разрабатывалась под SQL Server 6.5 (а точнее она дорабатывалась версии 7.5, которая работала на более ранних версиях SQL Server). На момент написания статьи актуальным релизом 1С (рели 7.70.027) поддерживаются версии SQL Server 6.5, 7.0. SQL2000, про поддержку SQL 2005 информация отсутствует. Но автор провел тест на подключение к SQL Server 2005 релиза 7.70.027 и тест законлился неудачей. Т.е. можно предположить что официально 27 релиз не поддерживает SQL Server 2005 (но эту проблему можно решить почитат здесь: ).
Для понимания того как работает 1С рассмотрим как 1С хранит и как запускает код на выполнение. Весь код 1С физически находится или в файле 1Cv7.md, или во внешних отчетах обработках (*.ert) (существует также возможность подгружать модули с внешних файлов, но это частный случай и он рассматриваться не будет). Запускается код на выполнение поэтапно. Это значит что код компилируется и запускается на выполнение по мере необходимости (а точнее тогда, когда осуществляется доступ к объекту или к форме объекта). Исключение составляет лишь глобальный модуль, его компиляция просиходит в момент запуска самой 1С (точнее после инициализации базы данных). Остальные же модули не компилируются в момент запуска 1С, а копмилируются лишь при обращении к этому модулю через форму или объект. Это приводит к тому, что синтаксис контроль надо проверять самому или же смотреть на синтаксические ошибки уже в момент работы приложения.

2. Объектная структура 1С

Логически код 1С хранится в модулях (модуль в понимании языка 1С - код, который запускается на выполнение). В 1С все модули можно разделить на 3 большие категории: 1 - глобальный модуль, модули обьектов 1С, модули обработок и отчетов. С точки зрения 1С под объектом понимается часть общего набора сущностей, что есть в конкретной базе данных, которые обладают одинаковыми свойствами, имеют одинаковый набор методов и выполняют однотипные функции с информацией или с базой данных. Следует отметить, что не все объекты 1С имеют модули, но в то же время некоторые объекты имеют более одного модуля. Обычно модули привязываются к формам. Форма с точки зрения 1С - это окно с набором своих атрибутов и реквизитов. Не все объекты имеют свои формы, в тоже время некоторые объекты имеют несколько форм. Обычно это форма конкртеного элемента или же форма списка элементов.
Следует учесть, что 1С работает с базой данных, в то же время некоторые объекты не хранятся в базе данных.
Т.е. первая классификация объектов может быть по тому, информация по объектам хранится в базе или не в базе, назовем первый тип обьектов Информационные, а второй тип - Неинформационные. Все информационные объекты хранятся в базе данных, в одной или нескольких таблицах. Работа с инофрмационными объектами всегда предполагает позиционирование на конкретную запись в таблице, которая идентифицирует объект. Это значит, что для обращения к такому объекту надо каким то образом перейти на требуемую запись в базе данных. Обычно для такого переходя используются методи 1С.
Очень хорошей особенностью 1С является то, что часть вновь созданных объектов могут иметь тип уже существующего объекта. Такие объекты называются типообразующие. Те типы, которые не образуют данных для вновь созданных объектов - нетипообразующие. Все типообразующие объекты есть информационными, т.е. они хранятся в базе данных. В понимании 1С типообразующие объекты - это агрегатные объекты.
В то же время, в 1С есть базовые типы, которые существуеют независимо от создаваемых объектов. Эти типы также хранятся в базе, но эти данные не есть объектами с точки зрения 1С, а они есть атрибутами информационных обьектов.
Также, важной классификацией объектов есть их типизация по тем признакам, по которым они делятся в самом описании базы данных. Вот эти объекты:
  • Константы.
  • Справочники.
  • Документы.
  • Журналы документов.
  • Перечисдения.
  • Отчеты.
  • Обработки.
  • Планы счетов.
  • Виды субконто.
  • Операция.
  • Проводка.
  • Регистры.
  • Журналы расчетов.
  • Виды расчетов.
  • Группы расчетов.
  • Календари.
Кроме этого существуют нетипизирующие объекты, которые не являются информационными и которые не присутствуют в дереве настройки конфигурации:
  • Текст.
  • XBase.
  • БухгалтерскиеИтоги.
  • КорректныеПроводки.
  • ПравилоПерерасчета.
  • Последовательность.
  • Периодический.
  • СписокЗначений.
  • ТаблицаЗначений.
  • Таблица.
  • Запрос.
  • Картинка.
  • ФС (Файловая система).
Почти ко всем с перечисленных типов объектов можно получить доступ в модулях посредством функции создания объектов СоздатьОбъект().Общаю структуру описаных классификаций объектов можно представить в виде такой матрицы:
Типы объектов Информационные Типообразующие СоздатьОбъект() Наличие модулей
Константы
Справочники + + + +
Документы + + + +
Журналы документов +
Перечисдения +
Отчеты +
Обработки +
Планы счетов + + + +
Виды субконто +
Операция + + +
Проводка + +
Регистры +
Журналы расчетов + +
Виды расчетов + +
Группы расчетов
Календари +
Текст +
XBase +
БухгалтерскиеИтоги +
КорректныеПроводки + +
ПравилоПерерасчета +
Последовательность + +
Периодический +
СписокЗначений +
ТаблицаЗначений +
Таблица +
Запрос +
Картинка +
ФС (Файловая система) +
Число +
Строка +
Дата +

3. Язык 1С. Модульность

Как уже было сказано весь текст программного кода делится по модулям.
Вцелом модули можно структурировать так:
Отдельная база данных
Глобальный модуль.
Модули Справочников.
Модули Форм списков справочников.
Модуль элемента справочников.
Модуль группы справочников
Модули документов.
Модуль формы документов.
Модуль документов.
Модули журналов документов.
Модуль форми журналов документов.
Модули плана счетов.
Модуль формы счета.
Модули форм списков планов счетов.
Модули операции.
Модуль операции.
Модули форм списков операции.
Модули проводки.
Модули форм списков журналов проводок.
Модули журналов расчетов.
Модули форм списков журналов расчетов.
Модули видов расчетов.
Модули расчетов.
Модули отчетов.
Модуль формы отчетов.
Модули обработок.
Модуль формы обработки.
Т.е. в пределах одной базы, с каждого модуля объекта доступен только глобальный модуль. Все остальные модули изолированные и их взаимосвязь без обращений к конкретному спозиционированному объекту невозможна. Но в тож время с каждого модуля доступны атрибуты (и часть методов, которые определены как системные функции) верхнего уровня. Следует отметить, что написанные пользовательские функции и процедуры не есть методами объектов и их вызов как методов невозможен.
Уровень изоляции атрибутов и переменных идет снизу вверх. Так переменные глобального модуля доступны во всех модулях, точно так же и функции и процедуры глобального модуля. В то же время атрибуты объектов доступны во всех модулях этих объектов, а вот методы делятся на те что доступны и недоступны.

4. Общее положения написания модулей

Семантика языка 1С такова что весь текст модуля делится на операторы и коментарии. Концом оператора является символ ";". Операторы состоят с выражений.

4.1.Коментарии

Коментарии в 1С только построчные (поблочных нет). комментарий начинается с двух символов "// " и заканчивается символом конца строки (т.е. до конца строки).

4.2. Имена переменных, процедур и функций

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

4.3. Зарезервированные слова

Приведенные далее ключевые слова являются зарезервированными и не могут использоваться в качестве создаваемых имен переменных и объявляемых процедур и функций. В данном варианте языка каждое из ключевых слов имеет два представления — русское и английское. Английское представление является традиционным для языков программирования. Ключевые слова в русском и английском представлении могут свободно смешиваться в одном исходном тексте. Регистр букв ключевых слов не имеет значения. Ниже приведен список ключевых слов в обоих вариантах представления.

ИначеЕсли

СтрДлина

КонецЕсли

Контекст

Продолжить

Прервать

КонецПроцедуры

КонецФункции

Предупреждение

КонецЦикла

Процедура

4.4. Структура программного модуля

Структуру программного модуля можно подразделить на следующие разделы:

  • раздел определения переменных;
  • раздел процедур и функций;
  • раздел основной программы.

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

Раздел определения переменных размещается от начала текста модуля до первого оператора Процедура или оператора Функция или любого исполняемого оператора. В этом разделе могут находиться только операторы объявления переменных Перем.

Раздел процедур и функций размещается от первого оператора Процедура или оператора Функция до любого исполняемого оператора вне тела описания процедур или функций.

Раздел основной программы размещается от первого исполняемого оператора вне тела процедур или функций до конца модуля. В этом разделе могут находиться только исполняемые операторы. Раздел основной программы исполняется в момент запуска модуля на выполнение (см. «Виды программных модулей»). Обычно в разделе основной программы имеет смысл размещать операторы инициализации переменных какими-либо конкретными значениями, которые необходимо провести до первого вызова любой из процедур или функций модуля.

5. Формат описания виражений и преобразования типов

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

5.1.Типы данных в выражениях и формат их записи.

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

Числа

Числа записываются цифрами от 0 до 9; при необходимости записать дробное число целая часть отделяется от дробной части точкой ".".
Например:
45 - положительное целое число
-12 - целое отрицательное число
16.67 - дробное положительное число.

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

Даты

Даты записываются в виде последовательности символов такого формата:
"ДД.ММ.ГГ"
или
"ДД.ММ.ГГГГ" ,
где:
ДД - число месяца. Обязательно записывается двумя цифрами: если число месяца меньше 9, впереди ставится 0, например «02»;
ММ - номер месяца, также записывается двумя цифрами;
ГГ (ГГГГ) - год, может записываться двумя или четырьмя цифрами.

Например: "01.01.2007"

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

Кроме конкретных дат, во встроенном языке существует такое понятие как «пустая дата». Пустая дата задается последовательностью "00.00.00". Обычно, пустая дата используется для сравнения. Получить пустую дату можно также при помощи метода преобразования Дата(0).

Примечание.

Типа Время в 1С нет, точно так же как и нет типа ДатаВремя.

Строковые величины

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

Если необходимо в строковой величине указать кавычки, следует использовать 2 символа кавычек подряд. Например, при записи в формуле содержания операции строковая величина вида

" Пример строки ""строка в кавычках"""

сформирует в содержании операции строку

Пример строки "строка в кавычках"

В рассмотренном примере в строковой величине:
первый символ кавычек - это открывающая кавычка строковой величины в целом;
2 символа кавычек подряд - это открывающая кавычка и в результирующей строке они заменены одним символом кавычек;
3 символа кавычек подряд - это группа, состоящая из: 2-х кавычек - закрывающей кавычки, которые в результирующей строке заменены одним символом кавычек, и одной кавычки - закрывающей кавычки строковой величины в целом.

Как показывает практика, почему-то именно указание кавычек в строковых величинах вызывает некоторые трудности. Хотя ничего сложного в этом нет, нужно только помнить простое правило: первая и последняя кавычка - по одному символу, а все кавычки внутри них - по два символа.

У строковых величин существует понятие "пустая строка". Пустая строка задается парой кавычек: "". Пустая строка обладает всеми свойствами "нормальной" строковой величины, однако не имеет длины.

5.2. Арифметические операции

Теперь рассмотрим арифметически операции, используемые в языке 1С (Оп - "операнд"):

Однако применение арифметических операций имеет определенные особенности, в зависимости от типов операндов.

С числовыми величинами можно использовать все перечисленные выше арифметические операции, практически без ограничений.

Для строковых величин допустима только операция "+", которая в этом случае называется операцией конкатенации (присоединения ). Эта операция присоединяет одну строковую величину к другой.

Например, результатом выражения:

"Пример строки " + "январь 2007 года"

будет строка

Пример строки январь 2007 года

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

Операцией конкатенации можно соединять более двух строковых величин одновременно. Например, допустимо такое выражение:

"Иванов" + " " + "Иван" +" " + "Иванович"

Результатом будет строка

Иванов Иван Иванович

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

К дате можно прибавить число, например:

"02.08.2000"+2

и результатом выражения будет дата, более поздняя, чем первое слагаемое, на количество дней, равных второму слагаемому. В данном случае результатом будет 04.08.2000, или 4 августа 2000 г.

"02.03.2000"-2

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

"02.10.2000" - "02.08.2000"

в этом случае результатом будет количество дней между уменьшаемым и вычитаемым.

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

"02.08.2000" + "02.10.2000"

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

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

Например, в выражении

«Амортизация за » + Формат(РабочаяДата(), «Д ММММГГГГ»)

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

5.3. Автоматическое преобразование типов

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

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

"Амортизация за " + Формат(РабочаяДата(), "Д ММММГГГГ")

В этом выражении второй операнд РабочаяДата(), имеющий тип "дата", преобразуется к типу "строка" при помощи функции Формат() .

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

Для базовых типов определены следующие правила преобразования:

Число -> Строка

Если число не имеет форматных установок, то его строковым представлением является полное представление числа в формате с фиксированной точкой.

Дата -> Строка

Дата преобразованная к строковому типу имеет вид ДД.ММ.ГГ, где ГГ — две цифры года, ММ — числовое обозначение месяца (01, ..., 12), ДД — день месяца.

Строка -> Число

Строка преобразуется в число пока это возможно. Получившееся число считается результатом преобразования. (Например, строка "1.22 Glass" будет преобразована к числу 1.22). Если в начале строки не имеется ничего, что могло бы быть проинтерпретировано как число, то результат равен 0.

Дата -> Число

Результатом данного преобразования является численное представление даты.

Строка -> Дата

Если в начале строки содержится что-то, что может быть проинтерпретировано как строковое представление даты в виде ДД.ММ.ГГ, где ГГ — две цифры года, ММ — числовое обозначение месяца (01, ..., 12), ДД — день месяца, то будет произведено соответствующее преобразование. В противном случае значение даты будет нулевым.

Число -> Дата

Делается попытка взять целую часть Числа и проинтерпретировать как численное представление даты. Если число отрицательно, то итогом является нулевая дата.

Итак, прежде всего, следует помнить, что тип результат выражения определяется по типу первого операнда этого выражения . К типу первого операнда приводятся остальные операнды. Зная это правило, можно и предвидеть тип результата выражения в целом, и управлять типом результата.

Например, результатом выражения

2+"А"

будет число 2, потому что первый операнд выражения имеет числовой тип, а второй операнд, в соответствии с правила преобразования типов, стал равен 0.

Однако, стоит немного изменить выражение, написав так:

""+ 2+"А"

как его результат радикально поменяется: результатом выражения станет строка "2А".

Почему так произошло? Выше мы рассказывали про понятие "пустой строки", которая обладает всеми свойствами строковой величины, в том числе и типом "строка". В нашем примере пустая строка является первым операндом выражения, и при вычислении выражения все его операнды были преобразованы к типу "строка" в соответствии с правилами преобразования типов.

Еще один пример. Выше мы подчеркивали, что величина типа "дата" задается символьной строкой в одинарных кавычках, а такая же последовательность символов, но уже в двойных кавычках, является строкой. Теперь мы это проиллюстрируем на примерах.

Как мы уже говорили, результатом выражения "02.08.2000"+2 будет дата 04.08.2000. Но, указав первый операнд в двойных кавычках:

"02.08.2000"+2

мы получим совершенно иной результат - строку "02.08.20002".

Подитожим. управлять типом результата всего выражения можно, ставя первым операндом пустую величину соответствующего типа. Преимущество такого метода состоит в том, что пустая величина не изменяет результата выражения. Например, поставив 0 в начале выражения:

0+ "23"+45

мы получим в результате число 68, потому что выражение в целом имеет тип "число", а символьная строка в соответствии с правилами преобразования типов, была успешно преобразована в число 45.

Тут уместно вспомнить и про пустую дату. Что будет результатом выражения "00.00.00"+ 2+"02.08.2000"? Конечно же, дата 04.08.2000 (4 августа 2000 года), потому что первым операндом выражения была величина типа "дата".

Наоборот, убрав пустую дату

2+"02.08.2000"

мы получим в результате 2451761 - это число дней с нулевой даты до 2 августа 2000 года, плюс еще 2 дня.

5.4. Логические операторы сравнения

В 1С существуют такие логические выражения для базовых типов данных.

> Больше

< Меньше

<> Не равно

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

По отношению с числовим типом данных - проблем не возникает, сравнивается стандартное число (целое или дробное).

Для строковых величин сравнение происходит ко их так назЫваемым "scan-кодам" (в понимании 1С такой код можно получить с помощью метода КодСимв()). Сравнение производится посимвольно. Так если сравниваются строки равной длины, то сравниваются последовательно коды соотвествующих символов. Сравнение происходит до первого неравенства в строке (если строка состоит больще чем с одного символа). Если сравниваются строки разной длины, то недостающие значение в операторе дополняются символами пустой строки (не с символом пробел (Код= 32)). Т.е. значение пробела (КодСимв(32)) больше значения пустой строки.

Для типов дата сраванивается сама дата (но не исключено что 1С перед сравнением дату переводит в число, которе равно количеству дней от Дата(0)).

6. Проблемы округления

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

Например, такая ситуация:
Приходуется 16 единиц товара по цене (включая НДС) 110,50 грн.
- общая стоимость составляет 110,50 * 16 = 1768 грн.
- НДС (по ставке 20%, в том числе) составляет 1768 * 20 / 120 = 294,67 грн.

Если теперь этот товар продать "поштучно" без всякой наценки, НДС будет другим:
- НДС одной единицы товара составит 110,50 * 20 / 120 = 18,42 грн.
- НДС всех 16 единиц составит 18,42 * 16 = 294,72 грн.

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

Заметим, что, приходуя товар, мы не могли считать НДС "поштучно" - вычисляя размер налога в стоимости одной единицы товара и умножая на количество товара. В этом случае могут быть еще большие потери округления. Например, если цена одной единицы товара 3 копейки, то чему равен НДС?

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

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

7. Ограничения системы V77

Дата
Дата - корректно работает в диапазоне дат от 01.01.0000 до 31.12.9999
Дата(0) соответствует 1721061 дню от даты 01.01.0000
При попытке уйти в минусовые даты - 31.12.0001 система работает некорректно, так как работает с 0 даты, т.е.: Дата("01.01.0000")-1 = 00.01.00. Функция формата для таких дат вообще не работает.

Число
максимальное количество значений = 64 (64 знака).

Строка
Максимальное количество значений = ограничивается свободной физической памятью (без файла подкачки), Предполагается что знаков не может быть больше 2^32-1.

Документ
Документ - может быть создано 9999 видов документов.
Документ может иметь и корректно работать имея не больше 9999 строк.
Максимальная длина кода - 20, т.е. может быть теоретически создано всего (27+33+10)^20 документов (70^20 = 7,9792266297612001e+36).
Всего в системе может быть не больше (длина ID кода в журнале=9), практически длина ID в 6 символов (3 на УРИБ) 36^6 = 2176782336 документов.
Количество введенных документ с одинаковым временем ограничивается 36^4 = 1679616

Внимание! Перед вами ознакомительная версия урока, материалы которого могут быть неполными.

Войдите на сайт как ученик

Войдите как ученик, чтобы получить доступ к материалам школы

Внутренний язык программирования 1С 8.3 для начинающих программистов: простые логические выражения в 1С

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

Наберитесь сил и терпения. Занятия №5 и №6 будут трудными, но очень важными для дальнейшего понимания программирования в 1С. Поэтому, если хоть что-то останется непонятным или нераскрытым - перечитывайте, вдумывайтесь, задавайте вопросы.

Простые логические выражения

Сегодня, к уже изученным типам данных (строка, число и дата) добавим ещё один - логический тип. Он может принимать всего два значения: Истина или Ложь .

Значение логического типа (Истина или Ложь ) является результатом некоторого логического выражения.

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

Операции сравнения бывают следующие:

Думаю, интуитивно понятно, что обозначает каждая из операций.

Читается, например, так:

  • 1 = 1 ("один равен одному").
  • 4 <> 5 ("четыре не равно пяти")
  • 3 > 1 ("три больше одного").

Обращаю ваше внимание, что перечисленные три примера логических выражений принимают значение Истина , так как все они верны.

Разберем на примере:

Задание №14. Укажите для каждого логического выражения его результат - Истина или Ложь .

  1. "Венера" = "Юпитер"
  2. "Венера" <> "Юпитер"
  3. 123 = 321
  4. 123 < 321
  5. 123 <= 321
  6. 123 <= 123
  7. "20000101" <> "20140101"
  8. "20000101" = "20000101"
  9. "20140101" > "20120101"
  10. 25 + 25 = 50
  11. 2 * (10 + 10) > 50
  12. "Юрий" + " Гагарин" = "Юрий Гагарин"

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

  1. "Венера" = "Юпитер" (Ложь , строки не равны между собой, а в выражении утверждается, что равны).
  2. "Венера" <> "Юпитер" (Истина , строки не равны между собой, как и утверждается в выражении).
  3. 123 = 321 (Ложь , так как числа не равны между собой, а в выражении утверждается, что равны).
  4. 123 < 321 (Истина , так как 123 меньше 321, как и утверждается в выражении).
  5. 123 <= 321 (Истина , так как 123 меньше 321, а данное утверждение истинно, если левое число меньше или равно правому).
  6. 123 <= 123 (Истина , так как 123 равно 123, а данное утверждение истинно, если левое число меньше или равно правому).
  7. "20000101" <> "20140101" (Истина , так как левая дата 01.01.2000 не равна 01.01.2014, как и утверждается в выражении).
  8. "20000101" = "20000101" (Истина , так как левая дата 01.01.2000 равна 01.01.2000, как и утверждается в выражении).
  9. "20140101" > "20120101" (Истина , так как первое января 2014 года больше первого января 2012 года, как и утверждается в выражении).
  10. 25 + 25 = 50 (Истина, так как 25 плюс 25 действительно равно пятидесяти, как и утверждается в выражении).
  11. 2 * (10 + 10) > 50 (Ложь , так как результат левого выражения равен 40, а 40 меньше 50, хотя в утверждении говорится обратное).
  12. "Юрий" + " Гагарин" = "Юрий Гагарин" (Истина , так как сумма строк "Юрий" и " Гагарин" образует одну строку "Юрий Гагарин", которая равна строке справа, как и утверждается в выражении).

Заставим считать компьютер

Но, что же мы сами-то считаем "верно" или "неверно ". Ведь у нас под рукой компьютер! Давайте возложим эту задачу на него, а заодно и проверим себя.

К примеру, проверим выражение 2 * (10 + 10) > 50.
Для этого напишем такую программу:

Сообщить(2 * (10 + 10 ) > 50 ) ;

Если мы запустим её, то компьютер выдаст "Нет", что означает - результат равен Ложь .

Как он посчитал это выражение?

  1. Компьютер увидел команду Сообщить.
  2. Посмотрел, что за параметр мы передаем этой команде.
  3. Увидел, что в качестве параметра указано логическое выражение 2 * (10 + 10) > 50.
  4. Стал вычислять результат логического выражения.
  5. Увидел, что выражение состоит из левой части 2 * (10 + 10), правой части 50 и знака больше между ними.
  6. Посчитал результат левой части и выяснил, что он равен сорока.
  7. Снова взглянул на выражение, только в уже упрощенном виде 40 > 50, а так как 40, конечно же, меньше 50, то он вывел "Нет".

Задание №15. Вычислите все примеры логических выражений из предыдущего задания на компьютере.

Например, выражение "Венера" = "Юпитер" , значение которого, как мы выяснили, равно Ложь .

Сообщить("Венера" = "Юпитер" ) ;

Компьютер при запуске выводит значение "Нет", что означает: результат действительно равен Ложь и мы совершенно верно вычислили его сами.

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

Применяются следующие логические операции:

НЕ логическое НЕ (отрицание); И логическое И;

ИЛИ логическое ИЛИ.

Операндами логических операций должны быть логические выражения. В табл. 2.5 приведены результаты логических операций над логическими выражениями ЛВ1 и ЛВ2, принимающими значения истина (И) или ложь (Л).

Таблица истинности

Таблица 2.5

ЛВ1 ЛВ2 ЛВ1 И ЛВ2 ЛВ1 ИЛИ ЛВ2 НЕ ЛВ1
И И И И Л
И Л Л И Л
Л И Л И И
Л Л Л Л И

Операция отрицания является унарной операцией, располагаемой слева от операнда. Все остальные рассмотренные операции являются бинарными.

2.6.5. ПРИОРИТЕТ ВЫПОЛНЕНИЯ ОПЕРАЦИЙ

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

Приоритет выполнения операций

Таблица 2. б

% *,/ +, НЕ И ИЛИ <, <=, >, >=, =, <>

Замечание. Каждая ячейка таблицы содержит операции с равным приоритетом.

Пример:

8 % 2 * 3 // Вернет 0
8 % (2 * 3) // Вернет 2

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

3>2и4< 5 // Так неверно

так как первоначально оценивается логическое подвыражение 2и 4

операнды которого не есть истина или ложь. А это неверно.

Зато верно логическое выражение

(3 > 2) и (4 < 5) // Это истина Пример. Вычислить результат логического выражения

(х / а = 1) или (б / (а + б) < 1) и не (б = а) или (х <> 6) при х = 6.0, а = 2.0 и б=3.0.

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

ложь или истина и не ложь или ложь.

ложь или истина и истина или ложь. После выполнения истина и истина: ложь или истина или ложь. Окончательный результат: истина.

2.7. МАССИВЫ

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

Число элементов массива называется его размером. Размером массива может быть только целочисленная буквальная константа.

Оператор перем а;

объявляет одномерный массив (вектор) а из пяти элементов. Элементы массива имеют следующие имена: а, а, а, а и а. В этих именах величины 1-5 индексы элементов массива.

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

для ин = 1 по 5 цикл

Присваивания

изменят соответственно значения 2-го и 5-го элементов массива а.

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

а = 9.1; // Меняем значение 3-го элемента массива а

Если индексное выражение массива вычисляется с нецелым значением, то в каче стве индекса берется целая часть этого значения. Например:

а = 9.1; // Меняем значение 1 -го элемента массива а

Значение индекса не должно выходить за границы массива. Так, при работе с ранее объявленным массивом а из пяти элементов ошибочны операторы

Элементы одного и того же массива могут быть разного типа. Например:

а = ‘25.11.01’; // Элемент типа Дата Элементы массива могут быть агрегатного типа. Например:

сСотр= СоздатьОбъект(“Справочник.Сотрудники”);

табл = СоздатьОбъект(“Таблица”);

Массив не может в качестве элементов содержать другие массивы.

Массив может быть формальным параметром программного компонента (процедуры или функции). При этом размер массива не указывается, а квадратные скобки сохраняются. Для определения размера переданного процедуре (функции) массива используется встроенная функция Разм.

Пример:

процедура ИнициализацияМассива(а) перем ин, размА;

размА = Разм(а); // Встроенная функция Разм вернет размер массива а

для ин = 1 по размА цикл

а[ин] = 1; // Теперь все элементы массива равны единице конецЦикла;

конецПроцедуры // ИнициализацияМассива

процедура Выполнить() перем а;

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

// Ее фактическим параметром является имя массива ИнициализацияМассива(а);

конецПроцедуры // Выполнить

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

Арифметические операции

В языке определены следующие виды арифметических операций:

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

Замечание
При выполнении операции % (остаток от деления) оба операнда операции округляются до целого значения
.

Операция конкатенации

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

Пример :

· Для того, чтобы удалить ненужные пробелы, используются системные функции СокрЛ и СокрП. ФИО = СокрП(Фамилия) + " " + СокрП(Имя) + " " + СокрП(Отчество);

Язык запросов в 1С 8 — это упрощенный аналог широко известного «структурированного языка программирования» (как чаще его называют, SQL). Но в 1С он используется только для чтения данных, для изменения данных применяется объектная модель данных.

Еще одно интересное отличие – русский синтаксис. Хотя на самом деле Вы можете использовать и англоязычные конструкции.

Пример запроса:

ВЫБРАТЬ
Банки.Наименование,
Банки.КоррСчет
ИЗ
Справочник.Банки КАК Банки

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

Язык запросов – самой простой и эффективный способ получения информации. Как видно из примера выше, в языке запросов нужно апеллировать именами метаданных ( – это список объектов системы, из которых состоит конфигурация, т.е справочники, документы, регистры и т.д.).

Описание конструкций языка запросов

Структура запросов

Для получения данных достаточно использовать конструкции «ВЫБРАТЬ» (select) и «ИЗ» (from). Простейший запрос выглядит следующим образом:

ВЫБРАТЬ * ИЗ Справочники.Номенклатура

Где «*» означает выбор всех полей таблицы, а Справочники.Номенклатура – имя таблицы в базе данных.

Рассмотрим более сложный и общий пример:

ВЫБРАТЬ
<ИмяПоля1> КАК <ПредставлениеПоля1>,
Сумма(<ИмяПоля2>) КАК <ПредставлениеПоля2>
ИЗ
<ИмяТаблицы1> КАК <ПредставлениеТаблицы1>
<ТипСоединения> СОЕДИНЕНИЕ <ИмяТаблицы2> КАК <ПредставлениеТаблицы2>
ПО <УсловиеСоединениеТаблиц>

ГДЕ
<УсловиеОтбораДанных>

СГРУППИРОВАТЬ ПО
<ИмяПоля1>

УПОРЯДОЧИТЬ ПО
<ИмяПоля1>

ИТОГИ
<ИмяПоля2>
ПО
<ИмяПоля1>

В данном запросе мы выбираем данные полей «ИмяПоля1» и «ИмяПоля1» из таблиц «ИмяТаблицы1» и «ИмяТаблицы», присваиваем полям синонимы с помощью оператора «КАК», соединяем их по некому условию «УсловиеСоединениеТаблиц».

Из полученных данных мы отбираем только данные, соответствующие условию из «ГДЕ» «УсловиеОтбораДанных».Далее мы группируем запрос по полю «ИмяПоля1», при этом суммируя «ИмяПоля2».Создаём итоги по полю «ИмяПоля1» и итоговым полем «ИмяПоля2».

Последним действием мы сортируем запрос с помощью конструкции «УПОРЯДОЧИТЬ ПО».

Общие конструкции

Рассмотрим общие конструкции языка запросов 1С 8.2.

ПЕРВЫЕ n

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

ВЫБРАТЬ ПЕРВЫЕ 100
Банки.Наименование,
Банки.Код КАК БИК
ИЗ
Справочник.Банки КАК Банки
УПОРЯДОЧИТЬ ПО
Банки.Наименование

Запросом будет получено первых 100 записей справочника «Банки», упорядоченных по алфавиту.

РАЗРЕШЕННЫЕ

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

Если пользователь пытается с помощью запроса прочитать записи недоступные ему, он получит сообщение об ошибке. Чтобы этого избежать, следует использовать конструкцию «РАЗРЕШЕННЫЕ», т.е запрос будет читать только разрешенные ему записи.

ВЫБРАТЬ РАЗРЕШЕННЫЕ
ХранилищеДополнительнойИнформации.Ссылка
ИЗ
Справочник.ХранилищеДополнительнойИнформации

РАЗЛИЧНЫЕ

Использование «РАЗЛИЧНЫЕ» позволит исключить попадание строк-дублей в результат запроса 1С. Дублирование означает совпадение всех полей запроса.

ВЫБРАТЬ ПЕРВЫЕ 100
Банки.Наименование,
Банки.Код КАК БИК
ИЗ
Справочник.Банки КАК Банки

ПустаяТаблица

Данная конструкция используется очень редко для объединения запросов. При объединении может возникнуть необходимость указать в одной из таблиц пустую вложенную таблицу. Для этого как раз подойдет оператор «ПустаяТаблица»

Пример из справки 1С 8:

ВЫБРАТЬ Ссылка.Номер, ПУСТАЯТАБЛИЦА.(Ном, Тов, Кол) КАК Состав
ИЗ Документ.РасхНакл
ОБЪЕДИНИТЬ ВСЕ
ВЫБРАТЬ Ссылка.Номер, Состав.(НомерСтроки, Товар, Количество)
ИЗ Документ.РасхНакл Документ.РасходнаяНакладная.Состав.*

ЕСТЬNULL

Очень полезная функция, которая позволяет избежать многих ошибок. ЕстьNULL() позволяет заменить значение NULL на нужное. Очень часто используется в проверках на наличие значения в присоединенных таблицах, например:

ВЫБРАТЬ
НоменклатураСпр.Ссылка,
ЕстьNULL(ОстаткиТовара.КоличествоОстаток,0) КАК КоличествоОстаток
ИЗ


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

ЕСТЬNULL(СчетФактураПолученный.Дата, СчетФактураВыданный.Дата)

КАК – оператор, который позволяет нам присвоить имя (синоним) таблицы или полю. Пример использования мы видели выше.

Данные конструкции очень похожи – они позволяют получить строковое представление нужного значения. Единственное отличие в том, что ПРЕДСТАВЛЕНИЕ преобразует любые значения в строковый тип, а ПРЕДСТАВЛЕНИЕССЫЛКИ — только ссылочные. ПРЕДСТАВЛЕНИЕССЫЛКИ рекомендуется применять в запросах системы компоновки данных для оптимизации, если, конечно, поле ссылочных данных не планируется использовать в отборах .

ВЫБРАТЬ
Представление(Ссылка), //строка, например «Авансовый отчет №123 от 10.10.2015
Представление(ПометкаУдаления) КАК ПометкаУдаленияТекст, //строка, «Да» или «Нет»
ПредставлениеСсылки(ПометкаУдаления) КАК ПометкаУдаленияБулево //булево, Истина или Ложь
ИЗ
Документ.АвансовыйОтчет

ВЫРАЗИТЬ

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

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

ВЫРАЗИТЬ(ТаблицаЗатрат.Субконто1 КАК Справочник.СтатьиЗатрат).ВидДеятельностиДляНалоговогоУчетаЗатрат

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

ВЫРАЗИТЬ(Комментарий КАК Строка(150))

РАЗНОСТЬДАТ

Получите 267 видеоуроков по 1С бесплатно:

Пример использования ЕСТЬ NULL в запросе 1С:

ВЫБРАТЬ * ИЗ
Спр
ЛЕВОЕ СОЕДИНЕНИЕ РегистрНакопления.ТоварыНаСкладах.Остатки КАК ОстаткиТовара
ПО НоменклатураСпр.Ссылка = РеализованныеТоварыКомитентовОстатки.Номенклатура
ГДЕ НЕ ОстаткиТовара.КоличествоОстаток ЕСТЬ NULL

Тип данных в запросе можно определить следующим образом: с помощью функций ТИП() и ТИПЗНАЧЕНИЯ() или с помощью логического оператора ССЫЛКА. Эти две функции аналогичны.

Предопределенные значения

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

Пример использования:

ГДЕ Номенклатура.ВидНоменклатуры = Значение(Справочник.ВидыНоменклатуры.Товар)

ГДЕ Контрагенты.ВидКонтактнойИнформации = Значение(Перечисление.ВидыКонтактнойИнформации.Телефон)

ГДЕ ОстаткиПоСчетам.СчетУчета = Значение(ПланСчетов.Хозрасчетный.ПрибылиУбытки)

Соединения

Соединения бывают 4 типов: ЛЕВОЕ , ПРАВОЕ , ПОЛНОЕ, ВНУТРЕННЕЕ .

ЛЕВОЕ и ПРАВОЕ СОЕДИНЕНИЕ

Соединения используются для связи двух таблиц по определенному условию. Особенность при ЛЕВОМ СОЕДИНЕНИИ в том, что мы берём первую указанную таблицу полностью и привязываем по условию вторую таблицу. Поля второй таблицы, которые не удалось привязать по условию, заполняются значением NULL .

Например:

Вернет всю таблицу Контрагентов и заполнит поле “Банк” лишь в тех местах, где будет соблюдаться условие “Контрагенты.Наименование = Банки.Наименование”. Если условие не соблюдается, в поле Банк будет установлено NULL .

ПРАВОЕ СОЕДИНЕНИЕ в языке 1С абсолютно аналогично ЛЕВОМУ соединению , за исключением одного отличия – в ПРАВОМ СОЕДИНЕНИИ “главная” таблица – вторая, а не первая.

ПОЛНОЕ СОЕДИНЕНИЕ

ПОЛНОЕ СОЕДИНЕНИЕ отличается от левого и правого тем, что выводит все записи из двух таблиц, соединяет лишь те, которые может соединить по условию.

Например:

ИЗ

ПОЛНОЕ СОЕДИНЕНИЕ
Справочник.Банки КАК Банки

ПО

Язык запросов вернет обе таблицы полностью лишь по выполненному условию соединить записи. В отличие от левого/правого соединения возможно появления NULL в двух полях.

ВНУТРЕННЕЕ СОЕДИНЕНИЕ

ВНУТРЕННЕЕ СОЕДИНЕНИЕ отличается от полного тем, что выводит только те записи, которые смогли соединить по заданному условию.

Например:

ИЗ
Справочник.Контрагенты КАК Клиенты

ВНУТРЕННЕЕ СОЕДИНЕНИЕ
Справочник.Банки КАК Банки

ПО
Клиенты.Наименование = Банки.Наименование

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

Объединения

Конструкция ОБЪЕДИНИТЬ и ОБЪЕДИНИТЬ ВСЕ объединяет два результата в один. Т.е. результат выполнения двух будет «слит» в один, общий.

Т.е система работает точно так же, как и обычные , только для временной таблицы.

Как использовать ИНДЕКСИРОВАТЬ ПО

Однако следует учесть один момент. Построение индекса временной таблицы также требует времени на выполнение. Поэтому целесообразно использовать конструкцию ” ”, только если точно известно, что во временной таблице будет не 1-2 записи. В противном случае эффект может быть обратным – быстродействие от индексированных полей не компенсирует времени построения индекса.

ВЫБРАТЬ
КурсыВалютСрезПоследних.Валюта КАК Валюта,
КурсыВалютСрезПоследних.Курс
ПОМЕСТИТЬ КурсыВалют
ИЗ
РегистрСведений.КурсыВалют.СрезПоследних(&Период,) КАК КурсыВалютСрезПоследних
ИНДЕКСИРОВАТЬ ПО
Валюта
;
ВЫБРАТЬ
ЦеныНоменклатуры.Номенклатура,
ЦеныНоменклатуры.Цена,
ЦеныНоменклатуры.Валюта,
КурсыВалют.Курс
ИЗ
РегистрСведений.ЦеныНоменклатуры.СрезПоследних(&Период,
Номенклатура В (&Номенклатура) И ТипЦен = &ТипЦен) КАК ЦеныНоменклатуры
ЛЕВОЕ СОЕДИНЕНИЕ КурсыВалют КАК КурсыВалют
ПО ЦеныНоменклатуры.Валюта = КурсыВалют.Валюта

Группировка

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

Существуют следующие функции:

Сумма, Количество, Количество разных, Максимум, Минимум, Среднее.

Пример №1:

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

СГРУППИРОВАТЬ ПО
РеализацияТоваровУслугТовары.Номенклатура

Запрос получает все строки с товарами и суммирует их по количеству и суммам в разрезе номенклатуры.

Пример №2

ВЫБРАТЬ
Банки.Код,
КОЛИЧЕСТВО(РАЗЛИЧНЫЕ Банки.Ссылка) КАК КоличествоДублей
ИЗ
Справочник.Банки КАК Банки
СГРУППИРОВАТЬ ПО
Банки.Код

Данный пример отобразит список БИКов справочника «Банки» и покажет, сколько дублей существует по каждому из них.

Итоги

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

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

ВЫБРАТЬ




ИЗ
Документ.РеализацияТоваровУслуг.Товары КАК РеализацияТоваровУслугТовары
УПОРЯДОЧИТЬ ПО

ИТОГИ
СУММА(Количество),
СУММА(Сумма)
ПО
Номенклатура

В результате запроса получится следующее иерархическое :

Общие итоги

Если необходимо получить итоги по всем «итогам», используйте оператор «ОБЩИЕ».

ВЫБРАТЬ
РеализацияТоваровУслугТовары.Номенклатура КАК Номенклатура,
РеализацияТоваровУслугТовары.Ссылка КАК Документ,
РеализацияТоваровУслугТовары.Количество КАК Количество,
РеализацияТоваровУслугТовары.Сумма КАК Сумма
ИЗ
Документ.РеализацияТоваровУслуг.Товары КАК РеализацияТоваровУслугТовары
УПОРЯДОЧИТЬ ПО
РеализацияТоваровУслугТовары.Ссылка.Дата
ИТОГИ
СУММА(Количество),
СУММА(Сумма)
ПО
ОБЩИЕ,
Номенклатура

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

В котором 1 уровень группировки – агрегирование всех нужных полей.

Упорядочивание

Оператор УПОРЯДОЧИТЬ ПО используется для сортировки результата запроса.

Сортировка для примитивных типов (строка, число, булево) происходит по обычным правилам. Для полей ссылочных типов сортировка происходит по внутреннему представлению ссылки (уникальный идентификатор), а не по коду или по представлению ссылки.

ВЫБРАТЬ

ИЗ
Справочник.Номенклатура КАК Номенклатура
УПОРЯДОЧИТЬ ПО
Наименование

Запрос выведет список наименований справочника номенклатуры, отсортированного по алфавиту.

Автоупорядочивание

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

Если необходимо выводить записи таблицы в постоянном порядке, необходимо использовать конструкцию «Автоупорядочивание».

ВЫБРАТЬ
Номенклатура.Наименование КАК Наименование
ИЗ
Справочник.Номенклатура КАК Номенклатура
АВТОУПОРЯДОЧИВАНИЕ

Виртуальные таблицы

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

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

  • срез первых;
  • срез последних.
  • остатки;
  • обороты;
  • остатки и обороты.
  • движения с субконто;
  • обороты;
  • обороты Дт Кт;
  • остатки;
  • остатки и обороты
  • субконто.
  • база;
  • данные графика;
  • фактический период действия.

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

ВЫБРАТЬ
ТоварыНаСкладахОстаткиИОбороты.Номенклатура,
ТоварыНаСкладахОстаткиИОбороты.КоличествоНачальныйОстаток,
ТоварыНаСкладахОстаткиИОбороты.КоличествоОборот,
ТоварыНаСкладахОстаткиИОбороты.КоличествоПриход,
ТоварыНаСкладахОстаткиИОбороты.КоличествоРасход,
ТоварыНаСкладахОстаткиИОбороты.КоличествоКонечныйОстаток
ИЗ
РегистрНакопления.ТоварыНаСкладах.ОстаткиИОбороты КАК ТоварыНаСкладахОстаткиИОбороты

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

Параметры виртуальных таблиц

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

Для таких таблиц считается неверным использования отбора в конструкции «ГДЕ». Помимо того, что запрос становится не оптимальным, возможно получение неверных данных.

Пример использования таких параметров:

РегистрНакопления.ТоварыНаСкладах.ОстаткиИОбороты(&НачалоПериода, &КонецПериода, Месяц, ДвиженияИГраницыПериода, Номенклатура = &НужнаяНоменклатура)

Алгоритм работы виртуальных таблиц

Например, наиболее используемая виртуальная таблица типа «Остатки» хранит данные двух физических таблиц – остатков и движений.

При использовании виртуальной таблицы система проделывает следующие манипуляции:

  1. Получаем ближайшее по дате и измерениям рассчитанное значение в таблице итогов.
  2. «Прибавляем» сумму из таблицы движения к сумме из таблицы итогов.


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

Использование конструктора запросов

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

Конструктор запроса имеет достаточно простой, интуитивно понятный интерфейс. Тем не менее рассмотрим применение конструктора запроса подробнее.

Запуск конструктора текста запроса производится контекстным меню (правой кнопкой мыши) в нужном месте программного кода.

Описание конструктора запроса 1С

Рассмотрим каждую вкладку конструктора подробнее. Исключение – вкладка Построитель, это тема для отдельного разговора.

Вкладка Таблицы и поля

На этой вкладке указывается источник данных и поля, которые необходимо выводить в отчет. По сути тут описываются конструкции ВЫБРАТЬ.. ИЗ.

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

В контекстном меню виртуальных таблиц можно задать параметры виртуальной таблицы:

Вкладка Связи

Вкладка служит для описания соединений нескольких таблиц, создает конструкции со словом СОЕДИНЕНИЕ.

Вкладка Группировка

На данной вкладке система позволяет группировать и суммировать нужные поля результата таблицы. Описывается использование конструкций СГРУППИРОВАТЬ ПО, СУММА, МИНИМУМ, СРЕДНЕЕ, МАКСИМУМ, КОЛИЧЕСТВО, КОЛИЧЕСТВО РАЗЛИЧНЫХ.

Вкладка Условия

Отвечает за всё, что идёт в тексте запроса после конструкции ГДЕ, т.е за все условия, накладываемые на получаемые данные.

Вкладка Дополнительно

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

Группировка Выборка записей :

  • Первые N – параметр, возвращающий в запрос только N записей (оператор ПЕРВЫЕ)
  • Без повторяющихся – обеспечивает уникальность полученных записей (оператор РАЗЛИЧНЫЕ)
  • Разрешенные – позволяет выбирать только те записи, которые позволяет выбрать система с учетом (конструкция РАЗРЕШЕННЫЕ)

Группировка Тип запроса определяет, какой будет тип запроса: выборка данных, создание временной таблицы или же уничтожение временной таблицы.

Ниже существует флаг Блокировать полученные данные для последующего изменения . Он позволяет включить возможность установки блокировки данных, которая обеспечивает сохранность данных от момента их чтения до изменения (актуально только для Автоматического режима блокировок, конструкция ДЛЯ ИЗМЕНЕНИЯ).

Вкладка Объединения/Псевдонимы

На этой вкладке конструктора запросов устанавливается возможность объединения разных таблиц и псевдонимов(конструкция КАК). В левой части указываются таблицы. Если установить флаги напротив таблицы, будет использоваться конструкция ОБЪЕДИНИТЬ, иначе – ОБЪЕДИНИТЬ ВСЕ (отличия двух способов ). В правой части указываются соответствия полей в разных таблицах, если соответствие не указано, запрос будет возвращать NULL.

Вкладка Порядок

Здесь указывается порядок сортировки значений (УПОРЯДОЧИТЬ ПО) – по убыванию (УБЫВ) или возрастанию(ВОЗР).

Также есть интересный флаг – Автоупорядочивание (в запросе – АВТОУПОРЯДОЧИВАНИЕ). По умолчанию система 1С выводит данные в “хаотичном” порядке. Если установить этот флаг, система будет сортировать данные по внутренним данным.

Вкладка Пакет запросов

На вкладке конструктора запросов можно создавать новые , а также использовать её в роли навигации. В тексте запроса пакеты разделяются символом “;”(точка запятая).

Кнопка “Запрос” в конструкторе запросов

В левом нижнем углу конструктора запроса есть кнопка Запрос, с помощью которого можно в любой момент просмотреть текст запроса:

В данном окне можно внести коррективы в запрос и выполнить его.


Использование консоли запросов

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

Рассмотрим этот инструмент подробнее.

Скачать консоль запросов 1С

Первым делом, чтобы начать работу с консолью запросов, её нужно откуда-то скачать. Обработки обычно делятся на два вида – на управляемых формах и обычных (или, иногда, их называют на 8.1 и на 8.2/8.3).

Я постарался объединить эти два вида в одной обработке – в нужном режиме работы открывается нужная форма (в управляемом режиме консоль работает только в толстом режиме).

Описание консоли запросов 1С

Начнем рассмотрение консоли запросов с описания главной панели обработки:

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

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

Слева, в поле “Запрос”, можно создавать новые запросы и сохранять их в древовидной структуре. Вторая группа кнопок как раз отвечает за управление списком запросов. С помощью неё можно создать, скопировать, удалить, переместить запрос.

  • Выполнить запрос – простое выполнение и получение результата
  • Выполнить пакет – позволяет просмотреть все промежуточные запросы в пакете запросов
  • Просмотр временных таблиц – позволяет увидеть результаты, которые возвращают временные запросы в таблице

Параметры запроса:

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

В окне параметров запроса интересно следующее:

  • Кнопка Получить из запроса автоматически находит все параметры в запросе для удобства разработчика.
  • Флаг Единые параметры для всех запросов – при установке его обработка не очищает параметры при переходе от запроса к запросу в общем списке запросов.

Задать параметр списком значений очень просто, достаточно при выборе значения параметра нажать на кнопку очистки значения (крестик), система предложит выбрать тип данных, где надо выбрать “Список значения”:

Также в верхней панели очень есть кнопка вызова настроек консоли запросов:

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

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

Конструктор запроса 1С 8 вызывается из контекстного меню (правая кнопка мыши) при нажатии на поле ввода:

Также в этом меню есть такие полезные функции, как очистка или добавление в запрос символов переноса строки (“|”) или же получения кода запроса вот в таком удобном виде:

Запрос = Новый Запрос;
Запрос.Текст = ”
|ВЫБРАТЬ
| Валюты.Ссылка
|ИЗ
| Справочник.Валюты КАК Валюты”;
РезультатЗапроса = Запрос.Выполнить();

В нижнем поле консоли запросов отображается поле результата запроса, ради чего и создана эта обработка:



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

Оптимизация запросов

Одним из важнейших пунктов в повышении производительности работы 1С предприятия 8.3 является оптимизация запросов . Этот пункт также очень важен при сдаче аттестации . Ниже пойдет речь о типичных причинах не оптимальной работы запросов и способах из оптимизации.

Отборы в виртуальной таблице с помощью конструкции ГДЕ

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

ПРАВИЛЬНО :

ВЫБРАТЬ

ИЗ
РегистрНакопления.ВзаиморасчетыСДепонентамиОрганизаций.Остатки(
,
Организация = &Организация
И Физлицо = &Физлицо) КАК ВзаиморасчетыСДепонентамиОрганизацийОстатки

НЕПРАВИЛЬНО :

ВЫБРАТЬ
ВзаиморасчетыСДепонентамиОрганизацийОстатки.СуммаОстаток
ИЗ
РегистрНакопления.ВзаиморасчетыСДепонентамиОрганизаций.Остатки(,) КАК ВзаиморасчетыСДепонентамиОрганизацийОстатки
ГДЕ
ВзаиморасчетыСДепонентамиОрганизацийОстатки.Организация = &Организация
И ВзаиморасчетыСДепонентамиОрганизацийОстатки.Физлицо = &Физлицо

Получение значения поля составного типа через точку

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

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

НЕПРАВИЛЬНО:

ВЫБРАТЬ
НаборЗаписей.Регистратор.Дата,
НаборЗаписей.Количество
ИЗ
РегистрНакопления.ТоварыОрганизации КАК НаборЗаписей

Т.е по факту вот такой запрос будет обращаться не к одной таблице, а к 22 таблицам базы данных (у этого регистра 21 тип регистратора).

ПРАВИЛЬНО:

ВЫБРАТЬ
ВЫБОР
КОГДА ТоварыОрг.Регистратор ССЫЛКА Документ.РеализацияТоваровУслуг
ТОГДА ВЫРАЗИТЬ(ТоварыОрг.Регистратор КАК Документ.РеализацияТоваровУслуг).Дата
КОГДА ТоварыОрг.Регистратор ССЫЛКА Документ.ПоступлениеТоваровУслуг
ТОГДА ВЫРАЗИТЬ(ТоварыОрг.Регистратор КАК Документ.ПоступлениеТоваровУслуг).Дата
КОНЕЦ КАК Дата,
ТоварыОрг.Количество
ИЗ
РегистрНакопления.ТоварыОрганизаций КАК ТоварыОрг

Либо второй вариант – добавление такой информации в реквизит, например, в нашем случае – добавление даты.

ПРАВИЛЬНО:

ВЫБРАТЬ
ТоварыОрганизаций.Дата,
ТоварыОрганизаций.Количество
ИЗ
РегистрНакопления.ТоварыОрганизаций КАК ТоварыОрганизаций

Подзапросы в условии соединения

Для оптимизации недопустимо использовать подзапросы в условиях соединения, это существенно замедляет работу запроса. Желательно в таких случаях использовать ВТ. Для соединения нужно использовать только объекты метаданных и ВТ, предварительно проиндексировав их по полям соединения.

НЕПРАВИЛЬНО:

ВЫБРАТЬ …

ЛЕВОЕ СОЕДИНЕНИЕ (
ВЫБРАТЬ ИЗ РегистрСведений.Лимиты
ГДЕ …
СГРУППИРОВАТЬ ПО …
) ПО …

ПРАВИЛЬНО:

ВЫБРАТЬ …
ПОМЕСТИТЬ Лимиты
ИЗ РегистрСведений.Лимиты
ГДЕ …
СГРУППИРОВАТЬ ПО …
ИНДЕКСИРОВАТЬ ПО …;

ВЫБРАТЬ …
ИЗ Документ.РеализацияТоваровУслуг
ЛЕВОЕ СОЕДИНЕНИЕ Лимиты
ПО …;

Соединение записей с виртуальными таблицами

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

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

Одна из самых распространенных ошибок при составления запросов – использование условий по не индексируемым полям, это противоречитправилам оптимизации запросов. СУБД не может выполнить запрос оптимально, если в запросе накладывается отбор по неиндексируемым полям. Если же берется временная таблица – также необходимо индексировать поля соединения.

Обязательно для каждого условия должен существовать подходящий индекс. Подходящим является индекс, удовлетворяющий следующим требованиям:

  1. Индекс содержит все поля, перечисленные в условии.
  2. Эти поля находятся в самом начале индекса.
  3. Эти отборы идут подряд, то есть между ними не «вклиниваются» значения, не участвующие в условии запроса.

Если СУБД не подобрал правильные индексы, то будет просканирована таблица полностью – это очень негативно скажется на производительности и может привести к продолжительной блокировке всего набора записей.

Использование логического ИЛИ в условиях

Вот и всё, в данной статье были освещены основы аспекты оптимизации запросов, которые должен знать каждый эксперт 1С.

Очень полезный бесплатный видеокурс по разработке и оптимизации запросов, категорически рекомендую новичкам и не только!