检查是否在OleDb的表中存在的列(Check if column exists in OleDb

2019-06-27 10:27发布

我想检查一个列上存在,如果没有,添加它。 我已经试过了几个解决方案,包括本 ,但语法不是Access数据库正确。

这是我到目前为止有:

    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也尝试过,但没有返回右表什么的。 我在想什么?

Answer 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
} 


Answer 2:

你有办法GetOleDbSchemaTable是要走的路。 架构表的每一行包含您的表的一列和架构表中的每一列的信息代表了它的一个特性。 因此,通过架构表中的行,而不是列循环!

foreach (DataRow row in dtColumns.Rows) { // <== dtColumns.Rows
                                          //     (NOT dtColumns.Columns)
    string columnName = (string)row["COLUMN_NAME"];
    ....
}

你的方法产生的架构表本身的列名。



文章来源: Check if column exists in OleDb table