/* * The contents of this file are subject to the Initial * Developer's Public License Version 1.0 (the "License"); * you may not use this file except in compliance with the * License. You may obtain a copy of the License at * http://www.ibphoenix.com/main.nfs?a=ibphoenix&page=ibp_idpl. * * Software distributed under the License is distributed AS IS, * WITHOUT WARRANTY OF ANY KIND, either express or implied. * See the License for the specific language governing rights * and limitations under the License. * * The Original Code was created by Adriano dos Santos Fernandes * for the Firebird Open Source RDBMS project. * * Copyright (c) 2008 Adriano dos Santos Fernandes * and all contributors signed below. * * All Rights Reserved. * Contributor(s): ______________________________________. */ #ifndef JRD_PREPARED_STATEMENT_H #define JRD_PREPARED_STATEMENT_H #include "firebird.h" #include "../jrd/common.h" #include "../jrd/dsc.h" #include "../common/classes/alloc.h" #include "../common/classes/array.h" #include "../common/classes/fb_string.h" #include "../common/classes/MetaName.h" namespace Jrd { class thread_db; class jrd_tra; class Attachment; class dsql_req; class dsql_msg; class ResultSet; class PreparedStatement : public Firebird::PermanentStorage { friend class ResultSet; public: PreparedStatement(thread_db* tdbb, Firebird::MemoryPool& aPool, Attachment* attachment, jrd_tra* transaction, const Firebird::string& text, bool isInternalRequest); ~PreparedStatement(); public: // Escape a metadata name accordingly to SQL rules. static Firebird::string escapeName(const Firebird::MetaName& s) { Firebird::string ret; for (const char* p = s.begin(); p != s.end(); ++p) { ret += *p; if (*p == '\"') ret += '\"'; } return ret; } // Escape a string accordingly to SQL rules. template static Firebird::string escapeString(const T& s) { Firebird::string ret; for (const char* p = s.begin(); p != s.end(); ++p) { ret += *p; if (*p == '\'') ret += '\''; } return ret; } public: void setDesc(thread_db* tdbb, unsigned param, const dsc& value); void setNull(unsigned param) { fb_assert(param > 0); const dsc* desc = &inValues[(param - 1) * 2 + 1]; fb_assert(desc->dsc_dtype == dtype_short); *reinterpret_cast(desc->dsc_address) = -1; } void setString(thread_db* tdbb, unsigned param, const Firebird::AbstractString& value) { fb_assert(param > 0); dsc desc; desc.makeText((USHORT) value.length(), inValues[(param - 1) * 2].getTextType(), (UCHAR*) value.c_str()); setDesc(tdbb, param, desc); } void setString(thread_db* tdbb, unsigned param, const Firebird::MetaName& value) { fb_assert(param > 0); dsc desc; desc.makeText((USHORT) value.length(), inValues[(param - 1) * 2].getTextType(), (UCHAR*) value.c_str()); setDesc(tdbb, param, desc); } void execute(thread_db* tdbb, jrd_tra* transaction); ResultSet* executeQuery(thread_db* tdbb, jrd_tra* transaction); unsigned executeUpdate(thread_db* tdbb, jrd_tra* transaction); int getResultCount() const; dsql_req* getRequest() { return request; } static void parseDsqlMessage(dsql_msg* dsqlMsg, Firebird::Array& values, Firebird::UCharBuffer& blr, Firebird::UCharBuffer& msg); static void generateBlr(const dsc* desc, Firebird::UCharBuffer& blr); private: dsql_req* request; Firebird::Array inValues, outValues; Firebird::UCharBuffer inBlr, outBlr; Firebird::UCharBuffer inMessage, outMessage; ResultSet* resultSet; }; } // namespace #endif // JRD_PREPARED_STATEMENT_H