Удалить базу данных Postgresql
Я пытаюсь удалить базу данных из aspnet(C#). Но это дает мне ошибку: есть некоторые связи. Если я удаляю все соединения:
SELECT pg_terminate_backend (pg_stat_activity.pid) FROM pg_stat_activity
WHERE pg_stat_activity.pid <> pg_backend_pid() and pg_stat_activity.datname = 'databsename';
Это дает мне еще одну ошибку: соединение потеряно.
Это как если бы я выполнил предложение выше, это закрывает все мои соединения.
Я использую npgsql в качестве разъема.
Вот мой код: код внутри кнопки:
NpgsqlConnection _connPgComienzo = new NpgsqlConnection("my_connection_to_other_DDBB_in_the_same_server;");
try
{
_connPgComienzo.Open();
FileInfo file1 = new FileInfo(Server.MapPath("desconectar.sql"));
string script_crear_bbdd = file1.OpenText().ReadToEnd();
var m_createdb_cmd1 = new NpgsqlCommand(script_crear_bbdd, _connPgComienzo);
m_createdb_cmd1.ExecuteNonQuery();
_connPgComienzo.Close();
_connPgComienzo.Open();
FileInfo file2 = new FileInfo(Server.MapPath("drop_bbdd.sql"));
string script_crear_bbdd2 = file2.OpenText().ReadToEnd();
var m_createdb_cmd2 = new NpgsqlCommand(script_crear_bbdd2, _connPgComienzo);
m_createdb_cmd2.ExecuteNonQuery();
_connPgComienzo.Close();
}
catch (Exception ex)
{
}
desconectar.slq:
SELECT pg_terminate_backend (pg_stat_activity.pid) FROM pg_stat_activity
WHERE pid <> pg_backend_pid() AND pg_stat_activity.datname = 'theDDBBIWantToDrop';
drop_bbdd.sql:
DROP DATABASE theDDBBIWantToDrop;
1 ответ
*Попробуй использовать psql
прекратить ваше postgreSQL database
- для этого вы должны создать
batch file(*.bat)
используя C#, этот файл.bat должен содержать следующий скрипт для разрыва соединения с базой данных
psql -U postgres -d postgres -c ВЫБРАТЬ pg_terminate_backend(pg_stat_activity.pid) FROM pg_stat_activity ГДЕ pg_stat_activity.datname ='yourdb'
Например
Private Sub TerminateDBactivity()
Dim strPG_dumpPath As String
Dim strSub As String
strPG_dumpPath = Application.StartupPath.ToString()
strPG_dumpPath = strPG_dumpPath.Replace("\", "\\")
Dim a As Integer = strPG_dumpPath.IndexOf(":\\", 0)
a = a + 2
strSub = strPG_dumpPath.Substring(0, (a - 2))
strPG_dumpPath = strPG_dumpPath.Substring(a, (strPG_dumpPath.Length - a))
Dim sbSB1 As New StringBuilder(strPG_dumpPath)
sbSB1 = sbSB1.Replace("\\", vbCrLf & vbCrLf & "cd ")
Dim sbSB2 As New StringBuilder("cd /D ")
sbSB2 = sbSB2.Append(strSub)
sbSB2 = sbSB2.Append(":\")
sbSB1 = sbSB2.Append(sbSB1)
sbSB1 = sbSB1.Append(vbCrLf & vbCrLf & "cd PG" & vbCrLf & vbCrLf)
Dim sw As New StreamWriter(Application.StartupPath.ToString() & "\PG\pgTerminate.bat")
If sbSB1.Length <> 0 Then
sbSB1 = sbSB1.Append("psql -U postgres -d postgres -c ""SELECT pg_terminate_backend(pg_stat_activity.pid) FROM pg_stat_activity WHERE pg_stat_activity.datname = '" & gStrDBName & "';")
sw.WriteLine(sbSB1)
sw.Dispose()
sw.Close()
Dim processDB As New ProcessStartInfo
processDB.FileName = Application.StartupPath.ToString() & "\PG\pgTerminate.bat"
processDB.WindowStyle = ProcessWindowStyle.Hidden
Process.Start(processDB).WaitForExit()
Cursor.Current = Cursors.Default
End If
End Sub
этот код создаст
pgTerminate.bat
файл в этом путиD:\Apps\RSTAR PGSQL DOTCONNECT\bin\Debug\PG
pgTerminate.bat
похожеCD /D D:\Apps
cd RSTAR PGSQL DOTCONNECT cd bin cd Debug cd PG psql -U postgres -d postgres -c SELECT pg_terminate_backend(pg_stat_activity.pid) FROM pg_stat_activity WHERE pg_stat_activity.datname = 'mydb';
Примечание: перед тем, как попробовать код, вы должны вручную создать файл bat завершения и проверить, работает ли он или нет