File: QualifierUtil.java

package info (click to toggle)
derby 10.14.2.0-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 79,056 kB
  • sloc: java: 691,961; sql: 42,686; xml: 20,512; sh: 3,373; sed: 96; makefile: 60
file content (137 lines) | stat: -rw-r--r-- 4,131 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
/*

   Derby - Class org.apache.derbyTesting.unitTests.store..QualifierUtil

   Licensed to the Apache Software Foundation (ASF) under one or more
   contributor license agreements.  See the NOTICE file distributed with
   this work for additional information regarding copyright ownership.
   The ASF licenses this file to You under the Apache License, Version 2.0
   (the "License"); you may not use this file except in compliance with
   the License.  You may obtain a copy of the License at

      http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.

 */

package org.apache.derbyTesting.unitTests.store;

import org.apache.derby.iapi.store.access.Qualifier;

import org.apache.derby.iapi.types.DataValueDescriptor;

class QualifierUtil implements Qualifier 
{
    private int                 column_id;
    private DataValueDescriptor key_val;
    private int                 operator;
    private boolean             negateCompareResult;
    private boolean             orderedNulls;
    private boolean             unknownRV;

    /**
     * Constuctor
     */
    public QualifierUtil(
    int                 column_id,
    DataValueDescriptor key_val,
    int                 operator,
    boolean             negateCompareResult,
    boolean             orderedNulls,
    boolean             unknownRV)
    {
        this.column_id              = column_id;
        this.key_val                = key_val;
        this.operator               = operator;
        this.negateCompareResult    = negateCompareResult;
        this.orderedNulls           = orderedNulls;
        this.unknownRV              = unknownRV;
    }

    /** Qualifier interface: **/

    /** Get the id of the column to be qualified. **/
    public int getColumnId()
    {
        return(this.column_id);
    }

    /** Get the value that the column is to be compared to. **/
    public DataValueDescriptor getOrderable()
    {
        return(this.key_val);
    }

    /** Get the operator to use in the comparison. 
     *
     *  @see DataValueDescriptor#compare
     **/
    public int getOperator()
    {
        return(this.operator);
    }

    /** Should the result of the compare be negated?
     *
     *  @see DataValueDescriptor#compare
     **/
    public boolean negateCompareResult()
    {
        return(this.negateCompareResult);
    }

    /** Get the getOrderedNulls argument to use in the comparison. 
     *  
     *  @see DataValueDescriptor#compare
     **/
    public boolean getOrderedNulls()
    {
        return(this.orderedNulls);
    }

    /** Get the getOrderedNulls argument to use in the comparison.
     *  
     *  @see DataValueDescriptor#compare
     **/
    public boolean getUnknownRV()
    {
        return(this.unknownRV);
    }

	/** Clear the DataValueDescriptor cache, if one exists.
	 *  (The DataValueDescriptor can be 1 of 3 types:
	 *		o  VARIANT		  - cannot be cached as its value can 
	 *							vary within a scan
	 *		o  SCAN_INVARIANT - can be cached within a scan as its
	 *							value will not change within a scan
	 *		o  QUERY_INVARIANT- can be cached across the life of the query
	 *							as its value will never change
	 *		o  CONSTANT		  - can be cached across executions
     *  
     *  @see Qualifier#getUnknownRV
	 */
	public void clearOrderableCache()
	{
		// No Orderable caching here
	}

	/** 
	 * This method reinitializes all the state of
	 * the Qualifier.  It is used to distinguish between
	 * resetting something that is query invariant
	 * and something that is constant over every
	 * execution of a query.  Basically, clearOrderableCache()
	 * will only clear out its cache if it is a VARIANT
	 * or SCAN_INVARIANT value.  However, each time a
	 * query is executed, the QUERY_INVARIANT qualifiers need
	 * to be reset.
	 */
	public void reinitialize()
	{
	}
}