mirror of
https://github.com/MariaDB/server.git
synced 2025-01-24 07:44:22 +01:00
114 lines
3.7 KiB
C++
114 lines
3.7 KiB
C++
/* 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 */
|
|
|
|
/*****************************************************************************
|
|
* Name: NdbResultSet.hpp
|
|
* Include:
|
|
* Link:
|
|
* Author: Martin Sköld
|
|
* Date: 2002-04-01
|
|
* Version: 0.1
|
|
* Description: Cursor class
|
|
* Documentation:
|
|
* Adjust: 2002-04-01 Martin Sköld First version.
|
|
****************************************************************************/
|
|
|
|
#ifndef NdbResultSet_H
|
|
#define NdbResultSet_H
|
|
|
|
|
|
#include <NdbCursorOperation.hpp>
|
|
#include <NdbIndexOperation.hpp>
|
|
#include <NdbScanOperation.hpp>
|
|
|
|
/**
|
|
* @class NdbResultSet
|
|
* @brief NdbResultSet contains a NdbCursorOperation.
|
|
*/
|
|
class NdbResultSet
|
|
{
|
|
friend class NdbCursorOperation;
|
|
|
|
public:
|
|
|
|
/**
|
|
* Get the next tuple in a scan transaction.
|
|
*
|
|
* After each call to NdbResult::nextResult
|
|
* the buffers and NdbRecAttr objects defined in
|
|
* NdbOperation::getValue are updated with values
|
|
* from the scanned tuple.
|
|
*
|
|
* @param fetchAllowed If set to false, then fetching is disabled
|
|
*
|
|
* The NDB API will contact the NDB Kernel for more tuples
|
|
* when necessary to do so unless you set the fetchAllowed
|
|
* to false.
|
|
* This will force NDB to process any records it
|
|
* already has in it's caches. When there are no more cached
|
|
* records it will return 2. You must then call nextResult
|
|
* with fetchAllowed = true in order to contact NDB for more
|
|
* records.
|
|
*
|
|
* fetchAllowed = false is useful when you want to update or
|
|
* delete all the records fetched in one transaction(This will save a
|
|
* lot of round trip time and make updates or deletes of scanned
|
|
* records a lot faster).
|
|
* While nextResult(false)
|
|
* returns 0 take over the record to another transaction. When
|
|
* nextResult(false) returns 2 you must execute and commit the other
|
|
* transaction. This will cause the locks to be transferred to the
|
|
* other transaction, updates or deletes will be made and then the
|
|
* locks will be released.
|
|
* After that, call nextResult(true) which will fetch new records and
|
|
* cache them in the NdbApi.
|
|
*
|
|
* @note If you don't take over the records to another transaction the
|
|
* locks on those records will be released the next time NDB Kernel
|
|
* is contacted for more records.
|
|
*
|
|
* @note Please contact for examples of efficient scan
|
|
* updates and deletes.
|
|
*
|
|
* @note See ndb/examples/ndbapi_scan_example for usage.
|
|
*
|
|
* @return
|
|
* - -1: if unsuccessful,<br>
|
|
* - 0: if another tuple was received, and<br>
|
|
* - 1: if there are no more tuples to scan.
|
|
* - 2: if there are no more cached records in NdbApi
|
|
*/
|
|
int nextResult(bool fetchAllowed = true);
|
|
|
|
void close();
|
|
|
|
NdbOperation* updateTuple();
|
|
NdbOperation* updateTuple(NdbConnection* takeOverTransaction);
|
|
|
|
int deleteTuple();
|
|
int deleteTuple(NdbConnection* takeOverTransaction);
|
|
|
|
private:
|
|
NdbResultSet(NdbCursorOperation*);
|
|
|
|
~NdbResultSet();
|
|
|
|
void init();
|
|
|
|
NdbCursorOperation* m_operation;
|
|
};
|
|
|
|
#endif
|