As you mentioned in the comment, your situation is depends on the RUs allocated.I provide you with below sample stored procedure code.You could refer to it.
function deleteSproc(query) {
var collection = getContext().getCollection();
var collectionLink = collection.getSelfLink();
var response = getContext().getResponse();
var responseBody = {
deleted: 0,
continuation: ""
};
// Validate input.
if (!query) throw new Error("The query is undefined or null.");
tryQueryAndDelete();
function tryQueryAndDelete(continuation) {
var requestOptions = {
continuation: continuation,
pageSize: 10
};
var isAccepted = collection.queryDocuments(collectionLink, query, requestOptions, function (err, documents, responseOptions) {
if (err) throw err;
if (documents.length > 0) {
tryDelete(documents);
if(responseOptions.continuation){
tryQueryAndDelete(responseOptions.continuation);
}else{
response.setBody(responseBody);
}
}
});
if (!isAccepted) {
response.setBody(responseBody);
}
}
function tryDelete(documents) {
if (documents.length > 0) {
var requestOptions = {etag: documents[0]._etag};
// Delete the document.
var isAccepted = collection.deleteDocument(
documents[0]._self,
requestOptions,
function (err, updatedDocument, responseOptions) {
if (err) throw err;
responseBody.deleted++;
documents.shift();
// Try updating the next document in the array.
tryDelete(documents);
}
);
if (!isAccepted) {
response.setBody(responseBody);
}
}
}
}
Furthermore, as I know, stored procedure has 5 seconds execute limitation. If you crash into the timeout error, you could pass the continuation token as parameter into stored procedure and execute stored procedure several times.
Any concern, please let me know. Thank you.