5#if defined(_WIN32) || defined(_WIN64)
10#include "../SqlServerType.hpp"
42 virtual void PlanPostExecuteCallback(std::function<
void()>&&) = 0;
43 virtual void PlanPostProcessOutputColumn(std::function<
void()>&&) = 0;
45 [[nodiscard]]
virtual SqlServerType ServerType()
const noexcept = 0;
46 [[nodiscard]]
virtual std::string
const& DriverName()
const noexcept = 0;
57struct SqlBasicStringOperations;
66concept HasGetStringAndGetLength =
requires(T
const& t) {
67 { t.GetLength() } -> std::same_as<int>;
68 { t.GetString() } -> std::same_as<char const*>;
72concept HasGetStringAndLength =
requires(T
const& t)
74 { t.Length() } -> std::same_as<int>;
75 { t.GetString() } -> std::same_as<char const*>;
83 concept HasSqlViewHelper =
requires(T
const& t) {
84 { SqlViewHelper<T>::View(t) } -> std::convertible_to<std::string_view>;
87 template <
typename CharT>
88 struct SqlViewHelper<std::basic_string<CharT>>
90 static LIGHTWEIGHT_FORCE_INLINE std::basic_string_view<CharT> View(std::basic_string<CharT>
const& str)
noexcept
92 return { str.data(), str.size() };
96 template <detail::HasGetStringAndGetLength CStringLike>
97 struct SqlViewHelper<CStringLike>
99 static LIGHTWEIGHT_FORCE_INLINE std::string_view View(CStringLike
const& str)
noexcept
101 return { str.GetString(),
static_cast<size_t>(str.GetLength()) };
105 template <detail::HasGetStringAndLength StringLike>
106 struct SqlViewHelper<StringLike>
108 static LIGHTWEIGHT_FORCE_INLINE std::string_view View(StringLike
const& str)
noexcept
110 return { str.GetString(),
static_cast<size_t>(str.Length()) };
119concept SqlInputParameterBinder =
requires(SQLHSTMT hStmt, SQLUSMALLINT column, T
const& value, SqlDataBinderCallback& cb) {
120 { SqlDataBinder<T>::InputParameter(hStmt, column, value, cb) } -> std::same_as<SQLRETURN>;
124concept SqlOutputColumnBinder =
125 requires(SQLHSTMT hStmt, SQLUSMALLINT column, T* result, SQLLEN* indicator, SqlDataBinderCallback& cb) {
126 { SqlDataBinder<T>::OutputColumn(hStmt, column, result, indicator, cb) } -> std::same_as<SQLRETURN>;
130concept SqlInputParameterBatchBinder =
131 requires(SQLHSTMT hStmt, SQLUSMALLINT column, std::ranges::range_value_t<T>* result, SqlDataBinderCallback& cb) {
133 SqlDataBinder<std::ranges::range_value_t<T>>::InputParameter(
134 hStmt, column, std::declval<std::ranges::range_value_t<T>>(), cb)
135 } -> std::same_as<SQLRETURN>;
139concept SqlGetColumnNativeType =
140 requires(SQLHSTMT hStmt, SQLUSMALLINT column, T* result, SQLLEN* indicator, SqlDataBinderCallback
const& cb) {
141 { SqlDataBinder<T>::GetColumn(hStmt, column, result, indicator, cb) } -> std::same_as<SQLRETURN>;
145concept SqlDataBinderSupportsInspect =
requires(T
const& value) {
146 { SqlDataBinder<std::remove_cvref_t<T>>::Inspect(value) } -> std::convertible_to<std::string>;
150template <
typename StringType,
typename CharType>
151concept SqlBasicStringBinderConcept =
requires(StringType* str) {
152 { SqlBasicStringOperations<StringType>::Data(str) } -> std::same_as<CharType*>;
153 { SqlBasicStringOperations<StringType>::Size(str) } -> std::same_as<SQLULEN>;
154 { SqlBasicStringOperations<StringType>::Reserve(str,
size_t {}) } -> std::same_as<void>;
155 { SqlBasicStringOperations<StringType>::Resize(str, SQLLEN {}) } -> std::same_as<void>;
156 { SqlBasicStringOperations<StringType>::Clear(str) } -> std::same_as<void>;