You've already forked OpenIntegrations
mirror of
https://github.com/Bayselonarrend/OpenIntegrations.git
synced 2025-11-27 22:18:36 +02:00
110 lines
6.4 KiB
Plaintext
Vendored
110 lines
6.4 KiB
Plaintext
Vendored
---
|
|
sidebar_position: 4
|
|
description: Выполнить запрос SQL и другие функции для работы с MS SQL в Открытом пакете интеграций - бесплатной open-source библиотеке интеграций для 1С:Предприятие 8, OneScript и CLI
|
|
keywords: [1C, 1С, 1С:Предприятие, 1С:Предприятие 8.3, API, Интеграция, Сервисы, Обмен, OneScript, CLI, MS SQL]
|
|
---
|
|
|
|
import Tabs from '@theme/Tabs';
|
|
import TabItem from '@theme/TabItem';
|
|
|
|
# Выполнить запрос SQL
|
|
Выполняет произвольный SQL запрос
|
|
|
|
|
|
|
|
`Функция ВыполнитьЗапросSQL(Знач ТекстЗапроса, Знач Параметры = "", Знач ФорсироватьРезультат = Ложь, Знач Соединение = "", Знач Tls = "") Экспорт`
|
|
|
|
| Параметр | CLI опция | Тип | Обяз. | Назначение |
|
|
|-|-|-|-|-|
|
|
| ТекстЗапроса | --sql | Строка | ✔ | Текст запроса к базе |
|
|
| Параметры | --params | Массив Из Произвольный | ✖ | Массив позиционных параметров запроса |
|
|
| ФорсироватьРезультат | --force | Булево | ✖ | Включает попытку получения результата, даже для не SELECT запросов |
|
|
| Соединение | --dbc | Строка, Произвольный | ✖ | Соединение или строка подключения |
|
|
| Tls | --tls | Структура Из КлючИЗначение | ✖ | Настройки TLS, если необходимо. См. ПолучитьНастройкиTls |
|
|
|
|
|
|
Возвращаемое значение: Соответствие Из КлючИЗначение - Результат выполнения запроса
|
|
|
|
<br/>
|
|
|
|
:::tip
|
|
Параметры запроса указываются как массив структур вида `{'Тип данных': 'Значение'}`. Список доступных типов описан на начальной странице документации библиотеки MSSQL
|
|
|
|
Без указания флага `ФорсироватьРезультат`, чтение результата осуществляется только для запросов, начинающихся с `SELECT` Для остальных запросов возвращается `result:true` или `false` с текстом ошибки
|
|
:::
|
|
<br/>
|
|
|
|
|
|
|
|
```bsl title="Пример использования для 1С:Предприятие/OneScript"
|
|
ТекущаяДата = OPI_Инструменты.ПолучитьТекущуюДату();
|
|
Картинка = "https://hut.openintegrations.dev/test_data/picture.jpg";
|
|
OPI_ПреобразованиеТипов.ПолучитьДвоичныеДанные(Картинка); // Картинка - Тип: ДвоичныеДанные
|
|
|
|
Адрес = "127.0.0.1";
|
|
Логин = "SA";
|
|
Пароль = "12we...";
|
|
База = "test_data";
|
|
|
|
НастройкиTLS = OPI_MSSQL.ПолучитьНастройкиTls(Истина);
|
|
СтрокаПодключения = OPI_MSSQL.СформироватьСтрокуПодключения(Адрес, База, Логин, Пароль);
|
|
Соединение = OPI_MSSQL.ОткрытьСоединение(СтрокаПодключения, НастройкиTLS);
|
|
|
|
// CREATE
|
|
|
|
ТекстЗапроса = "
|
|
|CREATE TABLE test_table (
|
|
| ID INT PRIMARY KEY,
|
|
| FirstName NVARCHAR(50),
|
|
| LastName NVARCHAR(50),
|
|
| BirthDate DATE,
|
|
| IsEmployed BIT,
|
|
| Salary DECIMAL(10, 2),
|
|
| CreatedAt DATETIME,
|
|
| Age SMALLINT,
|
|
| RowGuid UNIQUEIDENTIFIER,
|
|
| Data VARBINARY(MAX)
|
|
|);";
|
|
|
|
Результат = OPI_MSSQL.ВыполнитьЗапросSQL(ТекстЗапроса, , , Соединение);
|
|
|
|
// INSERT с параметрами
|
|
|
|
ТекстЗапроса = "
|
|
|INSERT INTO test_table (ID, FirstName, LastName, BirthDate, IsEmployed, Salary, CreatedAt, Age, RowGuid, Data)
|
|
|VALUES (@P1, @P2, @P3, @P4, @P5, @P6, @P7, @P8, @P9, @P10);";
|
|
|
|
МассивПараметров = Новый Массив;
|
|
МассивПараметров.Добавить(Новый Структура("INT" , 1));
|
|
МассивПараметров.Добавить(Новый Структура("NVARCHAR", "Vitaly"));
|
|
МассивПараметров.Добавить(Новый Структура("NVARCHAR", "Alpaca"));
|
|
МассивПараметров.Добавить(Новый Структура("DATE" , ТекущаяДата));
|
|
МассивПараметров.Добавить(Новый Структура("BIT" , Истина));
|
|
МассивПараметров.Добавить(Новый Структура("DECIMAL" , 10.30));
|
|
МассивПараметров.Добавить(Новый Структура("DATETIME", ТекущаяДата));
|
|
МассивПараметров.Добавить(Новый Структура("SMALLINT", 20));
|
|
МассивПараметров.Добавить(Новый Структура("UUID" , Новый УникальныйИдентификатор));
|
|
МассивПараметров.Добавить(Новый Структура("BYTES" , Картинка));
|
|
|
|
Результат = OPI_MSSQL.ВыполнитьЗапросSQL(ТекстЗапроса, МассивПараметров, , Соединение);
|
|
|
|
// SELECT (Результат этого запроса приведен в следующем блоке)
|
|
|
|
ТекстЗапроса = "SELECT FirstName, LastName, BirthDate, IsEmployed, Salary, CreatedAt, Age, RowGuid, Data FROM test_table;";
|
|
|
|
Результат = OPI_MSSQL.ВыполнитьЗапросSQL(ТекстЗапроса, , , Соединение);
|
|
|
|
// SQL запрос из файла
|
|
|
|
ФайлSQL = "https://hut.openintegrations.dev/test_data/TEST_DATA2.sql"; // Двоичные данные, URL или путь к файлу
|
|
|
|
Результат = OPI_MSSQL.ВыполнитьЗапросSQL(ФайлSQL, , , Соединение);
|
|
|
|
Закрытие = OPI_MSSQL.ЗакрытьСоединение(Соединение);
|
|
```
|
|
|
|
|
|
|
|
|
|
|