xref: /trunk/main/connectivity/source/inc/odbc/OPreparedStatement.hxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir #ifndef _CONNECTIVITY_ODBC_OPREPAREDSTATEMENT_HXX_
29*cdf0e10cSrcweir #define _CONNECTIVITY_ODBC_OPREPAREDSTATEMENT_HXX_
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir #include "odbc/odbcbasedllapi.hxx"
32*cdf0e10cSrcweir #include "odbc/OStatement.hxx"
33*cdf0e10cSrcweir #include <com/sun/star/sdbc/XPreparedStatement.hpp>
34*cdf0e10cSrcweir #include <com/sun/star/sdbc/XParameters.hpp>
35*cdf0e10cSrcweir #include <com/sun/star/sdbc/XResultSetMetaDataSupplier.hpp>
36*cdf0e10cSrcweir #include <com/sun/star/sdbc/XPreparedBatchExecution.hpp>
37*cdf0e10cSrcweir #include <com/sun/star/io/XInputStream.hpp>
38*cdf0e10cSrcweir #include <cppuhelper/implbase5.hxx>
39*cdf0e10cSrcweir 
40*cdf0e10cSrcweir namespace connectivity
41*cdf0e10cSrcweir {
42*cdf0e10cSrcweir     namespace odbc
43*cdf0e10cSrcweir     {
44*cdf0e10cSrcweir 
45*cdf0e10cSrcweir         class OBoundParam;
46*cdf0e10cSrcweir         typedef ::cppu::ImplHelper5<    ::com::sun::star::sdbc::XPreparedStatement,
47*cdf0e10cSrcweir                                         ::com::sun::star::sdbc::XParameters,
48*cdf0e10cSrcweir                                         ::com::sun::star::sdbc::XPreparedBatchExecution,
49*cdf0e10cSrcweir                                         ::com::sun::star::sdbc::XResultSetMetaDataSupplier,
50*cdf0e10cSrcweir                                         ::com::sun::star::lang::XServiceInfo> OPreparedStatement_BASE;
51*cdf0e10cSrcweir 
52*cdf0e10cSrcweir         class OOO_DLLPUBLIC_ODBCBASE OPreparedStatement :
53*cdf0e10cSrcweir                                     public  OStatement_BASE2,
54*cdf0e10cSrcweir                                     public  OPreparedStatement_BASE
55*cdf0e10cSrcweir         {
56*cdf0e10cSrcweir         protected:
57*cdf0e10cSrcweir             struct Parameter
58*cdf0e10cSrcweir             {
59*cdf0e10cSrcweir                 ::com::sun::star::uno::Any  aValue;
60*cdf0e10cSrcweir                 sal_Int32                   nDataType;
61*cdf0e10cSrcweir 
62*cdf0e10cSrcweir                 Parameter(const ::com::sun::star::uno::Any& rValue,
63*cdf0e10cSrcweir                           sal_Int32                         rDataType) : aValue(rValue),nDataType(rDataType)
64*cdf0e10cSrcweir                 {
65*cdf0e10cSrcweir                 }
66*cdf0e10cSrcweir 
67*cdf0e10cSrcweir             };
68*cdf0e10cSrcweir 
69*cdf0e10cSrcweir             ::std::vector< Parameter>                   m_aParameters;
70*cdf0e10cSrcweir             //====================================================================
71*cdf0e10cSrcweir             // Data attributes
72*cdf0e10cSrcweir             //====================================================================
73*cdf0e10cSrcweir             SQLSMALLINT     numParams;      // Number of parameter markers
74*cdf0e10cSrcweir                                             //  for the prepared statement
75*cdf0e10cSrcweir 
76*cdf0e10cSrcweir             OBoundParam*    boundParams;
77*cdf0e10cSrcweir                             // Array of bound parameter
78*cdf0e10cSrcweir                             //  objects.  Each parameter
79*cdf0e10cSrcweir                             //  marker will have a
80*cdf0e10cSrcweir                             //  corresponding object to
81*cdf0e10cSrcweir                             //  hold bind information, and
82*cdf0e10cSrcweir                             //  resulting data.
83*cdf0e10cSrcweir             ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XResultSetMetaData >  m_xMetaData;
84*cdf0e10cSrcweir             sal_Bool                                                                        m_bPrepared;
85*cdf0e10cSrcweir 
86*cdf0e10cSrcweir             void FreeParams();
87*cdf0e10cSrcweir             void putParamData (sal_Int32 index) throw(::com::sun::star::sdbc::SQLException);
88*cdf0e10cSrcweir             void setStream (sal_Int32 ParameterIndex,const ::com::sun::star::uno::Reference< ::com::sun::star::io::XInputStream>& x,
89*cdf0e10cSrcweir                                                         SQLLEN length,sal_Int32 SQLtype) throw(::com::sun::star::sdbc::SQLException);
90*cdf0e10cSrcweir             sal_Int32 getParamLength (  sal_Int32 index);
91*cdf0e10cSrcweir             sal_Int8* getLengthBuf (sal_Int32 index);
92*cdf0e10cSrcweir             sal_Int8* getDataBuf (sal_Int32 index);
93*cdf0e10cSrcweir             sal_Int8* allocBindBuf (    sal_Int32 index,    sal_Int32 bufLen);
94*cdf0e10cSrcweir             void initBoundParam () throw(::com::sun::star::sdbc::SQLException);
95*cdf0e10cSrcweir             void setParameter(sal_Int32 parameterIndex,sal_Int32 _nType,sal_Int32 _nSize,void* _pData);
96*cdf0e10cSrcweir 
97*cdf0e10cSrcweir             sal_Int32 getPrecision ( sal_Int32 sqlType);
98*cdf0e10cSrcweir 
99*cdf0e10cSrcweir             sal_Bool isPrepared() const { return m_bPrepared;}
100*cdf0e10cSrcweir             void prepareStatement();
101*cdf0e10cSrcweir             void checkParameterIndex(sal_Int32 _parameterIndex);
102*cdf0e10cSrcweir             void setDecimal( sal_Int32 parameterIndex, const ::rtl::OUString& x );
103*cdf0e10cSrcweir 
104*cdf0e10cSrcweir             /**
105*cdf0e10cSrcweir                 creates the driver specific resultset (factory)
106*cdf0e10cSrcweir             */
107*cdf0e10cSrcweir             virtual OResultSet* createResulSet();
108*cdf0e10cSrcweir 
109*cdf0e10cSrcweir         protected:
110*cdf0e10cSrcweir             virtual void SAL_CALL setFastPropertyValue_NoBroadcast(sal_Int32 nHandle,
111*cdf0e10cSrcweir                                                                    const ::com::sun::star::uno::Any& rValue)
112*cdf0e10cSrcweir                                                                         throw (::com::sun::star::uno::Exception);
113*cdf0e10cSrcweir         public:
114*cdf0e10cSrcweir             DECLARE_SERVICE_INFO();
115*cdf0e10cSrcweir             // ein Konstruktor, der fuer das Returnen des Objektes benoetigt wird:
116*cdf0e10cSrcweir             OPreparedStatement( OConnection* _pConnection,const ::rtl::OUString& sql);
117*cdf0e10cSrcweir 
118*cdf0e10cSrcweir             //XInterface
119*cdf0e10cSrcweir             virtual ::com::sun::star::uno::Any SAL_CALL queryInterface( const ::com::sun::star::uno::Type & rType ) throw(::com::sun::star::uno::RuntimeException);
120*cdf0e10cSrcweir             virtual void SAL_CALL acquire() throw();
121*cdf0e10cSrcweir             virtual void SAL_CALL release() throw();
122*cdf0e10cSrcweir             //XTypeProvider
123*cdf0e10cSrcweir             virtual ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Type > SAL_CALL getTypes(  ) throw(::com::sun::star::uno::RuntimeException);
124*cdf0e10cSrcweir 
125*cdf0e10cSrcweir             // XPreparedStatement
126*cdf0e10cSrcweir             virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XResultSet > SAL_CALL executeQuery(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
127*cdf0e10cSrcweir             virtual sal_Int32 SAL_CALL executeUpdate(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
128*cdf0e10cSrcweir             virtual sal_Bool SAL_CALL execute(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
129*cdf0e10cSrcweir             virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection > SAL_CALL getConnection(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
130*cdf0e10cSrcweir             // XParameters
131*cdf0e10cSrcweir             virtual void SAL_CALL setNull( sal_Int32 parameterIndex, sal_Int32 sqlType ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
132*cdf0e10cSrcweir             virtual void SAL_CALL setObjectNull( sal_Int32 parameterIndex, sal_Int32 sqlType, const ::rtl::OUString& typeName ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
133*cdf0e10cSrcweir             virtual void SAL_CALL setBoolean( sal_Int32 parameterIndex, sal_Bool x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
134*cdf0e10cSrcweir             virtual void SAL_CALL setByte( sal_Int32 parameterIndex, sal_Int8 x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
135*cdf0e10cSrcweir             virtual void SAL_CALL setShort( sal_Int32 parameterIndex, sal_Int16 x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
136*cdf0e10cSrcweir             virtual void SAL_CALL setInt( sal_Int32 parameterIndex, sal_Int32 x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
137*cdf0e10cSrcweir             virtual void SAL_CALL setLong( sal_Int32 parameterIndex, sal_Int64 x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
138*cdf0e10cSrcweir             virtual void SAL_CALL setFloat( sal_Int32 parameterIndex, float x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
139*cdf0e10cSrcweir             virtual void SAL_CALL setDouble( sal_Int32 parameterIndex, double x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
140*cdf0e10cSrcweir             virtual void SAL_CALL setString( sal_Int32 parameterIndex, const ::rtl::OUString& x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
141*cdf0e10cSrcweir             virtual void SAL_CALL setBytes( sal_Int32 parameterIndex, const ::com::sun::star::uno::Sequence< sal_Int8 >& x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
142*cdf0e10cSrcweir             virtual void SAL_CALL setDate( sal_Int32 parameterIndex, const ::com::sun::star::util::Date& x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
143*cdf0e10cSrcweir             virtual void SAL_CALL setTime( sal_Int32 parameterIndex, const ::com::sun::star::util::Time& x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
144*cdf0e10cSrcweir             virtual void SAL_CALL setTimestamp( sal_Int32 parameterIndex, const ::com::sun::star::util::DateTime& x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
145*cdf0e10cSrcweir             virtual void SAL_CALL setBinaryStream( sal_Int32 parameterIndex, const ::com::sun::star::uno::Reference< ::com::sun::star::io::XInputStream >& x, sal_Int32 length ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
146*cdf0e10cSrcweir             virtual void SAL_CALL setCharacterStream( sal_Int32 parameterIndex, const ::com::sun::star::uno::Reference< ::com::sun::star::io::XInputStream >& x, sal_Int32 length ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
147*cdf0e10cSrcweir             virtual void SAL_CALL setObject( sal_Int32 parameterIndex, const ::com::sun::star::uno::Any& x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
148*cdf0e10cSrcweir             virtual void SAL_CALL setObjectWithInfo( sal_Int32 parameterIndex, const ::com::sun::star::uno::Any& x, sal_Int32 targetSqlType, sal_Int32 scale ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
149*cdf0e10cSrcweir             virtual void SAL_CALL setRef( sal_Int32 parameterIndex, const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XRef >& x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
150*cdf0e10cSrcweir             virtual void SAL_CALL setBlob( sal_Int32 parameterIndex, const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XBlob >& x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
151*cdf0e10cSrcweir             virtual void SAL_CALL setClob( sal_Int32 parameterIndex, const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XClob >& x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
152*cdf0e10cSrcweir             virtual void SAL_CALL setArray( sal_Int32 parameterIndex, const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XArray >& x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
153*cdf0e10cSrcweir             virtual void SAL_CALL clearParameters(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
154*cdf0e10cSrcweir             // XPreparedBatchExecution
155*cdf0e10cSrcweir             virtual void SAL_CALL addBatch(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
156*cdf0e10cSrcweir             virtual void SAL_CALL clearBatch(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
157*cdf0e10cSrcweir             virtual ::com::sun::star::uno::Sequence< sal_Int32 > SAL_CALL executeBatch(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
158*cdf0e10cSrcweir             // XCloseable
159*cdf0e10cSrcweir             virtual void SAL_CALL close(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
160*cdf0e10cSrcweir             // XResultSetMetaDataSupplier
161*cdf0e10cSrcweir             virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XResultSetMetaData > SAL_CALL getMetaData(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
162*cdf0e10cSrcweir 
163*cdf0e10cSrcweir         public:
164*cdf0e10cSrcweir             using OStatement_Base::executeQuery;
165*cdf0e10cSrcweir             using OStatement_Base::executeUpdate;
166*cdf0e10cSrcweir             using OStatement_Base::execute;
167*cdf0e10cSrcweir         };
168*cdf0e10cSrcweir     }
169*cdf0e10cSrcweir }
170*cdf0e10cSrcweir #endif // _CONNECTIVITY_ODBC_OPREPAREDSTATEMENT_HXX_
171*cdf0e10cSrcweir 
172