Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2005.12.04;
Скачать: [xml.tar.bz2];

Вниз

Как выполнить скрипт в ADO из нескольких команд?   Найти похожие ветки 

 
Карелин Артем ©   (2005-10-20 13:50) [0]

Есть к примеру скрипт, состоящий из последовательности SQL-команд, разделенных командой GO, вроде приведенной ниже.
Когда пытаюсь выполнить через метод Execute класса TADOCommand или TADOConnection, происходит исключительная ситуация. Сообщение об ошибке ругается на некорректный синтаксис около команды GO, хотя скрипт правильный.
Можно ли выполнить скрипт из нескольких команд средствами ADO?

IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N"[DICT_AGENT_AD]") AND OBJECTPROPERTY(id, N"IsTrigger") = 1)
 DROP TRIGGER [dbo].[DICT_AGENT_AD]
GO

IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N"[repl_table2_del]") AND OBJECTPROPERTY(id, N"IsTrigger") = 1)
 DROP TRIGGER [dbo].[repl_table2_del]
GO

IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N"[repl_table2_ins]") AND OBJECTPROPERTY(id, N"IsTrigger") = 1)
 DROP TRIGGER [dbo].[repl_table2_ins]
GO


 
Nikolay M. ©   (2005-10-20 14:04) [1]

GO - не оператор T-SQL, а Batch separator, использующийся в QA. Убери его и будет счастье.


 
sniknik ©   (2005-10-20 15:42) [2]

не надо убирать, надо делить по нему на различные команды. т.к. при генерации скрипта например GO делит команды на логические блоки.
т.е. нужно писать свой "выполнитель" скриптов, по тойже логике с какой реализован Query Analyzer.


 
Nikolay M. ©   (2005-10-20 15:44) [3]


> не надо убирать, надо делить

В приведенном примере можно убрать, хуже не будет.


 
Val ©   (2005-10-20 15:46) [4]

>[2] sniknik ©   (20.10.05 15:42)
что за логические блоки? одна транзация?
в скриптах мсскл нет разделителя команды типа ";", "/" ?


 
Карелин Артем ©   (2005-10-20 15:48) [5]

В приведенном можно убрать. Хуже будет если я Create Trigger поставлю после Drop.
Надо все-таки делить.


 
sniknik ©   (2005-10-20 15:48) [6]

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


 
Nikolay M. ©   (2005-10-20 18:02) [7]


> ну, такая лафа не всегда будет

Ну дык тогда и пример надо было пошире дать.
Btw, можно не ломиться в гору, а расставить GO где следует и скормить его на вход osql.ехе.


 
Карелин Артем ©   (2005-10-20 18:11) [8]


> Nikolay M. ©   (20.10.05 18:02) [7]


> Ну дык тогда и пример надо было пошире дать.

Извиняюсь насчет непоказательного примера - особенность Карелин Артем ©  (20.10.05 15:48) [5] была открыта мной после запостения вопроса.


 
Baltika-10   (2005-10-21 01:39) [9]

procedure TForm1.Button4Click(Sender: TObject);
var
   s: String;
begin
   s := "DROP TABLE test_;"+
       "CREATE TABLE test_ (Field1 Int);"+
       "INSERT INTO test_ (Field1) VALUES (1)";
   ADOConnection1.Execute(s);
end;



Страницы: 1 вся ветка

Форум: "Базы";
Текущий архив: 2005.12.04;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.47 MB
Время: 0.034 c
2-1130822835
flatron84
2005-11-01 08:27
2005.12.04
Асемблер и Delphi


14-1131756453
Мазут Береговой
2005-11-12 03:47
2005.12.04
Массмедиа в основном передают ужасные новости...


3-1129812996
DelphiLexx
2005-10-20 16:56
2005.12.04
FIBDataSet и параметр


2-1131916842
Muh
2005-11-14 00:20
2005.12.04
Как создать папку..не файл, а папку!!


2-1132059696
voe
2005-11-15 16:01
2005.12.04
Жизнидеятельность приложений





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский