123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188 |
- #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;
- };
- }
- #endif
|