Class BigIntegerPoint
- java.lang.Object
- 
- org.apache.lucene.document.Field
- 
- org.apache.lucene.document.BigIntegerPoint
 
 
- 
- All Implemented Interfaces:
- IndexableField
 
 public class BigIntegerPoint extends Field An indexed 128-bitBigIntegerfield.Finding all documents within an N-dimensional shape or range at search time is efficient. Multiple values for the same field in one document is allowed. This field defines static factory methods for creating common queries: - newExactQuery(String, BigInteger)for matching an exact 1D point.
- newSetQuery(String, BigInteger...)for matching a set of 1D values.
- newRangeQuery(String, BigInteger, BigInteger)for matching a 1D range.
- newRangeQuery(String, BigInteger[], BigInteger[])for matching points/ranges in n-dimensional space.
 - See Also:
- PointValues
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from class org.apache.lucene.document.FieldField.Store
 
- 
 - 
Field SummaryFields Modifier and Type Field Description static intBYTESThe number of bytes per dimension: 128 bits.static BigIntegerMAX_VALUEA constant holding the maximum value a BigIntegerPoint can have, 2127-1.static BigIntegerMIN_VALUEA constant holding the minimum value a BigIntegerPoint can have, -2127.- 
Fields inherited from class org.apache.lucene.document.FieldfieldsData, name, tokenStream, type
 
- 
 - 
Constructor SummaryConstructors Constructor Description BigIntegerPoint(String name, BigInteger... point)Creates a new BigIntegerPoint, indexing the provided N-dimensional big integer point.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static BigIntegerdecodeDimension(byte[] value, int offset)Decode single BigInteger dimensionstatic voidencodeDimension(BigInteger value, byte[] dest, int offset)Encode single BigInteger dimensionstatic QuerynewExactQuery(String field, BigInteger value)Create a query for matching an exact big integer value.static QuerynewRangeQuery(String field, BigInteger[] lowerValue, BigInteger[] upperValue)Create a range query for n-dimensional big integer values.static QuerynewRangeQuery(String field, BigInteger lowerValue, BigInteger upperValue)Create a range query for big integer values.static QuerynewSetQuery(String field, BigInteger... values)Create a query matching any of the specified 1D values.NumbernumericValue()voidsetBigIntegerValues(BigInteger... point)Change the values of this fieldvoidsetBytesValue(BytesRef bytes)StringtoString()- 
Methods inherited from class org.apache.lucene.document.FieldbinaryValue, fieldType, getCharSequenceValue, name, readerValue, setBytesValue, setByteValue, setDoubleValue, setFloatValue, setIntValue, setLongValue, setReaderValue, setShortValue, setStringValue, setTokenStream, stringValue, tokenStream, tokenStreamValue
 
- 
 
- 
- 
- 
Field Detail- 
BYTESpublic static final int BYTES The number of bytes per dimension: 128 bits.- See Also:
- Constant Field Values
 
 - 
MIN_VALUEpublic static final BigInteger MIN_VALUE A constant holding the minimum value a BigIntegerPoint can have, -2127.
 - 
MAX_VALUEpublic static final BigInteger MAX_VALUE A constant holding the maximum value a BigIntegerPoint can have, 2127-1.
 
- 
 - 
Constructor Detail- 
BigIntegerPointpublic BigIntegerPoint(String name, BigInteger... point) Creates a new BigIntegerPoint, indexing the provided N-dimensional big integer point.- Parameters:
- name- field name
- point- BigInteger[] value
- Throws:
- IllegalArgumentException- if the field name or value is null.
 
 
- 
 - 
Method Detail- 
setBigIntegerValuespublic void setBigIntegerValues(BigInteger... point) Change the values of this field
 - 
setBytesValuepublic void setBytesValue(BytesRef bytes) - Overrides:
- setBytesValuein class- Field
 
 - 
numericValuepublic Number numericValue() - Specified by:
- numericValuein interface- IndexableField
- Overrides:
- numericValuein class- Field
 
 - 
encodeDimensionpublic static void encodeDimension(BigInteger value, byte[] dest, int offset) Encode single BigInteger dimension
 - 
decodeDimensionpublic static BigInteger decodeDimension(byte[] value, int offset) Decode single BigInteger dimension
 - 
newExactQuerypublic static Query newExactQuery(String field, BigInteger value) Create a query for matching an exact big integer value.This is for simple one-dimension points, for multidimensional points use newRangeQuery(String, BigInteger[], BigInteger[])instead.- Parameters:
- field- field name. must not be- null.
- value- exact value. must not be- null.
- Returns:
- a query matching documents with this exact value
- Throws:
- IllegalArgumentException- if- fieldis null or- valueis null.
 
 - 
newRangeQuerypublic static Query newRangeQuery(String field, BigInteger lowerValue, BigInteger upperValue) Create a range query for big integer values.This is for simple one-dimension ranges, for multidimensional ranges use newRangeQuery(String, BigInteger[], BigInteger[])instead.You can have half-open ranges (which are in fact </≤ or >/≥ queries) by setting lowerValue = BigIntegerPoint.MIN_VALUEorupperValue = BigIntegerPoint.MAX_VALUE.Ranges are inclusive. For exclusive ranges, pass lowerValue.add(BigInteger.ONE)orupperValue.subtract(BigInteger.ONE)- Parameters:
- field- field name. must not be- null.
- lowerValue- lower portion of the range (inclusive). must not be- null.
- upperValue- upper portion of the range (inclusive). must not be- null.
- Returns:
- a query matching documents within this range.
- Throws:
- IllegalArgumentException- if- fieldis null,- lowerValueis null, or- upperValueis null.
 
 - 
newRangeQuerypublic static Query newRangeQuery(String field, BigInteger[] lowerValue, BigInteger[] upperValue) Create a range query for n-dimensional big integer values.You can have half-open ranges (which are in fact </≤ or >/≥ queries) by setting lowerValue[i] = BigIntegerPoint.MIN_VALUEorupperValue[i] = BigIntegerPoint.MAX_VALUE.Ranges are inclusive. For exclusive ranges, pass lowerValue[i].add(BigInteger.ONE)orupperValue[i].subtract(BigInteger.ONE)- Parameters:
- field- field name. must not be- null.
- lowerValue- lower portion of the range (inclusive). must not be- null.
- upperValue- upper portion of the range (inclusive). must not be- null.
- Returns:
- a query matching documents within this range.
- Throws:
- IllegalArgumentException- if- fieldis null, if- lowerValueis null, if- upperValueis null, or if- lowerValue.length != upperValue.length
 
 - 
newSetQuerypublic static Query newSetQuery(String field, BigInteger... values) Create a query matching any of the specified 1D values. This is the points equivalent ofTermsQuery.- Parameters:
- field- field name. must not be- null.
- values- all values to match
 
 
- 
 
-