Reputation: 315
How can I query a Solr instance for all (or prefixed) field names?
I want to use dynamic fields where I do not know how many may exist e.g: category_0_s
, category_1_s
etc.
Preferably I'd like to use a prefix e.g. category_
Upvotes: 26
Views: 23733
Reputation: 3791
If you need to do this from your Java application you can use Solrj and LukeRequestRequestHandler.
Your code would look like this.
LukeRequest lukeRequest = new LukeRequest();
lukeRequest.setNumTerms(0);
LukeResponse lukeResponse = lukeRequest.process(server);
Map<String, FieldInfo> fieldInfoMap = lukeResponse.getFieldInfo();
for (Entry<String, FieldInfo> entry : fieldInfoMap.entrySet()) {
String fieldName = entry.getKey();
FieldInfo fieldInfo = entry.getValue();
// process fieldInfo
}
Upvotes: 1
Reputation: 1830
This query will return a comma-separated list of all the fields that are in use, including dynamic ones.
select?q=*:*&wt=csv&rows=0&facet
To answer the original question, this is how to get a list of all the fields starting with category_
select?q=*:*&wt=csv&rows=0&facet&fl=category_*
The presence of the facet
parameter is needed to make this query work on newer versions of Solr. On older versions, it will work without it.
On older versions, a wildcard in the fl
parameter won't work.
Upvotes: 52
Reputation: 6928
Use the luke handler:
http://solr:8983/solr/admin/luke?numTerms=0
Use a xpath to get all the field which has the tag dynamicBase matching the dynamic fields definition you are looking for.
Upvotes: 25