189 lines
4.8 KiB
C
189 lines
4.8 KiB
C
|
/*
|
||
|
* Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved.
|
||
|
*
|
||
|
* This program is free software; you can redistribute it and/or modify
|
||
|
* it under the terms of the GNU General Public License, version 2.0, as
|
||
|
* published by the Free Software Foundation.
|
||
|
*
|
||
|
* This program is also distributed with certain software (including
|
||
|
* but not limited to OpenSSL) that is licensed under separate terms,
|
||
|
* as designated in a particular file or component or in included license
|
||
|
* documentation. The authors of MySQL hereby grant you an
|
||
|
* additional permission to link the program and your derivative works
|
||
|
* with the separately licensed software that they have included with
|
||
|
* MySQL.
|
||
|
*
|
||
|
* Without limiting anything contained in the foregoing, this file,
|
||
|
* which is part of MySQL Connector/C++, is also subject to the
|
||
|
* Universal FOSS Exception, version 1.0, a copy of which can be found at
|
||
|
* http://oss.oracle.com/licenses/universal-foss-exception.
|
||
|
*
|
||
|
* 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, version 2.0, 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.,
|
||
|
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||
|
*/
|
||
|
|
||
|
|
||
|
|
||
|
#ifndef _SQL_RESULTSET_H_
|
||
|
#define _SQL_RESULTSET_H_
|
||
|
|
||
|
#include "config.h"
|
||
|
|
||
|
#include <list>
|
||
|
#include <map>
|
||
|
#include <iostream>
|
||
|
#include "sqlstring.h"
|
||
|
#include "resultset_metadata.h"
|
||
|
|
||
|
|
||
|
namespace sql
|
||
|
{
|
||
|
|
||
|
class Statement;
|
||
|
|
||
|
class RowID
|
||
|
{
|
||
|
public:
|
||
|
virtual ~RowID() {}
|
||
|
};
|
||
|
|
||
|
class ResultSet
|
||
|
{
|
||
|
public:
|
||
|
enum
|
||
|
{
|
||
|
CLOSE_CURSORS_AT_COMMIT,
|
||
|
HOLD_CURSORS_OVER_COMMIT
|
||
|
};
|
||
|
enum
|
||
|
{
|
||
|
CONCUR_READ_ONLY,
|
||
|
CONCUR_UPDATABLE
|
||
|
};
|
||
|
enum
|
||
|
{
|
||
|
FETCH_FORWARD,
|
||
|
FETCH_REVERSE,
|
||
|
FETCH_UNKNOWN
|
||
|
};
|
||
|
typedef enum
|
||
|
{
|
||
|
TYPE_FORWARD_ONLY,
|
||
|
TYPE_SCROLL_INSENSITIVE,
|
||
|
TYPE_SCROLL_SENSITIVE
|
||
|
} enum_type;
|
||
|
|
||
|
virtual ~ResultSet() {}
|
||
|
|
||
|
virtual bool absolute(int row) = 0;
|
||
|
|
||
|
virtual void afterLast() = 0;
|
||
|
|
||
|
virtual void beforeFirst() = 0;
|
||
|
|
||
|
virtual void cancelRowUpdates() = 0;
|
||
|
|
||
|
virtual void clearWarnings() = 0;
|
||
|
|
||
|
virtual void close() = 0;
|
||
|
|
||
|
virtual uint32_t findColumn(const sql::SQLString& columnLabel) const = 0;
|
||
|
|
||
|
virtual bool first() = 0;
|
||
|
|
||
|
virtual std::istream * getBlob(uint32_t columnIndex) const = 0;
|
||
|
virtual std::istream * getBlob(const sql::SQLString& columnLabel) const = 0;
|
||
|
|
||
|
virtual bool getBoolean(uint32_t columnIndex) const = 0;
|
||
|
virtual bool getBoolean(const sql::SQLString& columnLabel) const = 0;
|
||
|
|
||
|
virtual int getConcurrency() = 0;
|
||
|
virtual SQLString getCursorName() = 0;
|
||
|
|
||
|
virtual long double getDouble(uint32_t columnIndex) const = 0;
|
||
|
virtual long double getDouble(const sql::SQLString& columnLabel) const = 0;
|
||
|
|
||
|
virtual int getFetchDirection() = 0;
|
||
|
virtual size_t getFetchSize() = 0;
|
||
|
virtual int getHoldability() = 0;
|
||
|
|
||
|
virtual int32_t getInt(uint32_t columnIndex) const = 0;
|
||
|
virtual int32_t getInt(const sql::SQLString& columnLabel) const = 0;
|
||
|
|
||
|
virtual uint32_t getUInt(uint32_t columnIndex) const = 0;
|
||
|
virtual uint32_t getUInt(const sql::SQLString& columnLabel) const = 0;
|
||
|
|
||
|
virtual int64_t getInt64(uint32_t columnIndex) const = 0;
|
||
|
virtual int64_t getInt64(const sql::SQLString& columnLabel) const = 0;
|
||
|
|
||
|
virtual uint64_t getUInt64(uint32_t columnIndex) const = 0;
|
||
|
virtual uint64_t getUInt64(const sql::SQLString& columnLabel) const = 0;
|
||
|
|
||
|
virtual ResultSetMetaData * getMetaData() const = 0;
|
||
|
|
||
|
virtual size_t getRow() const = 0;
|
||
|
|
||
|
virtual RowID * getRowId(uint32_t columnIndex) = 0;
|
||
|
virtual RowID * getRowId(const sql::SQLString & columnLabel) = 0;
|
||
|
|
||
|
virtual const Statement * getStatement() const = 0;
|
||
|
|
||
|
virtual SQLString getString(uint32_t columnIndex) const = 0;
|
||
|
virtual SQLString getString(const sql::SQLString& columnLabel) const = 0;
|
||
|
|
||
|
virtual enum_type getType() const = 0;
|
||
|
|
||
|
virtual void getWarnings() = 0;
|
||
|
|
||
|
virtual void insertRow() = 0;
|
||
|
|
||
|
virtual bool isAfterLast() const = 0;
|
||
|
|
||
|
virtual bool isBeforeFirst() const = 0;
|
||
|
|
||
|
virtual bool isClosed() const = 0;
|
||
|
|
||
|
virtual bool isFirst() const = 0;
|
||
|
|
||
|
virtual bool isLast() const = 0;
|
||
|
|
||
|
virtual bool isNull(uint32_t columnIndex) const = 0;
|
||
|
virtual bool isNull(const sql::SQLString& columnLabel) const = 0;
|
||
|
|
||
|
virtual bool last() = 0;
|
||
|
|
||
|
virtual bool next() = 0;
|
||
|
|
||
|
virtual void moveToCurrentRow() = 0;
|
||
|
|
||
|
virtual void moveToInsertRow() = 0;
|
||
|
|
||
|
virtual bool previous() = 0;
|
||
|
|
||
|
virtual void refreshRow() = 0;
|
||
|
|
||
|
virtual bool relative(int rows) = 0;
|
||
|
|
||
|
virtual bool rowDeleted() = 0;
|
||
|
|
||
|
virtual bool rowInserted() = 0;
|
||
|
|
||
|
virtual bool rowUpdated() = 0;
|
||
|
|
||
|
virtual void setFetchSize(size_t rows) = 0;
|
||
|
|
||
|
virtual size_t rowsCount() const = 0;
|
||
|
|
||
|
virtual bool wasNull() const = 0;
|
||
|
};
|
||
|
|
||
|
} /* namespace sql */
|
||
|
|
||
|
#endif /* _SQL_RESULTSET_H_ */
|