检查 OleDb 表中是不是存在列
Posted
技术标签:
【中文标题】检查 OleDb 表中是不是存在列【英文标题】:Check if column exists in OleDb table检查 OleDb 表中是否存在列 【发布时间】:2012-08-27 19:59:16 【问题描述】:我正在尝试检查列是否存在,如果不存在,请添加它。我尝试了几个解决方案,包括 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,但它没有返回正确的表或其他东西。 我错过了什么?
【问题讨论】:
【参考方案1】:要检查数据表中是否存在列,您可以使用 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
【讨论】:
接受了这一点,因为在这种情况下,长度比返回所有列名更好。谢谢!【参考方案2】:您使用GetOleDbSchemaTable
的方法是可行的方法。模式表的每一行都包含表中单列的信息,模式表的每一列代表它的一个属性。所以,循环遍历模式表的行,而不是列!
foreach (DataRow row in dtColumns.Rows) // <== dtColumns.Rows
// (NOT dtColumns.Columns)
string columnName = (string)row["COLUMN_NAME"];
....
您的方法会生成架构表本身的列名。
【讨论】:
以上是关于检查 OleDb 表中是不是存在列的主要内容,如果未能解决你的问题,请参考以下文章