我使用以下代码通过OleDb
C# .Net
连接连接到Access数据库
我怎么知道我硬编码到程序中的表是否实际存在于文件中,以便我可以向用户显示相应的消息?
try
{
var dbSource = "Data Source = " + source;
const string dbProvider = "PROVIDER=Microsoft.Jet.OLEDB.4.0;";
using (var con = new OleDbConnection())
{
con.ConnectionString = dbProvider + dbSource;
con.Open();
using (var cmd = new OleDbCommand())
{
cmd.Connection = con;
cmd.CommandText = "SELECT * FROM [Concrete Design Table 1]";
// How do I know the table name is valid? It results in errors when it is not?
// How to prevent it?
using (var dataReader = cmd.ExecuteReader())
{
while (dataReader != null && dataReader.Read())
{
// read the table here
}
}
}
}
}
catch (Exception e)
{
MessageBox.Show(e.ToString());
}
答案 0 :(得分:2)
您可以使用
获取表格列表var schema = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
并通过它们:
foreach (var row in schema.Rows.OfType<DataRow>())
{
string tableName = row.ItemArray[2].ToString();
}
或检查是否存在:
if (schema.Rows
.OfType<DataRow>()
.Any(r => r.ItemArray[2].ToString().ToLower() == tablename.ToLower()))
{
// table exists
}
丑陋,我知道。 :(
答案 1 :(得分:1)
SQL错误将抛出OleDbException
,您可以check SQLState
for specified error。如果该表不存在,则根据Microsoft's documentation,代码应为3376。所以你的代码看起来应该是
catch (OleDbException e)
{
switch (dbException.Errors[0].SQLState)
{
case "3376":
MessageBox.Show(dbException.Errors[0].Message); // or any message
break;
default:
MessageBox.Show(e.Message);
}
}
答案 2 :(得分:0)
这是我使用的工作解决方案(在VB.NET中,但我想你可以找出C#变体):
Dim myTable As Object, TableSchema As Object
Dim con As OleDb.OleDbConnection
con = New System.Data.OleDb.OleDbConnection
con.ConnectionString = "Provider=Microsoft.Jet.OleDb.4.0; Data Source=" & myFileName & ";"
If Not con.State = ConnectionState.Open Then con.Open()
TableSchema = con.GetSchema("TABLES")
myTable = TableSchema.select("TABLE_NAME='MYTABLENAME'")
If myTable.length = 0 Then
Dim cmd As New OleDb.OleDbCommand
cmd.Connection = con
cmd.CommandText = "CREATE TABLE MYTABLENAME;"
nAffected = cmd.ExecuteNonQuery
End If