C#使用NPOI在数据库中查询出20万的数据导出到excel。引发类型为“System.OutOfMemoryException”的异常。

坚持的小马 2015-11-18 02:47:37
我的导出代码如下:
public MemoryStream RenderToExcel(DataTable table)
{
MemoryStream ms = new MemoryStream();

using (table)
{
IWorkbook workbook = new XSSFWorkbook();

ISheet sheet = workbook.CreateSheet();

IRow headerRow = sheet.CreateRow(0);

// handling header.
foreach (DataColumn column in table.Columns)
headerRow.CreateCell(column.Ordinal).SetCellValue(column.Caption);//If Caption not set, returns the ColumnName value

// handling value.
int rowIndex = 1;

foreach (DataRow row in table.Rows)
{
IRow dataRow = sheet.CreateRow(rowIndex);

foreach (DataColumn column in table.Columns)
{
dataRow.CreateCell(column.Ordinal).SetCellValue(row[column].ToString());
}

rowIndex++;
}

workbook.Write(ms);
ms.Flush();
ms.Position = 0;
}


return ms;
}
程序报错的位置:workbook.Write(ms);这段代码,请教一下各位,我这个需要进行怎么样的优化才可以导出大数据量的数据到excel呢
...全文
1003 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
BitCoffee 2015-11-18
  • 打赏
  • 举报
回复
foreach外面定义一个int row=0; foreach里面 if(row % 10000 ==0) { ISheet sheet = workbook.CreateSheet(); IRow headerRow = sheet.CreateRow(0); } 每次sheet.CreateRow(0)时row++; 其它细节自己去组织。
海棠是否依旧 2015-11-18
  • 打赏
  • 举报
回复
創建多個Sheet導入
坚持的小马 2015-11-18
  • 打赏
  • 举报
回复
请教一下,duanzi_peng你有没有分批次的实例代码呢,我拿来参考一下。
BitCoffee 2015-11-18
  • 打赏
  • 举报
回复
分批次倒入的时候注意下这个 : Excel 07-2003一个工作表最多可有65536行;最多可有256列;255个工作表。 Excel 2007及以后版本,一个工作表最多可有1048576行,16384列; 另外Excel 07-2003的单个表的行数过多时,会导致打开文件很慢。
  • 打赏
  • 举报
回复
分批次写入。

111,120

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Creator Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧