检查数据库中是否存在两个表

本文关键字:两个 数据库 是否 存在 检查 | 更新日期: 2023-09-27 18:25:27

我有一个数据库pavaminimas.mdf,它包含两个表:Vehicle和Repairs。我想检查数据库中是否存在这两个表。到目前为止,我设法检查了一个表是否存在,但如何检查两者是否存在,如果不创建它们的话。

这是我的代码:

string tblnm = "Vehicle";
            SqlConnection conn;
            using (conn = new SqlConnection(connection))
            {
                conn.Open();           
                System.Data.SqlClient.SqlCommand cmd = new System.Data.SqlClient.SqlCommand();
                cmd.CommandText = @"IF EXISTS(SELECT * FROM INFORMATION_SCHEMA.TABLES 
                       WHERE TABLE_NAME='" + tblnm + "') SELECT 1 ELSE SELECT 0"; ;
                cmd.Connection = conn;
                cmd.ExecuteNonQuery();
                int x = Convert.ToInt32(cmd.ExecuteScalar());
                conn.Close();
                if (x == 2)
                {
                    MessageBox.Show("Lentelės yra");
                }
                else
                {
                    MessageBox.Show("Lenteliu nėra.Sukuriama");
                }

我还有应该创建表的代码。这是代码:

string table1 = "Repairs";
                 SqlConnection conn;
                 conn = new SqlConnection(connection);
                     conn.Open();
                     string createString = "CREATE TABLE [dbo].['" + table1 + "'](" + "[VIN] [nvarchar](50)," + "[Taisymas] [nvarchar](50)," + "[Kaina] [decimal](18, 2))";
                       SqlCommand sqlCmd = new SqlCommand(createString, conn);
                       sqlCmd.ExecuteNonQuery();
                       conn.Close();

但这段代码不会在我的数据库中创建表。然后我调用这个方法,它说表已经存在,但当我检查数据库中的表时,它什么都不是,空的。。。

检查数据库中是否存在两个表

你在寻找类似于的东西吗

IF EXISTS(SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME='tbl1') AND EXISTS(SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME='tbl2') SELECT 1 ELSE SELECT 0

使用一个参数并在表中循环如何?

conn.Open();
var cmd = new System.Data.SqlClient.SqlCommand(
    @"SELECT count (*) FROM INFORMATION_SCHEMA.TABLES where TABLE_NAME = @TABLE_NAME",
    conn);
cmd.Parameters.Add("@TABLE_NAME", SqlDbType.VarChar);
List<String> tables = new List<string>() { "Vehicles", "Repairs" };
foreach (string tableName in tables)
{
    cmd.Parameters[0].Value = tableName;
    int x = Convert.ToInt32(cmd.ExecuteScalar());
    if (x == 0)
        CreateTable(tableName, conn);
}
conn.Close();

--编辑--

上面添加了CreateTable方法,代码看起来像这样。注意——这是一种极端的暴力,但在没有其他信息的情况下,这是完成任务的一种方式,因为我最理解你的问题。

private void CreateTable(String TableName, System.Data.SqlClient.SqlConnection conn)
{
    StringBuilder sql = new StringBuilder(@"create table [");
    sql.Append(TableName);
    sql.AppendLine(@"] (");
    switch (TableName)
    {
        case "Vehicle":
            sql.AppendLine("[VIN] varchar(100),");
            sql.AppendLine("[Manufacturer] varchar(100),");
            sql.AppendLine("[Model] varchar(100),");
            sql.AppendLine("[Year] integer");
            break;
        case "Repair":
            sql.AppendLine("[VIN] varchar(100),");
            sql.AppendLine("[Correction] varchar(100),");
            sql.AppendLine("[Price] decimal");
            break;
    }
    sql.Append(")");
    System.Data.SqlClient.SqlCommand cmd = new System.Data.SqlClient.SqlCommand(
        sql.ToString, conn);
    try
    {
        cmd.ExecuteNonQuery();
        MessageBox.Show("Created Table " + TableName);
    }
    catch (Exception ex)
    {
        MessageBox.Show("Oops, I did it again");
    }
}

将其包裹在for循环中

for(int i = 0; i < 2; i++){
  if (i = 0)
  {
    string tblnm = "Vehicle";
  }
  else
  {
    string tblnm = "Repairs";
  }
        SqlConnection conn;
        using (conn = new SqlConnection(connection))
        {
            conn.Open();           
            System.Data.SqlClient.SqlCommand cmd = new System.Data.SqlClient.SqlCommand();
            cmd.CommandText = @"IF EXISTS(SELECT * FROM INFORMATION_SCHEMA.TABLES 
                   WHERE TABLE_NAME='" + tblnm + "') SELECT 1 ELSE SELECT 0"; ;
            cmd.Connection = conn;
            cmd.ExecuteNonQuery();
            int x = Convert.ToInt32(cmd.ExecuteScalar());
            conn.Close();
            if (x == 2)
            {
                MessageBox.Show("Lentelės yra");
            }
            else
            {
                MessageBox.Show("Lenteliu nėra.Sukuriama");
            }
}