16 #include "pqxx/compiler-public.hxx" 17 #include "pqxx/internal/compiler-internal-pre.hxx" 23 #include "pqxx/except.hxx" 24 #include "pqxx/types.hxx" 25 #include "pqxx/util.hxx" 26 #include "pqxx/zview.hxx" 28 #include "pqxx/internal/encodings.hxx" 39 class result_connection;
40 class result_creation;
41 class result_pipeline;
43 class result_sql_cursor;
83 m_data(make_data_pointer()),
85 m_encoding(internal::encoding_group::MONOBYTE)
95 [[nodiscard]]
bool operator==(
result const &)
const noexcept;
98 return not operator==(rhs);
102 [[nodiscard]] const_reverse_iterator rbegin()
const;
103 [[nodiscard]] const_reverse_iterator crbegin()
const;
104 [[nodiscard]] const_reverse_iterator rend()
const;
105 [[nodiscard]] const_reverse_iterator crend()
const;
107 [[nodiscard]] const_iterator begin() const noexcept;
108 [[nodiscard]] const_iterator cbegin() const noexcept;
109 [[nodiscard]] inline const_iterator end() const noexcept;
110 [[nodiscard]] inline const_iterator cend() const noexcept;
112 [[nodiscard]] reference front() const noexcept;
113 [[nodiscard]] reference back() const noexcept;
115 [[nodiscard]] PQXX_PURE size_type size() const noexcept;
116 [[nodiscard]] PQXX_PURE
bool empty() const noexcept;
117 [[nodiscard]]
size_type capacity() const noexcept {
return size(); }
119 void swap(
result &) noexcept;
121 [[nodiscard]]
row operator[](size_type i)
const noexcept;
122 row at(size_type)
const;
134 [[nodiscard]] PQXX_PURE
row_size_type columns() const noexcept;
143 return column_number(name.c_str());
149 return column_number(name.
c_str());
153 [[nodiscard]]
char const *column_name(
row_size_type number)
const;
159 template<
typename STRING>[[nodiscard]] oid
column_type(STRING col_name)
const 161 return column_type(column_number(col_name));
168 template<
typename STRING>
171 return column_table(column_number(col_name));
178 template<
typename STRING>
181 return table_column(column_number(col_name));
186 [[nodiscard]] PQXX_PURE std::string
const &query() const noexcept;
192 [[nodiscard]] PQXX_PURE oid inserted_oid() const;
199 [[nodiscard]] PQXX_PURE size_type affected_rows() const;
203 using data_pointer = std::shared_ptr<internal::pq::PGresult const>;
210 make_data_pointer(internal::pq::PGresult const *res =
nullptr)
215 friend class pqxx::internal::gate::result_pipeline;
216 PQXX_PURE std::shared_ptr<std::string> query_ptr() const noexcept
222 std::shared_ptr<std::string> m_query;
224 internal::encoding_group m_encoding;
226 static std::string
const s_empty_string;
234 friend class pqxx::internal::gate::result_creation;
236 internal::pq::PGresult *rhs, std::shared_ptr<std::string> query,
237 internal::encoding_group enc);
239 PQXX_PRIVATE
void check_status()
const;
241 friend class pqxx::internal::gate::result_connection;
242 friend class pqxx::internal::gate::result_row;
243 bool operator!() const noexcept {
return m_data.get() ==
nullptr; }
244 operator bool() const noexcept {
return m_data.get() !=
nullptr; }
246 [[noreturn]] PQXX_PRIVATE
void 247 ThrowSQLError(std::string
const &Err, std::string
const &Query)
const;
248 PQXX_PRIVATE PQXX_PURE
int errorposition()
const;
249 PQXX_PRIVATE std::string StatusError()
const;
251 friend class pqxx::internal::gate::result_sql_cursor;
252 PQXX_PURE
char const *cmd_status() const noexcept;
256 #include "pqxx/internal/compiler-internal-post.hxx" int result_difference_type
Difference between result sizes.
Definition: types.hxx:21
row_size_type column_number(zview name) const
Number of given column (throws exception if it doesn't exist).
Definition: result.hxx:147
Definition: cursor.hxx:219
void clear_result(pq::PGresult const *)
C++ wrapper for libpq's PQclear.
Definition: result.cxx:35
Reverse iterator for result. Use as result::const_reverse_iterator.
Definition: result_iterator.hxx:147
bool operator!=(result const &rhs) const noexcept
Definition: result.hxx:96
result() noexcept
Definition: result.hxx:82
Marker-type wrapper: zero-terminated std::string_view.
Definition: zview.hxx:32
void clear() noexcept
Definition: result.hxx:124
Reference to a field in a result set.
Definition: field.hxx:32
result_size_type size_type
Definition: result.hxx:73
oid column_table(STRING col_name) const
What table did this column come from?
Definition: result.hxx:169
Definition: connection.hxx:59
oid column_type(STRING col_name) const
Return column's type, as an OID from the system catalogue.
Definition: result.hxx:159
size_t field_size_type
Number of bytes in a field of database data.
Definition: types.hxx:30
Iterator for rows in a result. Use as result::const_iterator.
Definition: result_iterator.hxx:35
Result set containing data returned by a query or command.
Definition: result.hxx:70
row_size_type col() const noexcept
Definition: field.hxx:213
int row_size_type
Number of fields in a row of database data.
Definition: types.hxx:24
constexpr char const * c_str() const noexcept
Either a null pointer, or a zero-terminated text buffer.
Definition: zview.hxx:41
int result_size_type
Number of rows in a result set.
Definition: types.hxx:18
Reference to one row in a result.
Definition: row.hxx:38
Dedicated namespace for helper types related to prepared statements.
Definition: array.hxx:25
row_size_type table_column(STRING col_name) const
What column in its table did this column come from?
Definition: result.hxx:179
result_difference_type difference_type
Definition: result.hxx:74