检查 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 表中是不是存在列的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 python pyodbc 检查表中是不是存在列?

检查表中是不是存在列,如果没有,则添加列

MySQL,使用SQL检查表中是不是存在列

如何使用 JdbcTemplate 检查表列是不是存在?

检查 presto/hive 表中是不是存在列名

FluentMigrator - 检查列是不是存在跨数据库