Estoy intentando crear una tabla SQL Server mediante programación. Aquí está el código.
using (SqlConnection con = new SqlConnection(conStr))
{
try
{
//
// Open the SqlConnection.
//
con.Open();
//
// The following code uses an SqlCommand based on the SqlConnection.
//
using (SqlCommand command = new SqlCommand("CREATE TABLE Customer(First_Name char(50),Last_Name char(50),Address char(50),City char(50),Country char(25),Birth_Date datetime);", con))
command.ExecuteNonQuery();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
Cuando estoy ejecutando esta aplicación por segunda vez estoy recibiendo una excepción:
"Ya existe un objeto llamado 'Cliente' en la base de datos"
pero cuando compruebo la base de datos no veo dicha tabla.
Esta es mi cadena de conexión.
<connectionStrings>
<add name ="AutoRepairSqlProvider" connectionString=
"Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\AutoRepairDatabase.mdf;
Integrated Security=True;User Instance=True"/>
</connectionStrings>
Cuando estoy ejecutando select query; Estoy obteniendo resultados de las tablas existentes por lo que creo que la cadena de conexión debe estar bien. Espero que vea el problema :/
No ha mencionado el nombre del Catálogo inicial
en la cadena de conexión. Indique el nombre de su base de datos como Catálogo inicial
.
<add name ="AutoRepairSqlProvider" connectionString=
"Data Source=.\SQLEXPRESS; Initial Catalog=MyDatabase; AttachDbFilename=|DataDirectory|\AutoRepairDatabase.mdf;
Integrated Security=True;User Instance=True"/>
Para la gestión de objetos de base de datos en SQL Server me gustaría sugerir el uso de Server Management Objects
Prueba esto
Compruebe si la tabla existe y elimínela, a continuación, cree
using (SqlCommand command = new SqlCommand("IF EXISTS (
SELECT *
FROM sys.tables
WHERE name LIKE '#Customer%')
DROP TABLE #Customer CREATE TABLE Customer(First_Name char(50),Last_Name char(50),Address char(50),City char(50),Country char(25),Birth_Date datetime);", con))