Buenas, mi problematica es que quiero generar un archivo excel desde un DataTable en C#; actualmente realizo una consulta en la base de datos que me devuelve al rededor de 4 millones de tuplas he logrado hacer que la respuesta de dicha consulta se reduzca a 2 minutos aproximadamente; ahora no quiero que toda esa optimización se vea afectada al momento de generar un archivo de Excel con la información consultada ¿Existe algún tipo de "Bulk" para escribir los datos en un archivo? ya que actualmente las opciones que he encontrado es recorrer el DataTable y realizar la escritura del archivo row por row y toda la optimización realizada se pierde.
entre Desarrolladores
Recibe ayuda de expertos
Registrate y pregunta
Es gratis y fácil
Recibe respuestas
Respuestas, votos y comentarios
Vota y selecciona respuestas
Recibe puntos, vota y da la solución
Pregunta
1 Respuesta
¿Quieres generar un archivo de Excel con 4 millones de registros? A priori sin conocer más detalles no parece el mejor formato para soportar tanta información, ten en cuenta que Excel en sus últimas versiones admite algo más de 1 millón de filas por cada hoja.
Sobre rendimiento y tiempos de escritura en ficheros Excel te recomiendo este artículo que he encontrado: http://www.clear-lines.com/blog/post/Write-data-to-an-Excel-worksheet-with-C-fast.aspx
Lo suyo es que hagas pruebas de rendimiento escribiendo en forma de array cada tupla, pero según ese artículo te vas a mover en tiempos de entre 0,005 a 3 milisegundos por celda, lo que te deja un arco de entre 1 minuto y 7 horas xD
Lo malo es que por tu tipo de datos con pocas columnas (entiendo que 2 columnas si hablamos de tuplas) parece no vas a beneficiarte de la escritura en array.
Otra opción es que te plantees las necesidades y lo exportes a un fichero CSV, que posteriormente puede convertirse a Excel fácilmente.
Por favor, accede o regístrate para añadir un comentario.
Por favor, accede o regístrate para responder a esta pregunta.
En el blog
-
- 406380
- 1
- Jul 5, 2015
Sin Respuesta
-
- 20
- 0
- Sep 19
-
- 50
- 0
- Ago 21
-
- 139
- 0
- May 14
-
- 120
- 0
- Abr 21
-
- 215
- 0
- Mar 31
-
- 189
- 0
- Mar 27
-
- 1006
- 0
- Feb 18
-
- 329
- 0
- Nov 23, 2022
- ver todas
Actividad Reciente
pedrourday preguntó Sep 19
Alternativas a ThreeJS y BabylonJS?pedrourday preguntó Ago 21
¿Que tecnologias y lenguajes me recomiendan?Fabio respondió Jul 11
plugin de efecto circular 3d en imagenesSergio-HiTech respondió Jun 9
Crear tabla de horarios de C#Sergio-HiTech respondió Jun 9
¿Que libro/tutorial para un programador sin base q…Sergio-HiTech respondió Jun 9
C# Problema con comboboxdanielaGM preguntó May 14
Generar reporte con PhpWord con un CRUDrach preguntó Abr 21
Cruzar excel por id con pythonelporfirio respondió Feb 22
Construir URL para actualizar contraseña después d…
Ultimas Preguntas
Usuarios Top
- Leonardo-Tadei
- 227320 Puntos
- Peter
- 150430 Puntos
- white
- 75880 Puntos
- carlossevi
- 63580 Puntos
- magarzon
- 30650 Puntos
- pregunton
- 20400 Puntos