DataTable ColumnName限制?

时间:2019-05-05 12:28:00

标签: c# wpf excel-interop oledbdataadapter datacolumn

我正在尝试将数据从Excel文件读取到DataSet中,但是我的问题是DataTable列名与Excel中的名称不匹配。似乎只有具有长列名的列。在DataTable列名中,它会在某些时候切断。

这是我的尝试:

DataSet mainExcelDataToImport = new DataSet();
using (OleDbConnection mainExcelOleDbConnection = new OleDbConnection())
{
    string theMainExcelConnectionString = this.ExcelConnectionString.Replace("{FullFilePath}", this.SelectedFilePath);
    mainExcelOleDbConnection.ConnectionString = theMainExcelConnectionString;

    // Open
    mainExcelOleDbConnection.Open();

    string mainExcelSQL = "SELECT * FROM [{ExcelSheet}$]";
    mainExcelSQL = mainExcelSQL.Replace("{ExcelSheet}", selectedExcelSheet);

    using (OleDbCommand mainExcelOleDbCommand = mainExcelOleDbConnection.CreateCommand())
    {
        mainExcelOleDbCommand.CommandText = mainExcelSQL;
        mainExcelOleDbCommand.CommandType = CommandType.Text;

        // Prepare
        mainExcelOleDbCommand.Prepare();

        using (OleDbDataAdapter mainOleDbDataAdapter = new OleDbDataAdapter(mainExcelOleDbCommand))
        {
            mainOleDbDataAdapter.Fill(mainExcelDataToImport);

            // Close
            mainExcelOleDbConnection.Close();
        }
    }
}

这是我尝试过的.xlsx:

A1234567890123456789012345678901234567890123456789012345678901234567890

TEST

'A12345.....' is the Column Name at A1

'TEST' is the Value at A2

When I check the `ColumnName` in the `DataTable` I get: 'A123456789012345678901234567890123456789012345678901234567890123' which is 64 characters.

ColumnName MaxLength限制如何工作?

我可以摆脱它吗?

也许是对OleDbDataAdapter的限制吗?

任何帮助/建议将不胜感激。

1 个答案:

答案 0 :(得分:3)

64个字符对于数据库列的名称来说异常长。我从未见过列名在该长度附近。

列名这么长似乎很奇怪。

它们当然必须存储在某个地方,因此任何数据库软件上都可能有最大值,例如SQL Server的最大值为128。如果像sqlclient这样的中间软件具有较低的限制,这也不会令我感到惊讶。非常长的名字是如此不寻常。

可能是适配器的局限性。

您可以尝试此线程中提到的一些替代方法:

Best /Fastest way to read an Excel Sheet into a DataTable?

或者也许您只能使用xml-而不是数据表。 Xml将能够处理excel可以处理的任何大小字段。

https://docs.microsoft.com/en-us/office/open-xml/understanding-the-open-xml-file-formats https://docs.microsoft.com/en-us/office/open-xml/how-to-parse-and-read-a-large-spreadsheet