Xử lý các tệp Excel lớn trong ứng dụng ngăn xếp MERN của bạn
Xây dựng một ứng dụng web bằng ngăn xếp MERN mở ra nhiều khả năng, đặc biệt là khi làm việc với các tệp do người dùng tải lên. Một kịch bản như vậy là xử lý các tệp Excel lớn, một yêu cầu phổ biến trong các ứng dụng nặng về dữ liệu. Cho dù bạn đang xây dựng một công cụ phân tích tài chính hay một ứng dụng xử lý dữ liệu, người dùng thường cần tải lên các tệp Excel để xử lý và phân tích dữ liệu. Tuy nhiên, khi các tệp đó tăng kích thước—chứa tối đa 100.000 hàng trở lên—mọi thứ có thể trở nên rắc rối! 🧐
Trong trường hợp này, việc xử lý việc lưu trữ và truy xuất tệp trở thành một thách thức, đặc biệt là khi sử dụng MongoDB. Ban đầu, nhiều nhà phát triển có thể chọn chuyển đổi tệp Excel sang định dạng JSON bằng các thư viện như `xlsx` và lưu trữ chúng trực tiếp trong cơ sở dữ liệu. Mặc dù điều này có thể hoạt động đối với các tệp nhỏ hơn nhưng vấn đề sẽ phát sinh khi xử lý các tập dữ liệu lớn. MongoDB áp đặt giới hạn kích thước BSON là 16 MB, nghĩa là tệp của bạn có thể vượt quá ngưỡng đó và gây ra sự cố. 😓
Để khắc phục hạn chế này, các giải pháp như GridFS cung cấp một cách tinh tế để lưu trữ các tệp lớn trong MongoDB mà không cần đạt đến giới hạn kích thước đó. Bằng cách chia tệp thành các phần nhỏ hơn và lưu trữ chúng một cách hiệu quả, GridFS cho phép bạn tải lên, lưu trữ và truy xuất các tệp lớn hiệu quả hơn. Nhưng có một vấn đề khác—việc chuyển đổi các tệp Excel lớn sang định dạng JSON ở giao diện người dùng cũng có thể tốn thời gian, ngay cả với các thư viện mạnh mẽ như `xlsx`.
Vì vậy, làm cách nào chúng tôi có thể tối ưu hóa quy trình này để đảm bảo rằng người dùng có thể tải lên và truy xuất các tệp Excel lớn mà không gặp phải tắc nghẽn về hiệu suất? Trong bài viết này, chúng ta sẽ khám phá các cách tiếp cận khác nhau để lưu trữ các tệp Excel lớn trong MongoDB và cách tối ưu hóa phần xử lý giao diện người dùng để cải thiện hiệu suất cho ứng dụng ngăn xếp MERN của bạn. 🚀
Yêu cầu | Ví dụ về sử dụng |
---|---|
FileReader | API FileReader được sử dụng để đọc nội dung của các tệp được lưu trữ trên máy tính của người dùng. Trong tập lệnh giao diện người dùng, FileReader.readAsArrayBuffer() đọc tệp Excel thành một mảng byte, sau đó có thể được xử lý và chuyển đổi thành JSON bằng thư viện xlsx. |
GridFSBucket | GridFSBucket là một tính năng MongoDB được sử dụng để lưu trữ các tệp lớn theo từng khối, bỏ qua giới hạn kích thước BSON 16 MB. Nó cho phép tải lên và tải xuống tập tin hiệu quả. Lệnh Bucket.openUploadStream() mở một luồng để tải dữ liệu lên GridFS, trong khi Bucket.openDownloadStreamByName() truy xuất tệp theo tên của nó. |
XLSX.read() | Lệnh này là một phần của thư viện xlsx, cho phép đọc các tệp Excel. XLSX.read() lấy một bộ đệm hoặc mảng và xử lý nó thành một đối tượng sổ làm việc có thể được thao tác thêm. Điều cần thiết là chuyển đổi tệp Excel thành dữ liệu JSON trên cả giao diện người dùng và phụ trợ. |
XLSX.utils.sheet_to_json() | Hàm tiện ích này chuyển đổi một trang tính từ sổ làm việc Excel sang định dạng JSON. Điều quan trọng là khi chúng ta muốn xử lý dữ liệu Excel theo từng hàng, trích xuất thông tin vào một đối tượng JavaScript. |
multer.memoryStorage() | Trong phần phụ trợ, multer.memoryStorage() được sử dụng để lưu trữ tệp tải lên trong bộ nhớ (thay vì đĩa). Điều này hữu ích cho việc xử lý tệp tạm thời, đặc biệt là khi làm việc với GridFS, vốn yêu cầu bộ đệm tệp. |
upload.single('file') | Lệnh này, một phần của phần mềm trung gian multer, chỉ định rằng mỗi lần chỉ có một tệp được tải lên và gán cho nó tên 'tệp'. Điều này hữu ích để xử lý việc tải tệp lên theo cách có cấu trúc ở phần phụ trợ. |
fetch() | tìm nạp() là một phương thức JavaScript hiện đại được sử dụng để gửi yêu cầu HTTP. Trong ví dụ này, nó được sử dụng để gửi yêu cầu POST để tải tệp lên và yêu cầu GET để truy xuất tệp từ chương trình phụ trợ. Điều cần thiết là xử lý các lệnh gọi API không đồng bộ trong các ứng dụng ngăn xếp MERN. |
res.status().send() | res.status().send() được sử dụng để gửi phản hồi HTTP trở lại máy khách. Phương thức status() đặt mã trạng thái phản hồi và send() gửi nội dung phản hồi. Điều này rất quan trọng để cung cấp phản hồi về việc tải lên tệp hoặc thao tác thành công hay thất bại. |
Buffer.concat() | Buffer.concat() được sử dụng để kết hợp nhiều khối dữ liệu vào một Bộ đệm duy nhất. Khi tải xuống một tệp theo từng đoạn từ GridFS, dữ liệu của tệp được lưu trữ trong nhiều đối tượng Bộ đệm và Buffer.concat() sẽ hợp nhất chúng để xử lý thêm (như chuyển đổi Excel). |
Tối ưu hóa việc xử lý tệp Excel lớn trong ngăn xếp MERN
Khi xây dựng ứng dụng web ngăn xếp MERN xử lý các tệp Excel lớn, đặc biệt khi xử lý hàng trăm nghìn hàng, quá trình lưu trữ và thao tác dữ liệu có thể nhanh chóng trở nên kém hiệu quả. Trong trường hợp của chúng tôi, chúng tôi cần tải lên các tệp Excel, chuyển đổi chúng thành và thực hiện các phép tính như tổng, trung bình và giá trị tối đa/tối thiểu cho mỗi hàng. Cách tiếp cận ban đầu là chuyển đổi tệp thành đối tượng JSON bằng cách sử dụng thư viện và lưu trữ trực tiếp vào MongoDB. Tuy nhiên, giải pháp này dẫn đến lỗi giới hạn kích thước BSON khi xử lý các tệp lớn với hơn 100.000 hàng. Để giải quyết vấn đề này, chúng tôi đã quyết định sử dụng GridFS của MongoDB, cho phép lưu trữ các tệp lớn dưới dạng khối, bỏ qua giới hạn kích thước BSON. Đây là một công cụ thay đổi cuộc chơi, cho phép chúng tôi lưu trữ toàn bộ tệp Excel mà không gặp phải giới hạn về kích thước.
Sau khi lưu trữ tệp trong GridFS, việc truy xuất và xử lý tệp trên giao diện người dùng cần có các bước bổ sung. Giao diện người dùng gửi yêu cầu đến phần phụ trợ để tìm nạp tệp từ GridFS. Sau khi được truy xuất, tệp sẽ được chuyển đổi thành định dạng JSON bằng thư viện XLSX. Tuy nhiên, mặc dù GridFS đã giải quyết được vấn đề lưu trữ nhưng nhiệm vụ tốn thời gian chuyển đổi các tệp lớn sang JSON vẫn là một nút thắt cổ chai. Thư viện XLSX cần thời gian đáng kể để xử lý các tệp lớn với 100.000 hàng, điều này có thể làm chậm trải nghiệm người dùng. Tại đây, chúng tôi nhận ra rằng mình cần tối ưu hóa hơn nữa quá trình xử lý giao diện người dùng. Chúng tôi có thể xem xét các cách xử lý chuyển đổi hiệu quả hơn hoặc xem xét chuyển một số quy trình xử lý sang phần phụ trợ để giảm bớt tải cho phía máy khách.
Để cải thiện trải nghiệm người dùng và giảm tải cho giao diện người dùng, chúng tôi có thể tận dụng quá trình xử lý không đồng bộ ở phần phụ trợ. Thay vì đợi giao diện người dùng xử lý toàn bộ tệp Excel, phần phụ trợ có thể xử lý việc chuyển đổi và thực hiện các phép tính trên máy chủ. Điều này sẽ trả lại kết quả được xử lý trực tiếp cho giao diện người dùng, cải thiện tốc độ và hiệu quả. Một cách tiếp cận khác là sử dụng phân trang, trong đó chỉ một tập hợp con các hàng được xử lý tại một thời điểm. Điều này sẽ giảm tải giao diện người dùng và cho phép người dùng tương tác với dữ liệu nhanh hơn. Chúng tôi cũng có thể khám phá việc chia nhỏ quá trình chuyển đổi JSON để tránh làm quá tải trình duyệt với quá nhiều dữ liệu cùng một lúc, tối ưu hóa việc sử dụng bộ nhớ và cải thiện hiệu suất.
Tóm lại, việc tối ưu hóa việc xử lý tệp Excel lớn trong ngăn xếp MERN liên quan đến việc giải quyết cả vấn đề về lưu trữ và hiệu suất. Bằng cách tận dụng GridFS của MongoDB để lưu trữ hiệu quả và triển khai xử lý hoặc phân trang phía máy chủ, ứng dụng có thể mở rộng quy mô và xử lý các tệp lớn hiệu quả hơn. Tuy nhiên, điểm nghẽn về hiệu năng ở giao diện người dùng khi chuyển đổi Excel sang JSON vẫn cần được chú ý. Bằng cách giảm tải các tác vụ xử lý nặng cho phần phụ trợ, ứng dụng có thể chạy mượt mà hơn, mang lại trải nghiệm tốt hơn cho người dùng. Khi chúng tôi tiếp tục cải tiến phương pháp này, rõ ràng rằng việc cân bằng trách nhiệm phía máy khách và phía máy chủ, cùng với việc tối ưu hóa việc thực thi mã, là chìa khóa để xây dựng ứng dụng ngăn xếp MERN hiệu quả và có thể mở rộng. 🚀
Giải pháp 1: Lưu trữ tệp Excel dưới dạng JSON trong MongoDB (Frontend và Backend)
Giải pháp này sử dụng phương pháp cơ bản trong đó chúng tôi chuyển đổi dữ liệu Excel thành JSON trên giao diện người dùng và lưu trữ dữ liệu đó trong MongoDB. Tập lệnh này hỗ trợ các tệp nhỏ nhưng có thể không mở rộng tốt với các tệp lớn (trên 16MB). Điều này tốt cho các thiết lập cơ bản trong đó khả năng mở rộng không phải là vấn đề.
// Frontend: Handle File Upload and Convert to JSONconst handleFileUpload = (event) => { const file = event.target.files[0]; if (file) { const reader = new FileReader(); reader.onload = async (e) => { const data = new Uint8Array(e.target.result); const workbook = XLSX.read(data, { type: 'array' }); const json = XLSX.utils.sheet_to_json(workbook.Sheets[workbook.SheetNames[0]]); // Send JSON data to backend await fetch('/api/uploadExcel', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ fileData: json }) }); }; reader.readAsArrayBuffer(file); }};// Backend: Express API to Store Data in MongoDBconst express = require('express');const mongoose = require('mongoose');const app = express();mongoose.connect('mongodb://localhost:27017/exceldb', { useNewUrlParser: true, useUnifiedTopology: true });const fileSchema = new mongoose.Schema({ data: Array });const File = mongoose.model('File', fileSchema);app.use(express.json());app.post('/api/uploadExcel', async (req, res) => { try { const newFile = new File({ data: req.body.fileData }); await newFile.save(); res.status(200).send('File uploaded successfully!'); } catch (error) { res.status(500).send('Error uploading file'); }});app.listen(5000, () => { console.log('Server running on port 5000');});
Giải pháp 2: Sử dụng GridFS để lưu trữ các tệp Excel lớn trong MongoDB
Theo phương pháp này, chúng tôi sử dụng GridFS để lưu trữ các tệp Excel lớn dưới dạng các đoạn trong MongoDB. Điều này cho phép chúng tôi xử lý các tệp lớn hơn 16MB. Sau khi lưu trữ tệp, giao diện người dùng sẽ truy xuất tệp đó và chuyển đổi nó thành JSON để xử lý.
// Frontend: Handle File Upload Using FormDataconst handleFileUpload = async (event) => { const file = event.target.files[0]; if (file) { const formData = new FormData(); formData.append('file', file); // Send file to backend await fetch('/api/uploadExcel', { method: 'POST', body: formData }); }};// Backend: Express API to Store Excel File in GridFSconst express = require('express');const mongoose = require('mongoose');const multer = require('multer');const { GridFSBucket } = require('mongodb');const app = express();mongoose.connect('mongodb://localhost:27017/exceldb', { useNewUrlParser: true, useUnifiedTopology: true });const storage = multer.memoryStorage();const upload = multer({ storage: storage });app.post('/api/uploadExcel', upload.single('file'), (req, res) => { const bucket = new GridFSBucket(mongoose.connection.db, { bucketName: 'excelFiles' }); const uploadStream = bucket.openUploadStream(req.file.originalname); uploadStream.end(req.file.buffer); res.status(200).send('File uploaded successfully!');});// Backend: Retrieve and Convert Excel File to JSONapp.get('/api/getExcel/:filename', (req, res) => { const bucket = new GridFSBucket(mongoose.connection.db, { bucketName: 'excelFiles' }); const downloadStream = bucket.openDownloadStreamByName(req.params.filename); const chunks = []; downloadStream.on('data', (chunk) => chunks.push(chunk)); downloadStream.on('end', () => { const buffer = Buffer.concat(chunks); const workbook = XLSX.read(buffer, { type: 'buffer' }); const json = XLSX.utils.sheet_to_json(workbook.Sheets[workbook.SheetNames[0]]); res.json(json); });});app.listen(5000, () => { console.log('Server running on port 5000');});
Giải pháp 3: Xử lý phía máy chủ để tối ưu hóa hiệu suất
Giải pháp này cải thiện hiệu suất bằng cách chuyển chuyển đổi JSON từ giao diện người dùng sang phụ trợ. Điều này đảm bảo giao diện người dùng không bị ảnh hưởng bởi thời gian xử lý tệp lớn và cho phép chuyển đổi tệp nhanh hơn cho các tập dữ liệu lớn.
// Backend: Express API to Handle File Conversion and Calculationconst express = require('express');const mongoose = require('mongoose');const { GridFSBucket } = require('mongodb');const XLSX = require('xlsx');const app = express();mongoose.connect('mongodb://localhost:27017/exceldb', { useNewUrlParser: true, useUnifiedTopology: true });app.post('/api/uploadExcel', upload.single('file'), (req, res) => { const bucket = new GridFSBucket(mongoose.connection.db, { bucketName: 'excelFiles' }); const uploadStream = bucket.openUploadStream(req.file.originalname); uploadStream.end(req.file.buffer); res.status(200).send('File uploaded successfully!');});// Backend: Retrieve, Convert, and Process Excel Fileapp.get('/api/getProcessedExcel/:filename', (req, res) => { const bucket = new GridFSBucket(mongoose.connection.db, { bucketName: 'excelFiles' }); const downloadStream = bucket.openDownloadStreamByName(req.params.filename); const chunks = []; downloadStream.on('data', (chunk) => chunks.push(chunk)); downloadStream.on('end', () => { const buffer = Buffer.concat(chunks); const workbook = XLSX.read(buffer, { type: 'buffer' }); const sheet = workbook.Sheets[workbook.SheetNames[0]]; const json = XLSX.utils.sheet_to_json(sheet); // Process data to calculate sum, average, etc. const processedData = json.map(row => ({ ...row, sum: row.values.reduce((a, b) => a + b, 0), average: row.values.reduce((a, b) => a + b, 0) / row.values.length })); res.json(processedData); });});app.listen(5000, () => { console.log('Server running on port 5000');});
Giải thích các lệnh lập trình chính được sử dụng trong Giải pháp
Tối ưu hóa xử lý tệp Excel trong ứng dụng ngăn xếp MERN
Việc xử lý các tệp Excel lớn trong các ứng dụng ngăn xếp MERN có thể đặt ra những thách thức đáng kể, đặc biệt khi các tệp chứa hàng trăm nghìn hàng. Trong bối cảnh ứng dụng web của bạn cho phép người dùng tải lên và thực hiện các phép tính trên dữ liệu Excel, những thách thức này càng trở nên rõ ràng hơn. Cách phổ biến để chuyển đổi tệp Excel thành định dạng để lưu trữ trong MongoDB thường dẫn đến tắc nghẽn hiệu năng do do MongoDB áp đặt. Khi xử lý các tệp Excel có trên 100.000 hàng, giới hạn này có thể nhanh chóng bị vượt quá, gây ra lỗi và ngăn cản việc lưu trữ thành công. Để giải quyết vấn đề này, việc sử dụng GridFS của MongoDB cung cấp một giải pháp có thể mở rộng. GridFS chia tệp thành các phần nhỏ hơn và lưu trữ chúng một cách hiệu quả, bỏ qua giới hạn kích thước của BSON và cho phép ứng dụng của bạn xử lý các tệp lớn hơn nhiều mà không gặp phải sự cố.
Tuy nhiên, việc lưu trữ tệp trong GridFS chỉ là một phần của quá trình tối ưu hóa. Sau khi tệp được lưu trữ, việc truy xuất và xử lý tệp trên giao diện người dùng vẫn có thể đặt ra những thách thức về hiệu suất, đặc biệt là khi xử lý các tập dữ liệu lớn. Việc chuyển đổi một tệp có 100.000 hàng thành JSON bằng thư viện XLSX có thể rất tốn thời gian, đặc biệt là ở phía máy khách. Vì giao diện người dùng chịu trách nhiệm thực hiện các phép tính như tính trung bình, tổng và các thao tác theo hàng khác nên quá trình này có thể dẫn đến trải nghiệm người dùng kém do độ trễ hiển thị. Trong những trường hợp như vậy, việc chuyển một số công việc này sang phần phụ trợ thường có lợi. Bằng cách xử lý chuyển đổi và tính toán ở phía máy chủ, bạn có thể giảm đáng kể khối lượng công việc trên máy khách, giúp ứng dụng nhanh hơn và phản hồi nhanh hơn.
Một cân nhắc quan trọng khác khi tối ưu hóa việc xử lý tệp Excel lớn trong các ứng dụng ngăn xếp MERN là đảm bảo xử lý dữ liệu hiệu quả. Một cách tiếp cận có thể là triển khai phân trang hoặc phân nhóm dữ liệu, trong đó mỗi lần chỉ một tập hợp con dữ liệu được truy xuất và xử lý. Phương pháp này sẽ giảm thời gian tải ban đầu, cho phép người dùng tương tác với dữ liệu khi nó đang được xử lý. Ngoài ra, việc tận dụng các cơ chế lập chỉ mục và bộ đệm trên phần phụ trợ có thể cải thiện hiệu suất hơn nữa. Tóm lại, để tối ưu hóa hiệu quả việc xử lý tệp lớn trong ứng dụng web ngăn xếp MERN của bạn, hãy xem xét kết hợp sử dụng GridFS để lưu trữ, giảm tải tính toán cho máy chủ và triển khai phân đoạn dữ liệu để tương tác giao diện người dùng hiệu quả. 🚀
- Làm cách nào để tránh giới hạn kích thước BSON trong MongoDB khi lưu trữ các tệp lớn?
- Để bỏ qua giới hạn kích thước BSON trong MongoDB, bạn có thể sử dụng , cho phép bạn lưu trữ các tệp lớn theo từng khối, xử lý hiệu quả các tệp vượt quá giới hạn kích thước BSON 16MB.
- Các phương pháp hay nhất để tối ưu hóa hiệu suất giao diện người dùng khi xử lý các tệp Excel lớn là gì?
- Để tối ưu hóa hiệu suất của giao diện người dùng, hãy cân nhắc việc giảm tải các tác vụ tính toán và xử lý tệp sang phần phụ trợ. Điều này sẽ giảm tải cho trình duyệt của khách hàng, đảm bảo trải nghiệm người dùng mượt mà hơn.
- Làm cách nào để cải thiện tốc độ chuyển đổi các tệp Excel lớn sang JSON?
- Một cách để tăng tốc quá trình chuyển đổi là chia tệp thành các phần nhỏ hơn và xử lý chúng không đồng bộ. Ngoài ra, việc tận dụng các thư viện hiệu quả hoặc sử dụng dịch vụ phụ trợ để chuyển đổi có thể giảm đáng kể thời gian thực hiện.
- Có cách nào để xử lý các phép tính theo thời gian thực trên các tệp Excel lớn không?
- Tính toán thời gian thực có thể được thực hiện bằng cách sử dụng xử lý phía máy chủ để tổng hợp dữ liệu (tổng, trung bình, tối đa, tối thiểu). Điều này sẽ giảm thời gian xử lý dữ liệu ở giao diện người dùng và cải thiện khả năng phản hồi.
- Phương pháp tốt nhất để lưu trữ các tệp Excel lớn thường xuyên được truy cập là gì?
- Nếu tệp Excel của bạn lớn và cần truy cập thường xuyên, là một sự lựa chọn tuyệt vời. Nó đảm bảo việc lưu trữ và truy xuất hiệu quả bằng cách chia các tệp thành các phần nhỏ hơn, dễ quản lý hơn.
- Tôi có thể triển khai phân trang cho các tệp Excel lớn trong ứng dụng web của mình không?
- Có, việc triển khai phân trang có thể giúp tối ưu hóa hiệu suất. Bạn có thể tìm nạp và xử lý các tập hợp con dữ liệu nhỏ hơn, điều này giúp ứng dụng phản hồi nhanh hơn và giảm thời gian tải ban đầu.
- MongoDB GridFS cải thiện việc xử lý các tệp Excel lớn như thế nào?
- GridFS lưu trữ các tệp theo từng phần nhỏ, giúp có thể lưu trữ các tệp lớn hơn giới hạn 16MB do MongoDB áp đặt. Điều này đặc biệt hữu ích khi xử lý các tập dữ liệu lớn như tệp Excel.
- Tôi nên thực hiện những bước nào để tránh hết thời gian chờ khi xử lý tệp Excel lớn?
- Để tránh hết thời gian chờ, bạn có thể chia quá trình xử lý tệp thành các tác vụ nhỏ hơn, sử dụng nhân viên nền hoặc hàng đợi để xử lý và tối ưu hóa mã phía máy chủ để xử lý dữ liệu hiệu quả.
- Làm cách nào để giảm mức sử dụng bộ nhớ giao diện người dùng khi xử lý các tệp Excel lớn?
- Để giảm mức sử dụng bộ nhớ giao diện người dùng, bạn có thể triển khai tính năng truyền trực tuyến và phân chia tệp Excel, xử lý các phần nhỏ hơn của tệp cùng lúc thay vì tải mọi thứ vào bộ nhớ cùng một lúc.
Để lưu trữ và truy xuất hiệu quả các tệp Excel lớn trong ứng dụng ngăn xếp MERN, bạn nên cân nhắc sử dụng dành cho MongoDB, xử lý các tệp lớn hơn giới hạn kích thước BSON 16 MB. Việc chuyển đổi trực tiếp các tệp Excel thành JSON và lưu trữ chúng có thể dẫn đến tắc nghẽn hiệu suất, đặc biệt là khi xử lý các tập dữ liệu lớn. Việc giảm tải việc xử lý và tính toán tệp xuống phần phụ trợ sẽ giảm tải giao diện người dùng và cung cấp thời gian xử lý nhanh hơn cho người dùng.
Hơn nữa, việc triển khai các kỹ thuật như phân chia dữ liệu và phân trang trên giao diện người dùng có thể đảm bảo rằng chỉ một phần dữ liệu có thể quản lý được mới được xử lý tại bất kỳ thời điểm nào. Điều này làm giảm mức tiêu thụ bộ nhớ và giúp ngăn ngừa thời gian chờ. Bằng cách tối ưu hóa cả bộ nhớ phụ trợ và xử lý dữ liệu giao diện người dùng, ứng dụng web ngăn xếp MERN của bạn có thể mở rộng quy mô một cách hiệu quả để xử lý các tệp Excel lớn với hàng nghìn hàng. 🚀
- Giải thích phương pháp sử dụng để lưu trữ các tệp lớn trong MongoDB: Tài liệu MongoDB GridFS
- Cung cấp cái nhìn sâu sắc về Chuyển đổi tệp Excel trong Node.js bằng thư viện xlsx: thư viện xlsx trên npm
- Cung cấp cái nhìn tổng quan về việc xử lý tệp trong các ứng dụng ngăn xếp MERN: Hướng dẫn DigitalOcean MERN
- Thảo luận về các kỹ thuật tối ưu hóa hiệu suất cho các tập dữ liệu lớn trong các ứng dụng giao diện người dùng: Blog bậc thầy về giao diện người dùng