Выразить строку как число и строку как дату в запросе

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

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

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

1. Преобразование таблицы строк в таблицу целых чисел. 

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


    "ВЫБРАТЬ Дано.НомерСтроки, Дано.Строка
    |ПОМЕСТИТЬ Дано
    |ИЗ &Дано КАК Дано
    |;
    |ВЫБРАТЬ 0 С,    1 КАК П
    |ПОМЕСТИТЬ Р16
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  1, 10
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  2, 100
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  3, 1000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  4, 10000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  5, 100000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  6, 1000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  7, 10000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  8, 100000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  9, 1000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 10, 10000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 11, 100000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 12, 1000000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 13, 10000000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 14, 100000000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 15, 1000000000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 16, 10000000000000000
    |;
    |ВЫБРАТЬ СУММА(А.П * Б.С) / МИНИМУМ(А.П) КАК Ответ
    |ИЗ Дано, Р16 КАК А, Р16 КАК Б
    |ГДЕ    Б.С < 10 И ПОДСТРОКА(Дано.Строка, 17 - А.С, 1) = ПОДСТРОКА(""0123456789"", Б.С + 1, 1)
    |СГРУППИРОВАТЬ ПО Дано.НомерСтроки"

В пакете всего три запроса.

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

Вся основная работа по преобразованию строки в число выполняется в последнем, третьем запросе пакета. В этом запросе таблица «Дано» умножается на таблицу весов позиций Р16 (КАК А) и еще раз на таблицу Р16 (КАК Б). В последней используется только первые десять строк первой колонки  для прохода по номерам всех цифр строки «0123456789». Условие «ГДЕ» отбирает записи, в которых цифры в исходной строке и строке «0123456789» совпадают в позиции, определяемой для исходной строки строкой таблицы весов А и для строки цифр – строкой таблицы номеров цифр Б. Это дает возможность определить искомое число как сумму произведений веса позиции на номер цифры. При этом группировка идет  по строкам таблицы «Дано».

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

Работа данного запроса иллюстрируется схемой на фиг.1, где показано преобразование в число строки «4957379257».

Схема работы последнего запроса пакета 

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

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

2. Преобразование таблицы строк в таблицу дробных чисел.

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

    "ВЫБРАТЬ Дано.НомерСтроки, Дано.Строка
    |ПОМЕСТИТЬ Дано
    |ИЗ &Дано КАК Дано
    |;
    |ВЫБРАТЬ 0 С,    1 КАК П
    |ПОМЕСТИТЬ Р16
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  1, 10
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  2, 100
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  3, 1000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  4, 10000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  5, 100000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  6, 1000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  7, 10000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  8, 100000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ  9, 1000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 10, 10000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 11, 100000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 12, 1000000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 13, 10000000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 14, 100000000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 15, 1000000000000000
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 16, 10000000000000000
    |;
    |ВЫБРАТЬ СУММА(А.П * Б.С * ВЫБОР КОГДА ПОДСТРОКА(Строка, 1, 17 - А.С) ПОДОБНО ""%.%"" ТОГДА 10 ИНАЧЕ 1 КОНЕЦ)
    |/ МИНИМУМ(ВЫБОР КОГДА НЕ ПОДСТРОКА(Строка, 1, 17 - А.С) ПОДОБНО ""%.%"" ТОГДА А.П ИНАЧЕ 100000000000000000 КОНЕЦ) КАК Ответ
    |ИЗ Дано КАК Дано, Р16 КАК А, Р16 КАК Б
    |ГДЕ    Б.С < 10 И ПОДСТРОКА(Строка, 17 - А.С, 1) = ПОДСТРОКА(""0123456789"", Б.С + 1, 1)
    |СГРУППИРОВАТЬ ПО Дано.НомерСтроки"


Данный пакетный запрос отличается от предыдущего особой обработкой позиций, находящихся справа от первой десятичной точки. Такие позиции выделяются с использованием оператора ПОДОБНО. Проверяется подобие подстроки, заканчивающейся в данной позиции и шаблона "%.%". Для позиций, находящихся правее точки, применяется дополнительный множитель 10. Также меняется определение нормализующего делителя, который находится как минимум веса позиций, не находящихся правее первой точки.

3. Преобразование таблицы строк в таблицу целых чисел с "выращиванием" таблицы весов.

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


    "ВЫБРАТЬ Дано.НомерСтроки, Дано.Строка
    |ПОМЕСТИТЬ Дано
    |ИЗ &Дано КАК Дано
    |;
    |ВЫБРАТЬ 0 КАК С, 1 КАК П
    |ПОМЕСТИТЬ Р1
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 1, 10
    |;
    |ВЫБРАТЬ    А.С + Б.С КАК С, МАКСИМУМ(А.П * Б.П) КАК П
    |ПОМЕСТИТЬ Р2
    |ИЗ Р1 КАК А, Р1 КАК Б
    |СГРУППИРОВАТЬ ПО А.С + Б.С
    |;
    |ВЫБРАТЬ    А.С + Б.С КАК С, МАКСИМУМ(А.П * Б.П) КАК П
    |ПОМЕСТИТЬ Р4
    |ИЗ Р2 КАК А, Р2 КАК Б
    |СГРУППИРОВАТЬ ПО А.С + Б.С
    |;
    |ВЫБРАТЬ    А.С + Б.С КАК С, МАКСИМУМ(А.П * Б.П) КАК П
    |ПОМЕСТИТЬ Р8
    |ИЗ Р4 КАК А, Р4 КАК Б
    |СГРУППИРОВАТЬ ПО А.С + Б.С
    |;
    |ВЫБРАТЬ    А.С + Б.С КАК С, МАКСИМУМ(А.П * Б.П) КАК П
    |ПОМЕСТИТЬ Р16
    |ИЗ Р8 КАК А, Р8 КАК Б
    |СГРУППИРОВАТЬ ПО А.С + Б.С
    |;
    |ВЫБРАТЬ СУММА(А.П * Б.С) / МИНИМУМ(А.П) КАК Ответ
    |ИЗ Дано, Р16 КАК А, Р16 КАК Б
    |ГДЕ    Б.С < 10 И ПОДСТРОКА(Дано.Строка, 17 - А.С, 1) = ПОДСТРОКА(""0123456789"", Б.С + 1, 1)
    |СГРУППИРОВАТЬ ПО Дано.НомерСтроки"


В этом пакетном запросе семь подзапросов.

Первый запрос, как всегда, осуществляет ввод данных.

Во втором запросе пакета определяется таблица Р1 для позиций 0 и 1 с весом 1 и 10. Затем в третьем запросе перемножением Р1 на себя получается таблица Р2, содержащая позиции 0, 1 и 2 с весом 1, 10 и 100. В четвертом запросе перемножением Р2 на себя получается  таблица Р4. Схема этого умножения показана на фиг.2. В пятом запросе пакета Р4 умножается на себя и получается Р8, в шестом Р8 умножается на себя и получается Р16. При перемножении используется группировка по сумме номера позиции с агрегацией в виде максимума произведения весов позиций. Поскольку число позиций каждый раз увеличивается вдвое,  для выращивания итоговой таблицы из 17 строк понадобилось всего четыре запроса. Похожая «математика» используется в статье "Транзитивное замыкание запросом" [//infostart.ru/public/158512/]. Все получаемые таблицы изображены на фиг.3.

Схема умножения таблиц при выращивании таблицы весов

Рост таблиц весов

4. Преобразование таблицы строк в таблицу дат. 

Преобразование таблицы строк вида «ГГГГММДД» в таблицу дат можно выполнить следующим пакетным запросом.

    "ВЫБРАТЬ Дано.НомерСтроки, Дано.Строка
    |ПОМЕСТИТЬ Дано
    |ИЗ &Дано КАК Дано
    |;
    |ВЫБРАТЬ 0 Х, 0 Д, 0 М, 1000 Г
    |ПОМЕСТИТЬ Формат
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 1, 0, 0, 100
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 2, 0, 0, 10
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 3, 0, 0, 1
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 4, 0, 10, 0
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 5, 0, 1, 0
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 6, 10, 0, 0
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 7, 1, 0, 0
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 8, 0, 0, 0
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 9, 0, 0, 0
    |;
    |ВЫБРАТЬ ДОБАВИТЬКДАТЕ(ДОБАВИТЬКДАТЕ(ДОБАВИТЬКДАТЕ(ДАТАВРЕМЯ(1,1,1,0,0,0),ДЕНЬ,СУММА(А.Д*Б.Х)-1),МЕСЯЦ,СУММА(А.М*Б.Х)-1),ГОД,СУММА(А.Г*Б.Х)-1) КАК Ответ
    |ИЗ Дано, Формат КАК А, Формат КАК Б
    |ГДЕ    А.Х < 8 И Б.Х < 10 И ПОДСТРОКА(Дано.Строка, А.Х + 1, 1) = ПОДСТРОКА(""0123456789"", Б.Х + 1, 1)
    |СГРУППИРОВАТЬ ПО Дано.НомерСтроки"

 

 

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

Во втором запросе определяется временная таблица "Формат" с четырьмя колонками. В колонке "Х" записывается номер позиции в строке, начиная с нуля слева направо, в колонке "Д" - вес позиции при подсчете числа дней, "М" - месяцев, "Г" - лет. В последнем запросе вычисляется сумма произведений каждой колонки на номер цифры, находящейся в соответствующей позиции. Далее эти суммы произведений как число лет, месяцев и дней добавляются функцией добавить к дате сначала к "нулевому дню" '00010101', потом к результату первого добавления, а затем к результату второго. Это и дает в итоге искомую дату.

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

 

5. Преобразование таблицы строк в таблицу дат с "выращиванием" таблицы позиций.

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


    "ВЫБРАТЬ Дано.НомерСтроки, Дано.Строка
    |ПОМЕСТИТЬ Дано
    |ИЗ &Дано КАК Дано
    |;
    |ВЫБРАТЬ    0 КАК Х
    |ПОМЕСТИТЬ Р1
    |ОБЪЕДИНИТЬ ВЫБРАТЬ 1
    |;
    |ВЫБРАТЬ    А.Х + 2 * Б.Х КАК Х
    |ПОМЕСТИТЬ Р2
    |ИЗ Р1 КАК А, Р1 КАК Б
    |;
    |ВЫБРАТЬ    А.Х + 4 * Б.Х КАК Х
    |ПОМЕСТИТЬ Р4
    |ИЗ Р2 КАК А, Р2 КАК Б
    |;
    |ВЫБРАТЬ ДОБАВИТЬКДАТЕ(
    |           ДОБАВИТЬКДАТЕ(
    |               ДОБАВИТЬКДАТЕ(
    |                   ДАТАВРЕМЯ(1, 1, 1, 0, 0, 0)
    |                   , ДЕНЬ
    |                   , СУММА(ВЫБОР А.Х КОГДА 7 ТОГДА 1 КОГДА 6 ТОГДА 10 КОНЕЦ * Б.Х) - 1
    |               )
    |               , МЕСЯЦ
    |               , СУММА(ВЫБОР А.Х КОГДА 5 ТОГДА 1 КОГДА 4 ТОГДА 10 КОНЕЦ * Б.Х) - 1
    |           )
    |           , ГОД
    |           , СУММА(ВЫБОР А.Х КОГДА 3 ТОГДА 1 КОГДА 2 ТОГДА 10 КОГДА 1 ТОГДА 100 КОГДА 0 ТОГДА 1000 КОНЕЦ * Б.Х) - 1
    |       ) КАК Ответ
    |ИЗ Дано, Р4 КАК А, Р4 КАК Б
    |ГДЕ    А.Х < 8 И Б.Х < 10 И ПОДСТРОКА(Дано.Строка, А.Х + 1, 1) = ПОДСТРОКА(""0123456789"", Б.Х + 1, 1)
    |СГРУППИРОВАТЬ ПО Дано.НомерСтроки"


В отличие от предыдущих запросов, здесь не используется определение веса позиций заранее. Веса позиций определяются в ходе суммирования. Поэтому заранее достаточно вырастить таблицу позиций цифр Р16. Это делается также как в статье "Порождающий запрос" [//infostart.ru/public/90367/] из таблицы Р2, содержащей 0 и 1, задаваемой вторым запросом пакета. Сначала Р2 умножается на себя и без группировок получается Р4 из четырех строк 0, 1, 2 и 3 (третий запрос), затем Р4 умножается на себя и получается Р16 из 16-ти строк 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14 и 15 (четвертый запрос пакета). Умножение матрицы Р4 на себя в четвертом запросе показано в виде схемы фиг.4.

Схема умножения таблиц при выращивании таблицы позиций

Вся основная работа выполняется в пятом запросе. Год в виде числа, месяц в виде числа и день в виде числа получаются как сумма произведений номера цифры на вес позиции. Вес позиций определяется для каждого элемента даты отдельно при помощи оператора «ВЫБОР». Определенные год, месяц и день подставляются в функции «ДОБАВИТЬКДАТЕ», что и дает в итоге искомую дату.

6. Преобразование таблицы строк в таблицу дат со временем по формату, задаваемом параметром запроса. 


При анализе запроса 4 можно увидеть, что формат даты задается таблицей весов позиций года, месяца и дня «Формат». Эту таблицу можно дополнить колонками для часов, минут и секунд. При различном заполнении этой таблицы можно анализировать даты, представленные в самом различном формате. Примеры заполнения таблицы "Формат" для различных форматов даты приведены на фиг.5.

Содержание таблицы  

В связи с эти возникает идея: А если вообще не задавать таблицу "Формат" заранее, а построить ее внутри запроса путем анализа текстового параметра "&Формат", передаваемого в запрос и определяющего формат даты. Тогда запрос станет чрезвычайно гибким и универсальным. На этой идее построен шестой запрос.

Текст данного запроса, отличающейся универсальностью за счет управления преобразованием с помощью строкового параметра "&Формат", можно посмотреть в прилагаемой к статье обработке. Дополнительным бонусом, скачавшим обработку, будут примеры очень уместного использования (как кажется) функции "НовыйЗапрос" [//infostart.ru/public/163853/] в модуле обработки. На скриншотах, прилагаемых к статье,  приведены примеры преобразований при задании различных форматов даты. В определении формата использованы русские букы "Г", "М", "Д", "Ч", "Н" и "С". Важно, что позиции минут обозначены не маленькой русской "м", а русской "н", поскольку в запросе нет возможности различить регистр символов. Для заполнения незначащих позиций можно использовать любые другие символы. Примеры задания формата: "ГГГГММДДЧЧННСС", "ДД_ММ_ГГГГ_ЧЧ:НН:СС", "ССССС - тоже работает". 

Заключение.

 

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

Скачать файлы

Наименование Файл Версия Размер
Обработка для тестирования запросов
.erf 11,28Kb
22.01.13
89
.erf 11,28Kb 89 Скачать

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

Вознаграждение за ответ
Показать полностью
Комментарии
Избранное Подписка Сортировка: Древо
1. Ёпрст 1036 24.01.13 10:47 Сейчас в теме
До чего только 1с-ина не доводит, всего лишь не реализовав простейший cast и convert в текстах запроса.
Сплошное извращение.
vladimirmatancev; oninfostart; TankO_o; KazanKokos; websamson; NN2P; Восьмой; Lem0n; KoldunOne; корум; igo1; madonov; Varsaavius; Nelli_A86; Spacer; PhoenixAOD; EMelihoff; maljaev; sstas007; Serg3141; evillit; Sanario; zqzq; baton_pk; CratosX; AllexSoft; JohnyDeath; logos; yuraos; OVladius; sh4d0w; Hany; _also; andrewks; +34 Ответить
3. Поручик 4363 24.01.13 11:51 Сейчас в теме
(1) Может вам ещё replace и insert с пивом подать?
5. Ёпрст 1036 24.01.13 12:44 Сейчас в теме
(3) а что в этом плохого ?
Всё жлу, мот кто сподобится хотя бы под скуль написать вк для прямой записи в таблички с метапарсером и типизацией, как в клюшках. (вилдфайре не предлагать)
28. yuraos 959 28.03.13 08:44 Сейчас в теме
(1) Ёпрст,
много что не реализовали...
например хотя бы простейшие строковые функции
LTRIM() и RTRIM()
---
не будем грузить разработчиков платформы
функцией ALLTRIM()
которой почему-то в T-SQL у Микрософта нет.
29. andrewks 1273 28.03.13 08:52 Сейчас в теме
(28) yuraos, я думаю, разработчики платформы и так не слишком загрузились ))
AllexSoft; yuraos; +2 Ответить
30. yuraos 959 28.03.13 18:57 Сейчас в теме
(29) andrewks,
ну думаю они даже очень загрузились в последнее время ...
...
только не тем, что нас простых смертых
(и довольно грешных) интересует.

Все в каких-то ОБЛАКАХ ВИТАЮТЬ !!!
:)
Rabot; tindir; +2 Ответить
47. pavlinuh 29.01.15 16:36 Сейчас в теме
(1)(1)(39) В учебниках "Алгебра и начала анализа" конца 80-х - начала 90-х для 10/11 классов этот раздел назывался "комбинаторика". В современных учебных пособиях, в зависимости от издания/автора, он называется "введение в теорию вероятности", "теория вероятности", "логические задачи" и т.п.
Что там в институтах - не в курсе.
2. Поручик 4363 24.01.13 11:46 Сейчас в теме
(0) Почему-то мне нравятся твои работы. Что-то уже применял в рабочих проектах.
4. wunderland 201 24.01.13 12:27 Сейчас в теме
да, некоторых функций SQL иногда не хватает, и за такие вот статьи большой (+)
6. Созинов 25.01.13 11:56 Сейчас в теме
Может вопрос глупый, но все же. Не ткнете носом, что необходимо освежить в памяти из области математики, чтобы лучше понимать такие запросы?
7. andrewks 1273 25.01.13 13:34 Сейчас в теме
(6) EfiopReal, из математики - почти ничего. ну, разве только матрицы и операции над ними
8. Hany 25.01.13 13:39 Сейчас в теме
(6) EfiopReal, дискретная математика, что-то из мат. анализа. Диф. ур. не надо.
Созинов; +1 Ответить
9. andrewks 1273 25.01.13 13:42 Сейчас в теме
(8) Hany, не расскажете поподробнее про мат.анализ?
11. ildarovich 6884 25.01.13 16:04 Сейчас в теме
(6) Основой описанных преобразований является небанальная арифметика (то есть раздел математики, изучающий числа, их отношения и свойства). В школе такую «арифметику» проходят на информатике. Тема называется «системы счисления». В Вузе предмет, включающий эту тему, может называться «Арифметические и логические основы вычислительной техники».
Также хорошо бы уметь работать с матрицами и векторами. Тогда будут более понятны суммы произведений. В школьной программе матриц вроде бы нет (возможно, их изучают в математических классах). В Вузе матрицы встречаются во многих курсах, но раньше всего, наверное, в курсе «Линейная алгебра».
Не пропустите комбинаторику. Научитесь считать варианты. Не знаю, насколько часто этот раздел изучается отдельно, но он наверняка есть в «теории вероятностей», а это самый «практичный» (на мой взгляд) раздел математики. В рамках теории вероятностей можно познакомиться с необходимой частью теории множеств.
От теории множеств недалеко до реляционной алгебры – это основа табличных (реляционных) баз данных. Хотя, возможно, сама теория на каждый день не так уж и нужна.
Ну и еще одна смежная дисциплина – «теория графов». Это очень популярная абстрактная модель, на основе которой можно формулировать и решать многие практические задачи.
user622032_iif1992; Dain; NittenRenegade; AzagTot; mairon; Zabava_; user597574_avarius007; forrain@rambler.ru; xsazar; Dozkni; adva; CratosX; SeiOkami; SirYozha; Созинов; +15 Ответить
19. Созинов 28.01.13 18:22 Сейчас в теме
(11) Спасибо большое, с первой половиной более менее могу разобраться, а вот вторую придется подтянуть.
12. bogdan_sukonnov 57 28.01.13 10:49 Сейчас в теме
в тексте описания примера упоминается строка "4957379257", а в примере разбирается 4957379252
13. ildarovich 6884 28.01.13 10:57 Сейчас в теме
(12) Спасибо! Вы очень внимательны. Поправлю поясняющий рисунок, когда буду обновлять статью.
14. bogdan_sukonnov 57 28.01.13 14:11 Сейчас в теме
тогда заодно поправьте подписи к колонкам в поясняющей таблице - насколько я понял, перепутаны местами А.П и А.С. Это, конечно, мелочи - статья замечательная, спасибо! Никак не могу понять как это работает, а самое главное, научиться самому писать такие запросы :(
Гриффин; ildarovich; +2 Ответить
15. bogdan_sukonnov 57 28.01.13 14:19 Сейчас в теме
интересно, что "1а2а3" преобразует к 10203 - как-то не очень хорошо
16. ildarovich 6884 28.01.13 14:32 Сейчас в теме
(15) Интерпретация ошибочных данных (здесь в запись числа вкрался не цифровой символ) требует до-определения правил преобразования. Их нетрудно внести в запрос, сделав это по примеру запроса №2. Реализованная интерпретация как кажется, имеет право на жизнь. Например, если столбик чисел Вы получили сканированием текста. Не распознанные цифры заменяются "0". В этом есть своя логика. Можно вообще отказываться от преобразования, обнаружив не цифровой символ. Но это уже детали.
17. bogdan_sukonnov 57 28.01.13 14:45 Сейчас в теме
наконец, осилил первый пример! Не стоит ли в целях облегчения понимания сделать отдельную таблицу "Б" с цифрами от 1 до 9? Плюс это поможет тем, кто будет преобразовывать строки длиной <10 (а я пытался переписать запрос на строку 3 символа - без отдельной таблицы "Б" никак). К тому же это, наверное, сократит количество комбинаций "А" и "Б", особенно для длинных строк "А". Ну и совсем было бы по 1С-овски дать осмысленные названия этим таблицам. Я понимаю, что программисты должны знать математику и т.д. Но почему бы не сделать людям понятнее?
18. ildarovich 6884 28.01.13 15:21 Сейчас в теме
(17) Отдельную таблицу заводить не хочется из эстетических соображений. Текст запроса в этом случае неминуемо станет длиннее. Предупредить о том, что таблица позиций и их весов должна иметь минимум ДЕСЯТЬ записей (таблица Б должна быть позволять пробегать и цифру "0"! Это важно), наверное, нужно . Проигрыш по времени из-за использования одной таблицы заключается в проверке ГДЕ, выполняемой ПЕРЕД соединением. Поэтому он НЕЗНАЧИТЕЛЕН. Над осмысленными именами таблиц я подумаю. Они нужны, согласен. С другой стороны, мне в другой публикации в качестве идеального решения приводили текст запроса для Postgre. Там имена таблиц и полей все состояли из одной латинской буквы и выглядело это действительно кратко и ясно. Так что тут одно из двух - либо математически коротко, чтобы запрос можно охватить одним взглядом, либо содержательные названия полей и таблиц.
20. akomar 436 29.01.13 18:07 Сейчас в теме
Но согласитесь запросы красиво смотрятся, пирамиды Хеопса)
21. Crush 30.01.13 11:13 Сейчас в теме
Замечательная статья! Спасибо большое!
Распечатал и добавил в избранное:)
22. It-developer 20 30.01.13 16:41 Сейчас в теме
Жесть. Сложно представить что это можно использовать. Типа сделать процедуру, а в нее передавать строковые числа? Не знаю, это может быть актуально для запроса, но передавать таблицу, а потом ее откуда-то получать не очень удобно
23. ildarovich 6884 30.01.13 18:18 Сейчас в теме
(22) Конечно,
это может быть актуально для запроса
. Вне запроса никаких проблем преобразования, конечно же, нет. Вас, видимо, смутил первый запрос в пакете. Он нужен ИСКЛЮЧИТЕЛЬНО ДЛЯ ТЕСТИРОВАНИЯ этих методов. Считается, что в реальных задачах строки, которые нужно преобразовать в числа или даты, берутся НЕПОСРЕДСТВЕННО из информационной базы. Возможно, нужно было подчеркнуть этот момент в самой статье.
24. ADirks 181 01.02.13 10:37 Сейчас в теме
Возможно, нужно было подчеркнуть этот момент в самой статье.

Если человек хотя бы примерно понимает, как это работает, то наверное поймёт и как использовать :)
25. ilov_boris 158 01.02.13 15:40 Сейчас в теме
Полезные сведения. Спасибо
26. alxbzm 06.02.13 18:23 Сейчас в теме
На Postgre 9 не работает к сожалению. Запрос падает с ошибкой function substr(...) does not exist. Именно на вычислении выражения ПОДТСТРОКА(...). Жаль, но сама идея запроса отличная.
31. a-novoselov 1098 04.06.13 18:27 Сейчас в теме
(26) Возможно у вас Postgre под 1С не патченый? Есть специальные сборки от EterSoft, в которых таких ошибок не возникает. Либо официальный патч от 1С (на официальном сайте выложен), но ни кто не дает гарантии что вы все правильно пропатчите... И патч, обычно, не для самых последних версий Postgre.
27. Andry.Boris 55 22.02.13 02:39 Сейчас в теме
32. Al-X 20.06.13 13:23 Сейчас в теме
Спасибо за статью. Тоже недавно надо было в запросе преобразовывать строки в числа. Теперь буду знать, КАК ПРАВИЛЬНО ДЕЛАТЬ.
33. Synoecium 673 28.08.13 11:11 Сейчас в теме
Качественная подача материала, спасибо.
34. Kesr 11.09.13 11:40 Сейчас в теме
Отличная идея. У меня как раз возникла задача, где придется реализовать 1 вариант.
36. ronhard 20.01.14 16:55 Сейчас в теме
Есть все-таки на свете умные люди.
Это, конечно, мелочи - статья замечательная, спасибо! Никак не могу понять как это работает, а самое главное, научиться самому писать такие запросы :(

Поддерживаю на 100%
37. yura1960 13.06.14 19:12 Сейчас в теме
Хм... С этой стороны я не догадался рассматривать эту проблему. Хотя у меня функции короче и проще, но кое в чем они проигрывают.
Автору спасибо. Попробую поизвращаться. Если реально поможет, то будет огромный СЕНКС!!!
38. Lama12-1 8 09.07.14 13:55 Сейчас в теме
А по какому национальному стандарту происходит преобразование?
39. ildarovich 6884 09.07.14 17:30 Сейчас в теме
(38) Lama12-1, если речь о "национальном стандарте", то, видимо, имеется ввиду преобразование строка -> дата.
Это преобразование задается ФОРМАТНОЙ СТРОКОЙ, которую в примере 6 можно задавать.
В примерах 4 и 5 форматная строка фиксирована. Она имеет вид ГГГГММДД. Например, сегодняшняя дата в этом формате "20140709".
Если вы чуть-чуть разбираетесь в запросах, то сможете составить преобразование под любой формат даты, ну или под тот национальный стандарт, который нужен.
40. chmv 07.08.14 08:37 Сейчас в теме
На самом деле это большая проблема.
До сих пор не могу написать
Выбрать Сотрудник.Наименование+Сотрдуник.ДатаРождения как СотрудникСДатойРождения
Подскажите как это сделать?
41. ildarovich 6884 07.08.14 09:12 Сейчас в теме
(40) chmv, то, что вы хотите, требует преобразования из даты в строку, а в данной статье рассматривается обратное преобразование - из строки в дату. Так, что приемы, описанные в данной статье, напрямую вам не помогут.
42. luic 17.08.14 09:42 Сейчас в теме
Спасибо, очень помогло))
43. evillit 22.10.14 19:56 Сейчас в теме
Полезная статья. В мемориз.
44. chmv 01.12.14 10:40 Сейчас в теме
Спасибо. А попроще нельзя?
45. ildarovich 6884 01.12.14 13:47 Сейчас в теме
(44) chmv, попроще пока не получилось
46. SemenovaMarinaV 27.01.15 14:00 Сейчас в теме
жаль что 1с это не предусмотрела, а то приходится извращаться
48. adva 41 08.06.15 08:58 Сейчас в теме
Иногда для практических целей нужно наоборот получить в запросе вместо числа строку. Имеется ли такое же красивое решение?
49. ildarovich 6884 08.06.15 09:48 Сейчас в теме
50. adva 41 08.06.15 12:38 Сейчас в теме
(49) спасибо, не попадалось ранее, а еще может быть есть статья о том, как пронумеровать в запросе строки (иногда нет номеров строк, а очень хочется, чтобы дальше в запросе использовать, не выгружая в ТЗ)?
51. ildarovich 6884 08.06.15 13:34 Сейчас в теме
(50) adva, это слишком простая задача для статьи. Вот в задаче 14 из статьи Минимализмы для нумерации таблицы дат используется подзапрос
ВЫБРАТЬ 
    Даты.Дата, 
    КОЛИЧЕСТВО(РАЗЛИЧНЫЕ ДатыДо.Дата) КАК Номер 
ПОМЕСТИТЬ НомераДат 
ИЗ 
    ВТДаты КАК Даты 
    ВНУТРЕННЕЕ СОЕДИНЕНИЕ ВТДаты КАК ДатыДо 
        ПО (ДатыДо.Дата < = Даты.Дата) 
СГРУППИРОВАТЬ ПО 
    Даты.Дата 
Показать

Аналогично может быть пронумерована любая другая таблица, в которой есть поле, определяющее порядок строк для нумерации. Если такого поля (набора полей) нет, то задача в запросе не может быть решена. Это принципиальный момент.
Соединение таблицы с собой довольно затратная по времени операция. В некоторых случаях нумерацию можно ускорить за счет того, что нумерация - это тот же нарастающий итог и его можно ускорить как показано в статье Баттерфляй - метод быстрого расчета нарастающего итога в запросе. Но это имеет смысл, только если строк больше 2000 (для SQL).
52. YuriFm 07.07.17 23:22 Сейчас в теме
статья однозначно крутая. использовал запрос для преобразования таблицу строк в таблицу целых чисел, с небольшим изменением. в числе были пробелы, нужно было от них избавиться. однозначно +
Оставьте свое сообщение

См. также

Краткое руководство по внесению изменений в конфигурацию

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

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

1 стартмани

13.01.2020    7093    14    sapervodichka    34       

Программы для исполнения 54-ФЗ Промо

С 01.02.2017 контрольно-кассовая техника должна отправлять электронные версии чеков оператору фискальных данных - правила установлены в 54-ФЗ ст.2 п.2. Инфостарт предлагает подборку программ, связанных с применением 54-ФЗ, ККТ и электронных чеков.

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

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

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

1 стартмани

07.10.2019    16848    8    HostHost    25       

Описание формата внутреннего представления данных 1С в контексте обмена данными

Статья Программист Внешняя обработка (ert,epf) v8 v8::УФ 1cv8.cf Абонемент ($m) Практика программирования Внешние источники данных Разработка

Фирма 1С не рекомендует использовать внутреннее представление данных для любых целей, которые отличны от обмена с 1С:Предприятием 7.7. Но сама возможность заглянуть на "внутреннюю кухню" платформы с помощью функций ЗначениеВСтрокуВнутр(), ЗначениеВФайл(), ЗначениеИзСтрокиВнутр() и ЗначениеИзФайла(), дала возможность сообществу программистов 1С разработать новые приемы разработки и анализа. Так, именно на использовании внутреннего представления был построен алгоритм "быстрого массива", который позволяет практически мгновенно создать массив в памяти на основании строки с разделителями. С помощью разбора внутреннего представления можно "на лету" программным кодом выполнить анализ обычной формы и даже сделать редактор графической схемы. Во внутреннем формате сохраняют свои данные между сеансами различные популярные внешние обработки. А еще это возможность сделать быстрый обмен с внешними системами.

1 стартмани

06.09.2019    9180    7    Dementor    27       

Программы для исполнения 488-ФЗ: Маркировка товаров Промо

1 января 2019 года вступил в силу ФЗ от 25.12.2018 № 488-ФЗ о единой информационной системе маркировки товаров с использованием контрольных (идентификационных) знаков, который позволяет проследить движение товара от производителя до конечного потребителя. Инфостарт предлагает подборку программ, связанных с применением 488-ФЗ и маркировкой товаров.

Конвейер проверки качества кода

Инструменты и обработки Программист Архив с данными v8 1cv8.cf Windows Абонемент ($m) Инструментарий разработчика Практика программирования Математика и алгоритмы

Jenkinsfile для выполнения проверки качества кода. Собирает информацию с АПК, EDT и BSL-LS. Сопоставляет ошибки с гит-репозиторием, выгруженным ГитКонвертором. Отправляет в Сонар.

3 стартмани

04.09.2019    11829    18    Stepa86    44       

Готовые переносы данных из различных конфигураций 1C Промо

Рекомендуем готовые решения для переноса данных из различных конфигураций 1C. C техподдержкой от разработчиков и гарантией от Инфостарт.

Вам нравятся запросы в 1С?

Инструменты и обработки Программист Конфигурация (md, cf) v8 v8::Запросы 1cv8.cf Абонемент ($m) Практика программирования Разработка

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

1 стартмани

03.07.2019    13446    4    m-rv    86       

1С:Ассемблер. Немного летнего веселья!

Статья Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Практика программирования Разработка

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

1 стартмани

21.06.2019    19501    57    Evil Beaver    116       

INFOSTART MEETUP Kazan. 13 марта 2020 г. Промо

Инфостарт продолжает путешествие по России. Следующая остановка - Казань. Тема мероприятия - управление и технологии автоматизации учета на платформе "1С: Предприятие". Ждем всех: докладчиков и участников! Стоимость участия - 5 500 рублей. Цена действительна до 30.01.2020

5 500

Простые примеры сложных отчетов на СКД

Статья Программист Архив с данными v8 v8::СКД 1cv8.cf Абонемент ($m) Практика программирования

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

1 стартмани

12.06.2019    19401    17    Hatson    22       

Безопасная работа с транзакциями во встроенном языке

Статья Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования

Разбираемся с опасностями использования транзакций во встроенном языке 1С. Познаем ошибку "В данной транзакции уже происходили ошибки". Учимся защищаться от них.

1 стартмани

25.03.2019    20955    9    tormozit    44       

Голосование за доклады на INFOSTART MEETUP Kazan - до 25 февраля. Промо

Выбирайте и голосуйте за самые интересные доклады! Лучшие из лучших попадут в окончательную программу казанского митапа. Оставить свой голос можно до 25 февраля 2020 года.

HTML в новой версии 8.3.14 на примере 3-х JavaScript библиотек: AmCharts, HighCharts, DHTMLX

Статья Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Универсальные обработки Практика программирования Разработка

Тестируем возможности HTML в новой версии 8.3.14 платформы на примере 3-х JavaScript библиотек: AmCharts, HighCharts, DHTMLX.

1 стартмани

29.01.2019    18967    77    Synoecium    40       

Подборка программ для взаимодействия с ЕГАИС Промо

ЕГАИС (Единая государственная автоматизированная информационная система) - автоматизированная система, предназначенная для государственного контроля за объёмом производства и оборота этилового спирта, алкогольной и спиртосодержащей продукции. Инфостарт рекомендует подборку проверенных решений для взаимодействия с системой.

Отладка сложных отчетов на СКД

Отчеты и формы Программист Расширение (cfe) v8 v8::СКД 1cv8.cf Россия Абонемент ($m) Практика программирования

Расширение для отладки сложных отчетов на СКД (в т.ч. для собираемых программно "на лету") и быстрого перехода к отладке таких отчетов в консоли запросов и отчетов на СКД.

1 стартмани

28.12.2018    18531    69    maxx    58       

Реализация простого http-сервиса "Просмотр карточки номенклатуры(товара) в браузере"

Статья Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования

Практический пример реализации простого http-сервиса средствами 1С Предприятие 8.3. Обеспечивает просмотр списка товаров и просмотр данных товара в браузере.

1 стартмани

07.12.2018    16730    12    dmitry1975    31       

​​​​​​​CorelDRAW Graphics Suite 2019 Промо

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

Работа с публикациями "Инфостарт"

Инструменты и обработки Программист Архив с данными v8 УУ Абонемент ($m) Практика программирования О сообществе WEB

Работа с рублевыми публикациями на сайте "Инфостарт": ведение клиентов, заказов, обновление файлов публикации, рассылка обновлений.

1 стартмани

13.09.2018    12384    12    RocKeR_13    16       

HTTP Сервисы: Путь к своему сервису. Часть 3

Инструменты и обработки Системный администратор Программист Расширение (cfe) v8 1cv8.cf Абонемент ($m) Инструментарий разработчика Практика программирования

Продолжение статьи «HTTP Сервисы: Путь к своему сервису. Часть 2». В предыдущих частях мы использовали только Get, в этой части поговорим о других методах и длительных операциях.

1 стартмани

27.08.2018    22147    38    dsdred    13       

Подборка решений для взаимодействия со ФГИС «Меркурий» Промо

С 1 июля 2019 года все компании, участвующие в обороте товаров животного происхождения, должны перейти на электронную ветеринарную сертификацию (ЭВС) через ФГИС «Меркурий». Инфостарт предлагает подборку программ, связанных с этим изменением.

Позиционирование в помещении с помощью нейросети по сигналу Wi-Fi. Интерактивная карта склада в 1С с показом позиции

Инструменты и обработки Программист Бизнес-аналитик Приложение (apk) v8 Windows Абонемент ($m) Инструментарий разработчика Практика программирования

Данная публикация содержит в себе редактор и интерактивную карту склада или иного помещения, на которой в реальном времени отображается позиция устройства, координаты которого вычисляются по уровням сигнала нескольких роутеров Wi-Fi. В статье и приложенным к ней разработкам предлагаются инструменты и методика для реализации вычисления точной геопозиции внутри помещений с помощью нейронной сети. Конфигурация написана на релизе 1С:Предприятие 8.3.12.1412, клиентское приложение имеет минимальный уровень совместимости SDK -16.

5 стартмани

09.08.2018    19334    25    informa1555    26       

Работа с данными выбора

Инструменты и обработки Программист Архив с данными v8 Россия Абонемент ($m) Практика программирования Работа с интерфейсом

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

1 стартмани

17.07.2018    29220    17    kalyaka    16       

Онлайн-курс "Подготовка к экзамену 1С:Эксперт и 1С:Профессионал по технологическим вопросам" с 7 по 24 апреля 2020 г. Промо

На курсе вы получите практические навыки решения задач производительности 1С, в том числе характерных для высоконагруженных информационных систем (более 1000 пользователей). Подготовка к экзамену – только одна из составляющих курса. 70% слушателей приходят за знаниями, которые позволят расти и зарабатывать, делать сложные задачи на крупных проектах.

16450 рублей

HTTP Сервисы: Путь к своему сервису. Часть 1

Статья Системный администратор Программист Расширение (cfe) v8 1cv8.cf Абонемент ($m) Практика программирования WEB

Уже много было написано про http-сервисы, но то и дело всплывают «Новые» статьи по обмену между базами V8 по COM, что «Немножко» удивляет. Решил внести свои 5 копеек, поработаем с http-сервисом.

1 стартмани

15.07.2018    52792    23    dsdred    24       

ВСТАВИТЬ В Справочник.Номенклатура (Код, Наименование) ЗНАЧЕНИЯ ("001", "Новый товар")

Инструменты и обработки Программист Внешняя обработка (ert,epf) v8 v8::Запросы 1cv8.cf Абонемент ($m) Практика программирования

Вас не обманывают ваши глаза, это запрос на изменение данных! И это работает без прямого доступа к БД, регистрации и смс.

1 стартмани

01.06.2018    22466    86    m-rv    57       

Управление ИТ-проектами. Модуль 2: продвинутый онлайн-курс по классическим методам управления проектами. Вебинары проходят с 12 марта по 11 июня 2020 года. Промо

Продвинутый онлайн-курс по классическому управлению ИТ-проектами позволит слушателям освоить инструменты из PMBoK® и 1С:Технологии корпоративного внедрения и научиться их применять для проектов любого масштаба. Курс включает в себя 12 вебинаров и 12 видеолекции, разбор кейсов и рекомендации экспертов по проектам слушателей. Ведущая курса - Мария Темчина.

от 13000 рублей

БСП: Дополнительная обработка (Регламенты), примеры от простого к сложному

Статья Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Практика программирования БСП (Библиотека стандартных подсистем)

Очень много попадается странных решений, которые можно решить через БСП:Дополнительные отчеты и обработки. Я бы вообще БСП из-за этой подсистемы переименовал в «Большое Спасибо Программистам». Поработаем с подсистемой в части написания регламентных заданий.

1 стартмани

10.05.2018    33401    31    dsdred    36       

1C:Предприятие для программистов: Расчетные задачи (зарплата). Онлайн-интенсив с 01 по 17 июня 2020 г. Промо

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

4900 рублей

Как выполнить отчет на СКД через COM и получить данные отчета?

Статья Программист Архив с данными v8 УПП1 Россия Windows Абонемент ($m) Практика программирования

Для чего это нужно. Например, нужно в одной базе получить какой-либо показатель из другой базы. Этот показатель вычисляется в каком-либо сложном отчете, который написан на СКД. Можно, конечно, "скопипастить" текст запроса из другой базы, немного подправить его и выполнять в том же COM подключении. Но с этим теряется гибкость: если отчет изменился, то нужно помнить о том, что где-то есть его "немного модифицированная" копия. В статье будет рассмотрен пример получения данных из базы ЗУП.

2 стартмани

08.05.2018    20729    11    wowik    3       

Работа со схемой запроса

Статья Программист Конфигурация (md, cf) v8 v8::Запросы Абонемент ($m) Инструментарий разработчика Практика программирования

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

1 стартмани

24.04.2018    33600    77    kalyaka    34       

1C:Предприятие для программистов: Запросы и отчеты. Второй поток. Онлайн-интенсив с 17 марта по 16 апреля 2020 г. Промо

Данный онлайн-курс предусматривает углубленное изучение языка запросов и возможностей системы компоновки данных, которые понадобятся при разработке отчетов, работающих на платформе “1С:Предприятие” в рамках различных прикладных решений. Курс предназначен для тех, кто уже имеет определенные навыки конфигурирования и программирования в системе “1С:Предприятие”, а также для опытных пользователей различных прикладных решений, которые используют в своей работе отчеты разного назначения.

6500 рублей

Заполняем по шаблону (по умолчанию)

Инструменты и обработки Программист Архив с данными v8 v8::УФ 1cv8.cf Абонемент ($m) Практика программирования

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

1 стартмани

08.02.2018    20258    20    mvxyz    17       

Бесплатная проверка контрагентов в ФНС (общий модуль с алгоритмом). На примере выводим статус в список справочника контрагентов

Статья Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования

Если вам интересно проверить контрагенте в ФНС, вам поможет данная публикация. Весь алгоритм работы строится на основе данных, полученных с сервиса http://npchk.nalog.ru совершенно бесплатно.

1 стартмани

01.02.2018    28576    63    rpgshnik    48