С# — создать таблицу SQL Server программно

Я пытаюсь создать таблицу 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);
    }
}

Когда я запускаю это приложение во второй раз, я получаю исключение:

"В базе данных уже есть объект с именем "Клиент""

но когда я проверяю базу данных, я не вижу такой таблицы.
Вот моя строка подключения.

<connectionStrings>
  <add name ="AutoRepairSqlProvider" connectionString=
     "Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\AutoRepairDatabase.mdf;
     Integrated Security=True;User Instance=True"/>
</connectionStrings>

Когда я запускаю запрос выбора; Я получаю результаты из существующих таблиц, поэтому я думаю, что строка подключения должна быть в порядке. Надеюсь, вы увидите проблему :/


person user2412672    schedule 25.10.2013    source источник
comment
Попробуйте обновить окно проводника SQL :)   -  person Jens Kloster    schedule 25.10.2013
comment
Это невозможно ;) Вы проверяете неверную базу данных или таблица есть, но вы ее по какой-то причине не видите.   -  person Claudio Redi    schedule 25.10.2013
comment
Я проверяю правильную базу данных, потому что я могу читать данные из нее   -  person user2412672    schedule 25.10.2013


Ответы (7)


Вы не упомянули имя Initial catalog в строке подключения. Дайте имя вашей базы данных как Initial Catalog имя.

<add name ="AutoRepairSqlProvider" connectionString=
     "Data Source=.\SQLEXPRESS; Initial Catalog=MyDatabase; AttachDbFilename=|DataDirectory|\AutoRepairDatabase.mdf;
     Integrated Security=True;User Instance=True"/>
person Kurubaran    schedule 25.10.2013
comment
ой ! Имя базы данных не было в его строке подключения. Но как показать это сообщение об ошибке There is already an object named 'Customer' in the database ?? - person Ramesh Rajendran; 25.10.2013
comment
@Ramesh - вы, вероятно, создали «Клиент» в базе данных «Мастер». - person Damien; 21.08.2015

Во-первых, проверьте, существует ли таблица или нет. Соответственно, создайте таблицу, если ее нет.

var commandStr= "If not exists (select name from sysobjects where name = 'Customer') CREATE TABLE Customer(First_Name char(50),Last_Name char(50),Address char(50),City char(50),Country char(25),Birth_Date datetime)";

using (SqlCommand command = new SqlCommand(commandStr, con))
command.ExecuteNonQuery();
person Sreejith Nair    schedule 25.10.2013

Для управления объектами базы данных в SQL Server я бы предложил использовать объекты управления сервером.

person Giannis Paraskevopoulos    schedule 25.10.2013
comment
Это должен был быть правильный и принятый ответ. Все остальное выше - древняя технология - person Fandango68; 02.05.2018

Попробуй это

Проверьте, есть ли таблица, и удалите таблицу, затем создайте

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))
person Ramesh Rajendran    schedule 25.10.2013

Если вам не нравится запоминать синтаксис SQL, с помощью Mig# вы можете просто:

var schema = new DbSchema(ConnectionString, DbPlatform.SqlServer2014);
schema.Alter(db => db.CreateTable("Customer")
     .WithPrimaryKeyColumn("Id", DbType.Int32).AsIdentity()
     .WithNotNullableColumn("First_Name", DbType.String).OfSize(50)
     .WithNotNullableColumn("Last_Name", DbType.String).OfSize(50)
     ...);

Если вы не уверены, существует ли он уже, вызовите DropIfExists перед:

db.Tables["Customers"].DropIfExists();
person Dejan    schedule 23.12.2015

Попробуй это:

protected void Button1_Click(object sender, EventArgs e)
{
    SqlConnection cn = new SqlConnection("Data Source=(LocalDB)\\v11.0;AttachDbFilename=|DataDirectory|\\Database.mdf;Integrated Security=True");
    try
    {
        cn.Open();
        SqlCommand cmd = new SqlCommand("create table Employee (empno int,empname varchar(50),salary money);", cn);
        cmd.ExecuteNonQuery();
        lblAlert.Text = "SucessFully Connected";
        cn.Close();
    }
    catch (Exception eq)
    {
        lblAlert.Text = eq.ToString();
    }
}
person Parmar Jigar    schedule 23.12.2016

person    schedule
comment
Пожалуйста, добавьте больше деталей - person a4arpan; 21.12.2015