Data export in this case is performed on the Front-end side:
...
- UI module downloads data from a back-end module sequentially - chunk by chunk. It makes download slower comparing to the multi-threaded approach.
- All data is stored in RAM until the last chunk is downloaded from the back-end module. If there are millions of records, it can take a good amount of RAM.
The more RAM it takes the higher probability that it will worsen front-end performance and hence user experience. - CSV creation is started only after the last data chunk is downloaded. It makes the overall data export process slower.
- The download process is synchronous, which means that if a user closes the page, then the process finishes. It makes the user wait until the CSV is created, which isn't a really good user experience.
- No data download / csv CSV generation progress is shown to the user, which can call user frustration in the case of big CSV file generation.
- If multiple customers will massively export data at the same time, it can create high pressure on the back-end module. It should be an edge case since it is expected that export operations are rare.
Collisions may occur if data is exported at the same time of the year regularly. For instance, if taxes should be paid by the end of the year, all customers may download data every year within the same time period.
This approach can work only in cases when small CSV files are generated. The bigger the file the less efficient the approach will be and the more user frustration it will make.