如果存在,如何删除Access中的表

时间:2011-05-01 10:09:06

标签: c# ms-access

我使用C#并访问db。
在mysql中有一个语句用于删除表,如下所示:

drop table if exists t_table

所以你知道Access的类似声明吗?

1 个答案:

答案 0 :(得分:3)


我在Access中不知道这样的SQL语句 但是,您可以执行以下操作之一:

  • 尝试drope table而不检查是否存在,捕获异常(如果没有找到表,它应该有特定的代码)并忽略它。

  • 如果表存在,请尝试检入Access隐藏表MSysObjects(但是,ADO默认情况下没有权限)

  • 使用类似下面的代码(坏事:丢弃表不会返回受影响的记录):

    using (OleDbConnection conn = new OleDbConnection(@"Provider=Microsoft.JET.OLEDB.4.0;data source=c:\myDatabase.mdb"))
    {
        conn.Open();
    
        string tableToDelete = "myTable";   //table name
        bool tableExists = false;
    
        DataTable dt = conn.GetSchema("tables");
    
        foreach (DataRow row in dt.Rows)
        {
            if (row["TABLE_NAME"].ToString() == tableToDelete)
            {
                tableExists = true;
                break;
            }
        }
    
        if (tableExists)
        {
            using (OleDbCommand cmd = new OleDbCommand(string.Format("DROP TABLE {0}", tableToDelete), conn))
            {
                cmd.ExecuteNonQuery();
                MessageBox.Show("Table deleted");
            }
        }
        else
            MessageBox.Show(string.Format("Table {0} not exists", tableToDelete));
    }