我使用C#并访问db。
在mysql中有一个语句用于删除表,如下所示:
drop table if exists t_table
所以你知道Access的类似声明吗?
答案 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));
}