我正在嘗試在Firebase云函數中運行以下代碼。我嘗試做的是遍歷名為 savedData 的 Firestore 集合中的所有文檔,解析存儲在每個文檔中的字符串的 JSON,然后將解析后的數據存儲到名為 stgPicks 的集合中的新文檔中。保存的數據收集集合中的每個文檔應在 stgPicks 集合中創建 50-100 個新文檔。當我嘗試運行該函數時,我得到以下錯誤代碼。任何人都可以幫助調試此代碼嗎?我不確定我是否正確處理了批處理。Error: 3 INVALID_ARGUMENT: maximum 500 writes allowed per request at Object.callErrorFromStatus (/workspace/node_modules/@grpc/grpc-js/build/src/call.js:30:26) at Object.onReceiveStatus (/workspace/node_modules/@grpc/grpc-js/build/src/client.js:175:52) at Object.onReceiveStatus (/workspace/node_modules/@grpc/grpc-js/build/src/client-interceptors.js:341:141) at Object.onReceiveStatus (/workspace/node_modules/@grpc/grpc-js/build/src/client-interceptors.js:304:181) at Http2CallStream.outputStatus (/workspace/node_modules/@grpc/grpc-js/build/src/call-stream.js:115:74) at Http2CallStream.maybeOutputStatus (/workspace/node_modules/@grpc/grpc-js/build/src/call-stream.js:154:22) at Http2CallStream.endCall (/workspace/node_modules/@grpc/grpc-js/build/src/call-stream.js:140:18) at Http2CallStream.handleTrailers (/workspace/node_modules/@grpc/grpc-js/build/src/call-stream.js:265:14) at ClientHttp2Stream.emit (events.js:198:13) at ClientHttp2Stream.EventEmitter.emit (domain.js:466:23)exports.parsePicksRecover = functions.https.onRequest((req, res) => { let savedDataRef = admin.firestore().collection('savedData') let allDrafts = savedDataRef .get() .then((snapshot) => { snapshot.forEach((doc) => { const docId = doc.id const getDoc = admin .firestore() .collection('savedData') .doc(`${docId}`) .get() .then((doc) => { if (!doc.exists) { console.log('No matching document.') }
INVALID_ARGUMENT:每個請求最多允許 500 次寫入
炎炎設計
2022-08-04 17:20:19