Mongo C# driver find multiple and delete










0















I'm using collection.FindOneAndDeleteAsync, but this uses a ton of cpu when used to get many documents. What's the best way to go about finding multiple documents(anywhere from 100 to 50k) and delete, using the c# mongo driver?



Thanks










share|improve this question






















  • As long as you don't also need the deleted documents returned, DeleteMany will give you the best performance. Is that an option for you?

    – JohnnyHK
    Nov 15 '18 at 23:05











  • The issue is, that i do. That's why i'm using FindOneAndDelete.

    – Victornor
    Nov 15 '18 at 23:13











  • Would it be better to FindMany and then remove those after?

    – Victornor
    Nov 15 '18 at 23:13











  • @JohnnyHK Thanks. Feel free to add as answer and i'll pick it. Really just needed to know the most efficient way to do this.

    – Victornor
    Nov 17 '18 at 19:31















0















I'm using collection.FindOneAndDeleteAsync, but this uses a ton of cpu when used to get many documents. What's the best way to go about finding multiple documents(anywhere from 100 to 50k) and delete, using the c# mongo driver?



Thanks










share|improve this question






















  • As long as you don't also need the deleted documents returned, DeleteMany will give you the best performance. Is that an option for you?

    – JohnnyHK
    Nov 15 '18 at 23:05











  • The issue is, that i do. That's why i'm using FindOneAndDelete.

    – Victornor
    Nov 15 '18 at 23:13











  • Would it be better to FindMany and then remove those after?

    – Victornor
    Nov 15 '18 at 23:13











  • @JohnnyHK Thanks. Feel free to add as answer and i'll pick it. Really just needed to know the most efficient way to do this.

    – Victornor
    Nov 17 '18 at 19:31













0












0








0








I'm using collection.FindOneAndDeleteAsync, but this uses a ton of cpu when used to get many documents. What's the best way to go about finding multiple documents(anywhere from 100 to 50k) and delete, using the c# mongo driver?



Thanks










share|improve this question














I'm using collection.FindOneAndDeleteAsync, but this uses a ton of cpu when used to get many documents. What's the best way to go about finding multiple documents(anywhere from 100 to 50k) and delete, using the c# mongo driver?



Thanks







c# mongodb






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 15 '18 at 22:57









VictornorVictornor

385




385












  • As long as you don't also need the deleted documents returned, DeleteMany will give you the best performance. Is that an option for you?

    – JohnnyHK
    Nov 15 '18 at 23:05











  • The issue is, that i do. That's why i'm using FindOneAndDelete.

    – Victornor
    Nov 15 '18 at 23:13











  • Would it be better to FindMany and then remove those after?

    – Victornor
    Nov 15 '18 at 23:13











  • @JohnnyHK Thanks. Feel free to add as answer and i'll pick it. Really just needed to know the most efficient way to do this.

    – Victornor
    Nov 17 '18 at 19:31

















  • As long as you don't also need the deleted documents returned, DeleteMany will give you the best performance. Is that an option for you?

    – JohnnyHK
    Nov 15 '18 at 23:05











  • The issue is, that i do. That's why i'm using FindOneAndDelete.

    – Victornor
    Nov 15 '18 at 23:13











  • Would it be better to FindMany and then remove those after?

    – Victornor
    Nov 15 '18 at 23:13











  • @JohnnyHK Thanks. Feel free to add as answer and i'll pick it. Really just needed to know the most efficient way to do this.

    – Victornor
    Nov 17 '18 at 19:31
















As long as you don't also need the deleted documents returned, DeleteMany will give you the best performance. Is that an option for you?

– JohnnyHK
Nov 15 '18 at 23:05





As long as you don't also need the deleted documents returned, DeleteMany will give you the best performance. Is that an option for you?

– JohnnyHK
Nov 15 '18 at 23:05













The issue is, that i do. That's why i'm using FindOneAndDelete.

– Victornor
Nov 15 '18 at 23:13





The issue is, that i do. That's why i'm using FindOneAndDelete.

– Victornor
Nov 15 '18 at 23:13













Would it be better to FindMany and then remove those after?

– Victornor
Nov 15 '18 at 23:13





Would it be better to FindMany and then remove those after?

– Victornor
Nov 15 '18 at 23:13













@JohnnyHK Thanks. Feel free to add as answer and i'll pick it. Really just needed to know the most efficient way to do this.

– Victornor
Nov 17 '18 at 19:31





@JohnnyHK Thanks. Feel free to add as answer and i'll pick it. Really just needed to know the most efficient way to do this.

– Victornor
Nov 17 '18 at 19:31












1 Answer
1






active

oldest

votes


















1














You need to Find the docs you want to delete, and then delete them using DeleteMany with a filter of _id: $in: ids, where ids is an enumerable of the _id values of those documents.



C# example:



public class Entity

public ObjectId id get; set;
public string name get; set;


// Find the documents to delete
var test = db.GetCollection<Entity>("test");
var filter = new BsonDocument();
var docs = test.Find(filter).ToList();

// Get the _id values of the found documents
var ids = docs.Select(d => d.id);

// Create an $in filter for those ids
var idsFilter = Builders<Entity>.Filter.In(d => d.id, ids);

// Delete the documents using the $in filter
var result = test.DeleteMany(idsFilter);





share|improve this answer























  • Thanks, sorry for the delay.

    – Victornor
    Nov 25 '18 at 14:35










Your Answer






StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");

StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53329048%2fmongo-c-sharp-driver-find-multiple-and-delete%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









1














You need to Find the docs you want to delete, and then delete them using DeleteMany with a filter of _id: $in: ids, where ids is an enumerable of the _id values of those documents.



C# example:



public class Entity

public ObjectId id get; set;
public string name get; set;


// Find the documents to delete
var test = db.GetCollection<Entity>("test");
var filter = new BsonDocument();
var docs = test.Find(filter).ToList();

// Get the _id values of the found documents
var ids = docs.Select(d => d.id);

// Create an $in filter for those ids
var idsFilter = Builders<Entity>.Filter.In(d => d.id, ids);

// Delete the documents using the $in filter
var result = test.DeleteMany(idsFilter);





share|improve this answer























  • Thanks, sorry for the delay.

    – Victornor
    Nov 25 '18 at 14:35















1














You need to Find the docs you want to delete, and then delete them using DeleteMany with a filter of _id: $in: ids, where ids is an enumerable of the _id values of those documents.



C# example:



public class Entity

public ObjectId id get; set;
public string name get; set;


// Find the documents to delete
var test = db.GetCollection<Entity>("test");
var filter = new BsonDocument();
var docs = test.Find(filter).ToList();

// Get the _id values of the found documents
var ids = docs.Select(d => d.id);

// Create an $in filter for those ids
var idsFilter = Builders<Entity>.Filter.In(d => d.id, ids);

// Delete the documents using the $in filter
var result = test.DeleteMany(idsFilter);





share|improve this answer























  • Thanks, sorry for the delay.

    – Victornor
    Nov 25 '18 at 14:35













1












1








1







You need to Find the docs you want to delete, and then delete them using DeleteMany with a filter of _id: $in: ids, where ids is an enumerable of the _id values of those documents.



C# example:



public class Entity

public ObjectId id get; set;
public string name get; set;


// Find the documents to delete
var test = db.GetCollection<Entity>("test");
var filter = new BsonDocument();
var docs = test.Find(filter).ToList();

// Get the _id values of the found documents
var ids = docs.Select(d => d.id);

// Create an $in filter for those ids
var idsFilter = Builders<Entity>.Filter.In(d => d.id, ids);

// Delete the documents using the $in filter
var result = test.DeleteMany(idsFilter);





share|improve this answer













You need to Find the docs you want to delete, and then delete them using DeleteMany with a filter of _id: $in: ids, where ids is an enumerable of the _id values of those documents.



C# example:



public class Entity

public ObjectId id get; set;
public string name get; set;


// Find the documents to delete
var test = db.GetCollection<Entity>("test");
var filter = new BsonDocument();
var docs = test.Find(filter).ToList();

// Get the _id values of the found documents
var ids = docs.Select(d => d.id);

// Create an $in filter for those ids
var idsFilter = Builders<Entity>.Filter.In(d => d.id, ids);

// Delete the documents using the $in filter
var result = test.DeleteMany(idsFilter);






share|improve this answer












share|improve this answer



share|improve this answer










answered Nov 17 '18 at 23:16









JohnnyHKJohnnyHK

211k41451375




211k41451375












  • Thanks, sorry for the delay.

    – Victornor
    Nov 25 '18 at 14:35

















  • Thanks, sorry for the delay.

    – Victornor
    Nov 25 '18 at 14:35
















Thanks, sorry for the delay.

– Victornor
Nov 25 '18 at 14:35





Thanks, sorry for the delay.

– Victornor
Nov 25 '18 at 14:35



















draft saved

draft discarded
















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53329048%2fmongo-c-sharp-driver-find-multiple-and-delete%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Top Tejano songwriter Luis Silva dead of heart attack at 64

政党

天津地下鉄3号線