2

列が存在するかどうかを確認し、存在しない場合は追加しようとしています。これを含むいくつかの解決策を試しましたが、Accessdbの構文が正しくありません。

これは私がこれまでに持っているものです:

    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も使用してみましたが、正しいテーブルなどが返されません。私は何が欠けていますか?

4

2 に答える 2

5

データテーブルに列が存在するかどうかを確認するには、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
} 
于 2012-08-27T20:08:37.070 に答える
3

でのあなたのアプローチGetOleDbSchemaTableは行く方法です。スキーマテーブルの各行には、テーブルの1つの列の情報が含まれ、スキーマテーブルの各列はその1つのプロパティを表します。したがって、列ではなく、スキーマテーブルの行をループします。

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

あなたのアプローチは、スキーマテーブル自体の列名を生成します。

于 2012-08-27T20:06:40.553 に答える