it-swarm.com.de

Erstellen Sie eine SQL Server-Tabelle programmgesteuert

Ich versuche, eine SQL Server-Tabelle programmgesteuert zu erstellen. Hier ist der Code.

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);
    }
}

Beim zweiten Ausführen dieser Anwendung erhalte ich eine Ausnahme:

"Es gibt bereits ein Objekt mit dem Namen 'Customer' in der Datenbank" 

aber wenn ich die Datenbank überprüfe, sehe ich keine solche Tabelle.
Hier ist meine Verbindungszeichenfolge.

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

Wenn ich laufe, wählen Sie die Abfrage. Ich erhalte Ergebnisse aus vorhandenen Tabellen, daher sollte die Verbindungszeichenfolge in Ordnung sein. Ich hoffe, Sie sehen das Problem: /

11
user2412672

Sie haben den Initial catalog-Namen in der Verbindungszeichenfolge nicht erwähnt. Geben Sie Ihren Datenbanknamen als Initial Catalog Namen an.

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

Prüfen Sie zunächst, ob eine Tabelle vorhanden ist oder nicht. Wenn nicht vorhanden, wird die Tabelle erstellt.

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();
6
Nair

Für die Verwaltung von Datenbankobjekten in SQL Server würde ich vorschlagen, Server Management Objects

Wenn Sie sich nicht an die SQL-Syntax erinnern möchten, können Sie mit Mig # einfach Folgendes tun:

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)
     ...);

Wenn Sie nicht sicher sind, ob es bereits existiert, rufen Sie DropIfExists auf:

db.Tables["Customers"].DropIfExists();
1
Dejan

Versuche dies

Prüfen Sie, ob die Tabelle dort ist, löschen Sie die Tabelle und erstellen Sie dann 

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))
0
using System;
using System.Data;
using System.Data.SqlClient;

namespace SqlCommend
{
    class sqlcreateapp
    {
        static void Main(string[] args)
        {
            try
            {
                SqlConnection conn = new SqlConnection("Data source=USER-PC; Database=Emp123;User Id=sa;Password=sa123");
                SqlCommand cmd = new SqlCommand("create table <Table Name>(empno int,empname varchar(50),salary money);", conn);
                conn.Open();
                cmd.ExecuteNonQuery();
                Console.WriteLine("Table Created Successfully...");
                conn.Close();
            }
            catch(Exception e)
            {
                Console.WriteLine("exception occured while creating table:" + e.Message + "\t" + e.GetType());
            }
            Console.ReadKey();
        }
    }
}
0

Versuche dies:

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();
    }
}
0
Parmar Jigar