-
Создаю временую БД на MSSQL сервере, затем с помощью TADOQuery (ADOQuery2) создаю в базе новую схему. После чего пытаюсь удалить БД - но ничего не получается - говорит используется БД... Я уже и Free и Close делал и через ADOConnection пробовал - все равно соединение висит. Если же создание схемы реализовать через TQuery и вызвать DataBase.Connected := False, то все нормально.... Как победить проблему с ADO?
Request3 := 'IF DB_ID (N''ArcTempDB'') IS NOT NULL DROP DATABASE SomeDB';
Query1.SQL.Text := Request3;
Query1.ExecSQL;
Request1 := 'CREATE DATABASE ArcTempDB COLLATE SQL_Latin1_General_CP1251_CI_AS';
Query1.SQL.Text := Request1;
Query1.ExecSQL;
Request2 := ' CREATE SCHEMA Common';
ADOQuery2.SQL.Text := Request2;
ADOQuery2.ExecSQL;
ADOQuery2.Close;
Database2.Connected := False;
Request3 := 'IF DB_ID (N''ArcTempDB'') IS NOT NULL DROP DATABASE ArcTempDB';
Query1.SQL.Text := Request3;
Query1.ExecSQL;
-
В примере в одном месте необходимо SomeDB заменить на ArcTempDB :-)
-
Перед удалением надо подсоединить используемый ADOConnection к другой, отличной от удаляемой, базе.
-
не обязательно, даже закрывать...
т.к. показанные тут команды делаются изначально из коннекта к другой базе (мастеру к примеру). ну вот как создать базу из коннекта к себе же, еще не существующей? и нет совершенно ничего, что бы захватывало эту.
т.е. как обычно показанные куски кода не имеют никакого отношения к реальной проблеме.
-
ADOConnection переключал на другую базу - не помогает...
Создание базы естественно делается через подключение к другой базе... А создание схемы как раз и захватывает новую созданную базу...
-
> А создание схемы как раз и захватывает новую созданную базу...
каким образом?
CREATE SCHEMA (Transact-SQL)
SQL Server 2008 R2
Другие версии
* SQL Server 2008
* SQL Server 2005
Создает схему в текущей базе данных. При помощи транзакции CREATE SCHEMA также можно создавать таблицы и представления в новой схеме и предоставлять разрешения GRANT, DENY или REVOKE на такие объекты.
а переключений/пере подключений нет (не показано = нет)
проверочное -
DROP SCHEMA
перед попыткой удалить "захваченную" базу
-
вообще описаниями и доказательствами, типа "у меня все правильно, но почему то не работает" ничего не добьешься. ну разве что советов типа "попробуй при другой фазе луны".
КОД !!! который можно проверить/повторить "глюк". вот что реально помогает.
-
На сколько я помню, ADO удерживает соединение какое-то время на случай, если снова подконнектиться надумаешь.
Рулится или нет таймаут - не помню.
-
Ну вобщем решил переводом базы перед удалением в режим SINGLE USER
А по поводу схемы она создается в новой БД.... Просто ADOQuery2 настроен на подключение к новой (создаваемой БД).... А само создание базы данных и удаление производится через другое соединение