I'm constructing a simple search form for our support ticket database using Lucene.Net, and I want to add the ability to filter, for example to filter results by ticket status. Whats the best way to do this? As far as I can see the options I have are:
- Include all the terms I want to filter by in my index, and filter using Lucene.Net
- Apply the filter after getting the search results from Lucene by going to the database to filter out results that Lucene returned that aren't valid for the filter.
Option 1 will inflate the size of my index more and more for each extra field I want to filter by. Option 2 on the other hand will inflate the size of my index, cause problems when adding new fields to filter by and also makes paging more tricky.
Is there an obvious choice here, or are combinations of both acceptable? (and is there a 3rd option that I cant see?)