ADOX表列的“可空”属性?

时间:2012-05-30 22:29:41

标签: c# .net-4.0 oledb jet adox

我正在尝试使用C#创建一个Access文件(.mdb)。我正在从SQL导出数据以用于遗留流程。我得到了它的工作,我面临的唯一问题是将列设置为可空。

这就是我所拥有的(为简洁起见删除了大多数专栏):

private void CreateAndExportLegacyFile(DataTable data, string exportFilename)
{
    var connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;";
    connectionString += "Data Source=" + exportFilename + ";Jet OLEDB:Engine Type=5";

    var catalog = new Catalog();
    catalog.Create(connectionString);

    var table = new Table { Name = "Main" };

    #region Column mapping
    table.Columns.Append("ID", DataTypeEnum.adVarWChar, 50);
    table.Columns.Append("FIRST", DataTypeEnum.adVarWChar, 50);
    table.Columns.Append("LAST", DataTypeEnum.adVarWChar, 50);
    #endregion

    foreach (Column column in table.Columns)
    {
        if (column.Name != "ID") column.Properties["Nullable"].Value = true;
    }

    catalog.Tables.Append(table);

    Marshal.FinalReleaseComObject(table);
    Marshal.FinalReleaseComObject(catalog.Tables);
    Marshal.FinalReleaseComObject(catalog.ActiveConnection);
    Marshal.FinalReleaseComObject(catalog);
}

尝试设置“Nullable”属性时出现以下错误:“在请求的名称或序号对应的集合中找不到项目。”

我发现有关是否使用Required或Nullable的相互矛盾的报告,但我已尝试过两者并得到相同的结果。

知道为什么我无法设置可空属性吗?我可能只是懒惰,并且在拉取数据时默认空值为空格,但如果可能的话,我希望避免这种情况。

编辑:正如Hans在评论中提到的那样,我不得不使用Attributes属性:

if (column.Name != "ID") column.Attributes = ColumnAttributesEnum.adColNullable;

1 个答案:

答案 0 :(得分:4)

Hans Passant在评论中回答了这一点,但从未将其作为答案添加。现在这样做是为了将其标记为已回答。必须使用Attributes属性:

if (column.Name != "ID") column.Attributes = ColumnAttributesEnum.adColNullable;