2004-05-26 13:24:14 +02:00
|
|
|
/* Copyright (C) 2003 MySQL AB
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
|
|
|
|
#ifndef NdbIndexScanOperation_H
|
|
|
|
#define NdbIndexScanOperation_H
|
|
|
|
|
|
|
|
#include <NdbScanOperation.hpp>
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @class NdbIndexScanOperation
|
|
|
|
* @brief Class of scan operations for use to scan ordered index
|
|
|
|
*/
|
|
|
|
class NdbIndexScanOperation : public NdbScanOperation {
|
|
|
|
friend class Ndb;
|
|
|
|
friend class NdbConnection;
|
|
|
|
friend class NdbResultSet;
|
|
|
|
friend class NdbOperation;
|
|
|
|
friend class NdbScanOperation;
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* readTuples returns a NdbResultSet where tuples are stored.
|
|
|
|
* Tuples are not stored in NdbResultSet until execute(NoCommit)
|
|
|
|
* has been executed and nextResult has been called.
|
|
|
|
*
|
|
|
|
* @param parallel Scan parallelism
|
|
|
|
* @param batch No of rows to fetch from each fragment at a time
|
|
|
|
* @param LockMode Scan lock handling
|
|
|
|
* @param order_by Order result set in index order
|
|
|
|
* @returns NdbResultSet.
|
|
|
|
* @see NdbScanOperation::readTuples
|
|
|
|
*/
|
|
|
|
NdbResultSet* readTuples(LockMode = LM_Read,
|
|
|
|
Uint32 batch = 0,
|
|
|
|
Uint32 parallel = 0,
|
|
|
|
bool order_by = false);
|
|
|
|
|
|
|
|
inline NdbResultSet* readTuples(int parallell){
|
|
|
|
return readTuples(LM_Read, 0, parallell, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline NdbResultSet* readTuplesExclusive(int parallell = 0){
|
|
|
|
return readTuples(LM_Exclusive, 0, parallell, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Define Range Scan
|
|
|
|
*
|
|
|
|
* A range scan is a scan on an ordered index. The operation is on
|
|
|
|
* the index table but tuples are returned from the primary table.
|
|
|
|
* The index contains all tuples where at least one index key has not
|
|
|
|
* null value.
|
|
|
|
*
|
|
|
|
* A range scan is currently opened via a normal open scan method.
|
|
|
|
* Bounds can be defined for each index key. After setting bounds,
|
|
|
|
* usual scan methods can be used (get value, interpreter, take over).
|
|
|
|
* These operate on the primary table.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Type of ordered index key bound. The values (0-4) will not change
|
|
|
|
* and can be used explicitly (e.g. they could be computed).
|
|
|
|
*/
|
|
|
|
enum BoundType {
|
|
|
|
BoundLE = 0, ///< lower bound,
|
|
|
|
BoundLT = 1, ///< lower bound, strict
|
|
|
|
BoundGE = 2, ///< upper bound
|
|
|
|
BoundGT = 3, ///< upper bound, strict
|
|
|
|
BoundEQ = 4 ///< equality
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Define bound on index key in range scan.
|
|
|
|
*
|
2004-07-27 13:20:37 +02:00
|
|
|
* Each index key can have lower and/or upper bound, or can be set
|
|
|
|
* equal to a value. The bounds can be defined in any order but
|
|
|
|
* a duplicate definition is an error.
|
2004-05-26 13:24:14 +02:00
|
|
|
*
|
2004-07-27 13:20:37 +02:00
|
|
|
* The bounds must specify a single range i.e. they are on an initial
|
|
|
|
* sequence of index keys and the condition is equality for all but
|
|
|
|
* (at most) the last key which has a lower and/or upper bound.
|
2004-05-26 13:24:14 +02:00
|
|
|
*
|
2004-07-27 13:20:37 +02:00
|
|
|
* NULL is treated like a normal value which is less than any not-NULL
|
|
|
|
* value and equal to another NULL value. To search for NULL use
|
|
|
|
* setBound with null pointer (0).
|
2004-05-26 13:24:14 +02:00
|
|
|
*
|
2004-07-27 13:20:37 +02:00
|
|
|
* An index stores also all-NULL keys (this may become optional).
|
|
|
|
* Doing index scan with empty bound set returns all table tuples.
|
2004-05-26 13:24:14 +02:00
|
|
|
*
|
|
|
|
* @param attrName Attribute name, alternatively:
|
2004-07-27 13:20:37 +02:00
|
|
|
* @param anAttrId Index column id (starting from 0)
|
2004-05-26 13:24:14 +02:00
|
|
|
* @param type Type of bound
|
2004-07-27 13:20:37 +02:00
|
|
|
* @param value Pointer to bound value, 0 for NULL
|
2004-05-26 13:24:14 +02:00
|
|
|
* @param len Value length in bytes.
|
|
|
|
* Fixed per datatype and can be omitted
|
|
|
|
* @return 0 if successful otherwise -1
|
|
|
|
*/
|
|
|
|
int setBound(const char* attr, int type, const void* aValue, Uint32 len = 0);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Define bound on index key in range scan using index column id.
|
|
|
|
* See the other setBound() method for details.
|
|
|
|
*/
|
|
|
|
int setBound(Uint32 anAttrId, int type, const void* aValue, Uint32 len = 0);
|
|
|
|
|
|
|
|
/** @} *********************************************************************/
|
|
|
|
|
|
|
|
private:
|
|
|
|
NdbIndexScanOperation(Ndb* aNdb);
|
|
|
|
virtual ~NdbIndexScanOperation();
|
|
|
|
|
|
|
|
int setBound(const NdbColumnImpl*, int type, const void* aValue, Uint32 len);
|
2004-07-05 20:41:06 +02:00
|
|
|
int saveBoundATTRINFO();
|
2004-05-26 13:24:14 +02:00
|
|
|
|
|
|
|
virtual int equal_impl(const NdbColumnImpl*, const char*, Uint32);
|
|
|
|
virtual NdbRecAttr* getValue_impl(const NdbColumnImpl*, char*);
|
|
|
|
|
|
|
|
void fix_get_values();
|
|
|
|
int next_result_ordered(bool fetchAllowed);
|
|
|
|
int send_next_scan_ordered(Uint32 idx);
|
|
|
|
int compare(Uint32 key, Uint32 cols, const NdbReceiver*, const NdbReceiver*);
|
|
|
|
|
|
|
|
Uint32 m_sort_columns;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|