Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
87 / 55 / 15
Регистрация: 01.10.2010
Сообщений: 492

DB2. Ошибки при выполнение скриптов в .Net

06.07.2017, 13:46. Показов 1033. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пробую выполнять скрипт через сторонний редактор скриптов, скрипт проходит на ура. Через OleDb появляются вылетает, жалуясь на синтаксические ошибки.

Пример скрипта:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
CREATE PROCEDURE ADD_ADMINISTRATIVE_DOC_TYPE
    (IN TYPE_NAME_IN VARCHAR(1000),
     IN TYPE_CODE_IN VARCHAR(100))
 
BEGIN ATOMIC
    
    DECLARE NEW_TYPE_ID BIGINT;
    
    -- если не существует не удалённого не устаревшего с таким кодом
    IF NOT EXISTS (SELECT * FROM UPD_ADMINISTRATIVE_DOC_TYPE WHERE (CODE = TYPE_CODE_IN) AND (STATE LIKE 'A@_%'ESCAPE'@')) THEN
 
        -- добавляем 
        INSERT INTO UPD_ADMINISTRATIVE_DOC_TYPE(ADMINISTRATIVE_DOC_TYPE_NAME,CODE)
            VALUES (TYPE_NAME_IN, TYPE_CODE_IN);
        SET NEW_TYPE_ID = IDENTITY_VAL_LOCAL();
    
    END IF;
 
END
Соединение с БД

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
    /// <summary>
    /// Соединение с базой данных
    /// </summary>
    public static class Connection
    {
 
        /// <summary>
        /// Получение соединения DB2
        /// </summary>
        /// <param name="ksDatabaseConfiguration">Конфигурация БД</param>
        /// <returns>Соединение</returns>
        public static OleDbConnection GetConnection(KsDatabaseConfiguration ksDatabaseConfiguration)
        {
            string connectionString = string.Format("Provider=IBMDADB2;Database={0};Hostname={1};Protocol=TCPIP;Port={2};Uid ={3};Pwd={4};", ksDatabaseConfiguration.ActualName, ksDatabaseConfiguration.Host, ksDatabaseConfiguration.Port, ksDatabaseConfiguration.Login, ksDatabaseConfiguration.Password);
            OleDbConnection connection = new OleDbConnection(connectionString);
            connection.Open();
 
            return connection;
        }
 
        /// <summary>
        /// Закрыть соединение DB2
        /// </summary>
        /// <param name="db2Connection">Соединение</param>
        public static void CloseConnection(OleDbConnection db2Connection)
        {
            if (db2Connection != null)
                db2Connection.Close();
        }
    }
Само выполнение скрипта
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
        /// <summary>
        /// Выполнить запрос
        /// </summary>
        /// <param name="query">Запрос</param>
        /// <param name="ksDatabaseConfiguration">Конфигурация БД</param>
        public static void ExecuteNonQuery(string query, KsDatabaseConfiguration ksDatabaseConfiguration)
        {
            OleDbTransaction db2Transaction = null;
            try
            {
                Logger.Log("Выполняется скрипт:");
                Logger.Log(query);
                OleDbConnection oleDbConnection = Connection.GetConnection(ksDatabaseConfiguration);
                db2Transaction = oleDbConnection.BeginTransaction();
                OleDbCommand oleDbCommand = new OleDbCommand(query, oleDbConnection, db2Transaction);
                // Ставим таймаут на 5 минут
                oleDbCommand.CommandTimeout = 300;
                oleDbCommand.ExecuteNonQuery();
                db2Transaction.Commit();
                Logger.Log("Скрипт выполнен успешно");
            }
            catch (Exception ex)
            {
                Logger.Log(ex);
                db2Transaction?.Rollback();
                throw new Exception(ex.Message);
            }

Что-то с этим можно сделать, чтобы не задействовать консоль db2?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.07.2017, 13:46
Ответы с готовыми решениями:

Как продолжить выполнение кода при возникновении System.Net.WebException?
Подскажите , как продолжить выполнение кода пропустив ошибку Ошибка возникает если адрес, указан не верно или машина отключена ...

Выполнение в c# скриптов, написанных на других языках
Доброго времени суток! У меня такой вопрос: предположим, есть строка (string) с кодом, например, на Visual Basic (или C). Можно ли...

Выполнение php скриптов (нужно на сервере поменять дату создания файла)
всем привет такая ситуация нужно на сервере поменять дату создания файла. в C# я так понял нет тако возможности. нотогда вопрос такой. как...

1
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18296 / 14220 / 5368
Регистрация: 17.03.2014
Сообщений: 28,896
Записей в блоге: 1
06.07.2017, 15:05
MDmitry_, какая именно ошибка выдается и как именно ты вызываешь свой метод ExecuteNonQuery? Интересует передача аргумента query
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.07.2017, 15:05
Помогаю со студенческими работами здесь

Пожалуйста подскажите с решением проблемы с окнами ошибки на Windows при выполнении скриптов
Пожалуйста посоветуйте какой командой системного администрирования(bat) можно скрывать сообщения Windows о ошибках с риторическим...

Есть готовый проект на asp.net 2.0 .net 4.5, ошибки при работе с одной из библиотек, нужна консультация
Всем добрый день, Столкнулся с такой ситуацией: есть готовый проект на asp.net 2.0 .net 4.5, есть ошибки при работе с одной из библиотек,...

Выполнение скриптов
Доброго времени всем. Есь такая проблема. Есть приложение, работающее под MS SQL Server 2005. Подскажите как реализовать возможность...

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

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru