Перевод текста запроса SQL в запрос 1С

16.10.23

База данных - Инструменты администратора БД

Обработка предназначена для перевода запросов извлечённых из SQL в язык запросов 1С. Работает как в управляемых, так и в обычных формах.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Перевод текста запроса SQL в запрос 1С:
.epf 10,64Kb
55 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

 

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

Протестировано на платформе 8.3.18.1289.

Ниже основной текст программы:

Функция ПереведённыйЗапрос() Экспорт
	
	Если ЗначениеЗаполнено(ЗапросSQL) Тогда
		SQL = СокрЛП(ЗапросSQL);
		SQL = СтрЗаменить(SQL, "[", "");
		SQL = СтрЗаменить(SQL, "]", "");
	Иначе
		Возврат "";
	КонецЕсли;
	
	СтруктурБД = ПолучитьСтруктуруХраненияБазыДанных(,Истина);
	
	СоответствиеИмёнТаблиц = Новый ТаблицаЗначений;
	СоответствиеИмёнТаблиц.Колонки.Добавить("ИмяSQL", Новый ОписаниеТипов("Строка"));
	СоответствиеИмёнТаблиц.Колонки.Добавить("Имя1С", Новый ОписаниеТипов("Строка"));
	СоответствиеИмёнТаблиц.Колонки.Добавить("Алиас", Новый ОписаниеТипов("Строка"));
	СоответствиеИмёнТаблиц.Колонки.Добавить("Поля");
	
	Рез = SQL;
	Сч = Найти(Рез, "dbo.");
	
	Пока Сч > 0 Цикл
		
		Остаток = Сред(Рез, Сч+4);
		Алиас = "";
		
		Сч = Найти(Остаток, " ");
		
		Если Сч > 0 Тогда
			ИмяТаблицыSQL = СокрЛП(Лев(Остаток, Сч));
			Алиас = АлиасТаблицыSQL(ИмяТаблицыSQL, Остаток, Сч);
		Иначе
			ИмяТаблицыSQL = СокрЛП(Остаток);
		КонецЕсли;
		
		НовСтр = СоответствиеИмёнТаблиц.Добавить();
		НовСтр.ИмяSQL = "dbo." + ИмяТаблицыSQL;
		
		СтрокаСтруктурыБД = СтруктурБД.НайтиСтроки(Новый Структура("ИмяТаблицыХранения", ИмяТаблицыSQL));
		Если СтрокаСтруктурыБД.Количество() = 1 Тогда
			НовСтр.Имя1С = СтрокаСтруктурыБД[0].ИмяТаблицы;
			НовСтр.Поля = СтрокаСтруктурыБД[0].Поля;
		Иначе
			НовСтр.Имя1С = ИмяТаблицыSQL;
		КонецЕсли;
		
		НовСтр.Алиас = Алиас;
		
		Если ЗначениеЗаполнено(Алиас) Тогда
			Рез = СтрЗаменить(Рез, НовСтр.ИмяSQL + " " + Алиас, НовСтр.Имя1С + " как " + Алиас);
		Иначе
			Рез = СтрЗаменить(Рез, НовСтр.ИмяSQL, НовСтр.Имя1С);
		КонецЕсли;
		
		Сч = Найти(Рез, "dbo.");
		
	КонецЦикла;
	
	Для Каждого Строка Из СоответствиеИмёнТаблиц Цикл
		
		Если ТипЗнч(Строка.Поля) = Тип("ТаблицаЗначений") Тогда
			
			Для Каждого СтрПоле Из Строка.Поля Цикл
				
				Если ЗначениеЗаполнено(Строка.Алиас) Тогда
					ИмяПоляХранения = Строка.Алиас + "." + СтрПоле.ИмяПоляХранения;
					ИмяПоля1С = Строка.Алиас + "." + СтрПоле.ИмяПоля;
				Иначе
					ИмяПоляХранения = СтрПоле.ИмяПоляХранения;
					ИмяПоля1С = СтрПоле.ИмяПоля;
				КонецЕсли;
				
				Рез = СтрЗаменить(Рез, ИмяПоляХранения, ИмяПоля1С);
				
			КонецЦикла;
			
		КонецЕсли;
		
	КонецЦикла;
	
	Рез = СтрЗаменить(Рез, "LEFT OUTER JOIN", "LEFT JOIN");
	Рез = СтрЗаменить(Рез, "OPTION (FAST 1)", "");
	Рез = СтрЗаменить(Рез, "@", "&");
	
	Возврат Рез;

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

Функция АлиасТаблицыSQL(ИмяТаблицыSQL, ОстатокЗапроса, Сч)
	
	Кон = СтрДлина(ОстатокЗапроса);
	Нач = Сч+1;
	Алиас = "";
	
	Для Инд = Нач По Кон Цикл
		
		Врм = Сред(ОстатокЗапроса, Инд, 1);
		
		Если Инд = Нач Тогда
			
			Если Врм = "T" Тогда
				Алиас = "T";
			Иначе
				Прервать;
			КонецЕсли;
			
		Иначе
			
			Если Найти("0123456789", Врм) > 0 Тогда
				Алиас = Алиас + Врм;
			Иначе
				Прервать;
			КонецЕсли;
			
		КонецЕсли;
		
	КонецЦикла;
	
	Возврат Алиас;
	
КонецФункции

 

Вступайте в нашу телеграмм-группу Инфостарт

SQL

См. также

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

14400 руб.

20.08.2024    49698    286    143    

252

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

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

16000 руб.

10.11.2023    20957    86    42    

95

Инструменты администратора БД Роли и права Системный администратор Программист Пользователь 8.3.14 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Документооборот 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Роли… Вы тратите много времени и сил на подбор ролей среди около 2400 в ERP или 1500 в Рознице 2, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 17.06.2025, версия 1.3

20400 руб.

06.12.2023    18763    69    10    

102

Закрытие периода Инструменты администратора БД Корректировка данных Бухгалтер Пользователь Бухгалтерский учет 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Расширение «Оперативное проведение» в 4 раза уменьшает время проведения документов и закрытия месяца. Является комплексным решением проблем 62 и 60 счетов. Оптимизирует проведение при включенной функциональной опции «Раздельный учет НДС». Используется в более 10 организациях уже 2 года. Совместимо с конфигурацией Бухгалтерия 3.0 (+КОРП).

14400 руб.

29.04.2020    40592    124    152    

84

Инструменты администратора БД Системный администратор Программист 1С v8.3 1C:Бухгалтерия Платные (руб)

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

12000 руб.

06.02.2017    34346    147    18    

53

Архивирование (backup) Инструменты администратора БД 1С v8.3 Управляемые формы 1C:Бухгалтерия 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Управление торговлей 11 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Данная разработка позволит решить вопрос с резервным копированием Ваших баз в автоматическом режиме, расположенных на сервере 1С. Система умеет ставить блокировки на вход, блокировать фоновые задания, принудительно отключать сеансы пользователей. И все это система делает в автоматически при создании бэкапа (или через команду). Выгрузка происходит в родной формат 1С - .dt. Так же система умеет архивировать данные выгрузки с установкой пароля. Умеет менять расширение файла zip или dt на любое указанное вами, что позволит сохранить выгрузки от шифровальщика. Может удалять старые копии выгрузок, оставляя указанное количество резервных копий, начиная с самой поздней. Только для WINDOWS!

6000 руб.

06.11.2012    76929    633    45    

91
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. гаврюша 3 16.10.23 18:56 Сейчас в теме
А обратного перевода нет (1С в SQL)?
svbel85; seperblunt2; +2 Ответить
3. sapervodichka 7230 17.10.23 11:02 Сейчас в теме
(1) вот держи
Прикрепленные файлы:
ТрансляторЗапросовИз1СвSQL.epf
akR00b; crazycat; DrAku1a; cleaner_it; webester; maksa2005; гаврюша; acces969; Andreyyy; svbel85; +10 Ответить
5. acces969 378 18.10.23 12:06 Сейчас в теме
(3) Отлично, спасибо. Нужные и удобные инструменты для работы.
2. SerVer1C 993 17.10.23 09:22 Сейчас в теме
Такие конвертеры надо делать с построением абстрактного синтаксического дерева. Чтобы можно было переводить любые запросы.
4. maksa2005 376 18.10.23 06:59 Сейчас в теме
Автор молодец. Спасибо. посмотрел.
Есть конечно особенности из SQL как:
0xAF591CC1DEE6F33211EB8648D9B1DF84

Это реквизит
Прикрепленные файлы:
6. user1647484 9 18.10.23 16:07 Сейчас в теме
сопоставление лучше делать в макете таблицей. очень удобно.
7. 1cembreg 22 19.10.23 10:35 Сейчас в теме
За стартмани так же обработка, я так понимаю что в тексте статьи? Получается MS SQL only, на PostgreSQL не взлетит судя по dbo? Укажите пожалуйста в требованиях
9. Дмитрий74Чел 248 23.10.23 12:35 Сейчас в теме
8. alex_sayan 68 19.10.23 18:23 Сейчас в теме
Для понятности псевдонимы таблиц тоже стоит преобразовать. Все эти Т1, Т2... превращаются в неразборчивое месиво. К т-шкам прилепить имя обьекта, и уже станет гораздо нагляднее

Т7 -> ПользователиТ7
Т8 -> ФизическиеЛицаТ8
AlexSTAL; ong1990; altu71; cleaner_it; +4 Ответить
10. onesec 13.06.24 07:25 Сейчас в теме
Для PostgreSQL бесполезная!
Для отправки сообщения требуется регистрация/авторизация