-
Notifications
You must be signed in to change notification settings - Fork 470
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
after_commit should delete instances out of scope (soft-deleting) #1216
Comments
Hi Aleksander Sorry for not responding sooner to this. I'm not quite sure if I understand your question properly, so let me confirm: You are wanting to mark records as deleted within Sphinx indices when your records are in certain 'soft-deleted' states - and then when those records are later updated, you want to ensure the record is still kept out of Sphinx (unless it's no longer considered 'soft-deleted'). Is that correct? If so, I would recommend looking at the state of your record rather than querying against Sphinx (or your database) to determine whether it should be updated vs deleted. Is that possible in your situation? |
It is indeed possible to look at object state and decide that. But it requires handling models on a case by case basis. We define a scope for the index anyway. On indexing no objects out of scope are selected. This makes it a universal way to check whether an object needs to be in the index or removed from it. In my particular case we do that processing in a background job (#1215) so a database query is necessary anyway. I see that it introduces some performance penalty for simple use cases, on the other hand it may save server RAM and I expect queries on the primary key to be fast. I don't know how often and with what use cases one approach or the other will have a noticeable difference. I only know it affects us :) |
If the scoped Sphinx query approach is working for you, wonderful :) I guess I would have looked into having a method with the same name in all indexed models which determines whether a record should be indexed or not, and then call that - to save the search query - but not a big deal either way. Are there any questions remaining for this issue? Or can it be closed? |
Well, the idea is to make this a default behavior - remove indexed models that are out of scope when scope is provided. But if you don't want such behavior, then you can close I guess. Thank you for the attention in either case. |
Coming back to this after a few months, I don't think I'm going to make this change, but appreciate the suggestion. Certainly if you or others find more reasons for it, I'm happy to discuss further! |
In #1057 a use case for soft-deleting documents is presented. In my project soft-deleting is implemented in a different way (state machine). But I think it is possible to cover all cases. Just not sure about the performance impact.
The idea is to check whether object is part of index scope in the
after_commit
callback. If it is not, then delete it instead of indexing it.The approach can be something like:
The text was updated successfully, but these errors were encountered: