Я пытаюсь экспортировать ряды данных из 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
Написание, чтобы Excel с помощью OLEDB ⇐ C#
Место общения программистов C#
1738429909
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[i] = String.Format("[{0}]", dataTable.Columns[i].ColumnName);
colParms[i] = "?";
}
// 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[i].ColumnName), OleDbType.Char, 255, dataTable.Columns[i].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[i] = "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 [i] = string.format ("[{0}]", DataTable .Columns [i] .columnname). Я обнаружил, что мне нужно [], чтобы объяснить пространства в именах столбцов, но на данный момент я не уверен, в чем проблема. Когда я смотрю на файл Excel, все кажется мне правильным.
Подробнее здесь: [url]https://stackoverflow.com/questions/12807362/writing-to-excel-using-oledb[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия