Написание, чтобы Excel с помощью OLEDBC#

Место общения программистов C#
Ответить
Anonymous
 Написание, чтобы Excel с помощью OLEDB

Сообщение Anonymous »

Я пытаюсь экспортировать ряды данных из SQL в Excel, но моя команда INSERT, кажется, не сбои. Я потратил много времени, пытаясь создать это, но я наконец -то столкнулся со стеной. < /P>
Документ Excel - это тот Измените все, что выше строки 16. Строка 16 - это строка заголовка, и все ниже, что должно быть данные из SQL. У всех имен заголовков есть места в них, и, кажется, именно там у меня возникают проблемы. < /P>
Начиная с строки 16 Фамилия, участник Ptin, номер программы, программа CE, награжденная программой, дата завершения < /p>
Вот как я пытаюсь написать в Excel < /p>
private void GenerateReport()
{
FileInfo xlsFileInfo = new FileInfo(Server.MapPath(CE_REPORTS_PATH + CE_PTIN_TEMPLATE + EXTENSION));

string connectionString = String.Format(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties='Excel 8.0;HDR=Yes'", xlsFileInfo.FullName);

//create connection
OleDbConnection oleDBConnection = new OleDbConnection(connectionString);
oleDBConnection.Open();

//create the adapter with the select to get
OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM [Sheet1$A16:F16]", oleDBConnection);

// Create the dataset and fill it by using the adapter.
DataTable dataTable = new DataTable();
adapter.FillSchema(dataTable, SchemaType.Source);
adapter.Fill(dataTable);

string[] colNames = new string[dataTable.Columns.Count];
string[] colParms = new string[dataTable.Columns.Count];

for (int i = 0; i < dataTable.Columns.Count; i++)
{
colNames = String.Format("[{0}]", dataTable.Columns.ColumnName);
colParms = "?";
}

// Create Insert Command
adapter.InsertCommand = new OleDbCommand(String.Format("INSERT INTO [Sheet1$] ({0}) values ({1})", string.Join(",", colNames), string.Join(",", colParms)), oleDBConnection);

// Create Paramaters
for (int i = 0; i < dataTable.Columns.Count; i++)
{
OleDbParameter param = new OleDbParameter(String.Format("@[{0}]", dataTable.Columns.ColumnName), OleDbType.Char, 255, dataTable.Columns.ColumnName);
adapter.InsertCommand.Parameters.Add(param);
}

// create a new row
DataRow newCERecord = dataTable.NewRow();

// populate row with test data
for (int i = 0; i < dataTable.Columns.Count; i++)
{
newCERecord = "new Data";
}
dataTable.Rows.Add(newCERecord);

// Call update on the adapter to save all the changes to the dataset
adapter.Update(dataTable);

oleDBConnection.Close();
}
< /code>
Ошибка, которую я получаю, происходит, когда Adapter.update (dataTable) вызывается и следующая < /p>

$ Exception { «Вставка в утверждение содержит следующее имя неизвестного поля:« Имя участника ». Убедитесь, что вы правильно набрали имя, и снова попробуйте операцию»} System.Except >
< /blockquote>
Это разочаровывает, потому что я вытаскиваю каждое поле непосредственно из имени столбца, как получилось Colnames = string.format ("[{0}]", DataTable .Columns .columnname). Я обнаружил, что мне нужно [], чтобы объяснить пространства в именах столбцов, но на данный момент я не уверен, в чем проблема. Когда я смотрю на файл Excel, все кажется мне правильным.

Подробнее здесь: https://stackoverflow.com/questions/128 ... sing-oledb
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»