C# - 以编程方式创建SQL Server表

时间:2013-10-25 11:48:52

标签: c# .net sql-server create-table

我正在尝试以编程方式创建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 query时;我从现有表中获得结果,所以我认为连接字符串应该没问题。希望你能看到问题:/

6 个答案:

答案 0 :(得分:11)

您尚未在连接字符串中提及Initial catalog名称。将您的数据库名称设为Initial Catalog名称。

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

答案 1 :(得分:7)

首先检查表是否存在。如果不存在则创建表。

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

答案 2 :(得分:3)

为了管理SQL Server中的数据库对象,我建议使用Server Management Objects

答案 3 :(得分:1)

试试这个

  

检查表格是否有,然后删除表格,然后创建

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

答案 4 :(得分:1)

如果您不想记住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();

答案 5 :(得分:0)

试试这个:

if(preg_match('/[^a-z_\-0-9]/i', $string))
{
  echo "not valid string";
}