[英]Check if column exists in OleDb table
我正在嘗試檢查是否存在一列,如果不存在,請添加它。 我嘗試了包括this在內的幾種解決方案,但是語法對於Access db不正確。
這是我到目前為止:
public void Update(string task, string dbPath, string tableName = "Frames")
{
OleDbConnection db = new OleDbConnection("Provider=Microsoft.JET.OLEDB.4.0;data source=" + dbPath);
db.Open();
OleDbCommand command = db.CreateCommand();
command.CommandText = "COL_LENGTH('Frames','SetNumber')";
Debug.WriteLine(command.ExecuteReader());
/*
string[] restrictions = new string[] {null, null, tableName};
DataTable dtColumns = db.GetOleDbSchemaTable(OleDbSchemaGuid.Columns, restrictions);
foreach (DataColumn column in dtColumns.Columns)
{
Debug.WriteLine(column.ColumnName);
}*/
}
我也嘗試過使用GetOleDbSchemaTable,但是它沒有返回正確的表或其他東西。 我想念什么?
若要檢查數據表中是否存在列,可以使用OleDbConnection的GetSchema方法
public void Update(string task, string dbPath, string colName, string tableName = "Frames")
{
using(OleDbConnection db = new OleDbConnection("........"))
{
db.Open();
var schema = db.GetSchema("COLUMNS");
var col = schema.Select("TABLE_NAME='" + tableName +
" AND COLUMN_NAME='" + colName + "'"
if(col.Length > 0)
// Column exist
else
// Column doesn't exist
}
使用GetOleDbSchemaTable
的方法是正確的方法。 模式表的每一行都包含表的單個列的信息,模式表的每一列代表其一個屬性。 因此,遍歷模式表的行而不是列!
foreach (DataRow row in dtColumns.Rows) { // <== dtColumns.Rows
// (NOT dtColumns.Columns)
string columnName = (string)row["COLUMN_NAME"];
....
}
您的方法將產生模式表本身的列名。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.