Я пытаюсь создать таблицу SQL Server программным путем. Вот код.
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);
}
}
Когда я'запускаю это приложение во второй раз, я'получаю исключение:
"В базе данных уже есть объект с именем 'Customer'"
но когда я проверяю базу данных, я не вижу такой таблицы.
Вот моя строка подключения.
<connectionStrings>
<add name ="AutoRepairSqlProvider" connectionString=
"Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\AutoRepairDatabase.mdf;
Integrated Security=True;User Instance=True"/>
</connectionStrings>
Когда я выполняю запрос select, я получаю результаты из существующих таблиц, поэтому я думаю, что строка подключения должна быть в порядке. Надеюсь, вы увидите проблему :/.
Вы не указали имя Инициального каталога
в строке подключения. Укажите имя вашей базы данных в качестве имени Initial Catalog
.
<add name ="AutoRepairSqlProvider" connectionString=
"Data Source=.\SQLEXPRESS; Initial Catalog=MyDatabase; AttachDbFilename=|DataDirectory|\AutoRepairDatabase.mdf;
Integrated Security=True;User Instance=True"/>
Для управления объектами базы данных в SQL Server я бы предложил использовать Server Management Objects.
Попробуйте это
Проверьте, есть ли там таблица, и отбросьте ее, затем создайте
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))