2000-09-18 15:18:56 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 10:44:05 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
2010-02-12 15:01:35 +01:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
2008-04-10 10:44:05 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
2008-04-10 10:44:05 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
2008-04-10 10:44:05 +00:00
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
2008-04-10 10:44:05 +00:00
|
|
|
* OpenOffice.org is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Lesser General Public License version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
2008-04-10 10:44:05 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _CONNECTIVITY_ODBC_OPREPAREDSTATEMENT_HXX_
|
|
|
|
#define _CONNECTIVITY_ODBC_OPREPAREDSTATEMENT_HXX_
|
|
|
|
|
2008-12-30 13:32:01 +00:00
|
|
|
#include "odbc/odbcbasedllapi.hxx"
|
2000-09-18 15:18:56 +00:00
|
|
|
#include "odbc/OStatement.hxx"
|
|
|
|
#include <com/sun/star/sdbc/XPreparedStatement.hpp>
|
|
|
|
#include <com/sun/star/sdbc/XParameters.hpp>
|
|
|
|
#include <com/sun/star/sdbc/XResultSetMetaDataSupplier.hpp>
|
|
|
|
#include <com/sun/star/sdbc/XPreparedBatchExecution.hpp>
|
|
|
|
#include <com/sun/star/io/XInputStream.hpp>
|
2002-07-25 06:21:56 +00:00
|
|
|
#include <cppuhelper/implbase5.hxx>
|
|
|
|
|
2000-09-18 15:18:56 +00:00
|
|
|
namespace connectivity
|
|
|
|
{
|
|
|
|
namespace odbc
|
|
|
|
{
|
|
|
|
|
|
|
|
class OBoundParam;
|
2000-11-15 15:02:53 +00:00
|
|
|
typedef ::cppu::ImplHelper5< ::com::sun::star::sdbc::XPreparedStatement,
|
|
|
|
::com::sun::star::sdbc::XParameters,
|
|
|
|
::com::sun::star::sdbc::XPreparedBatchExecution,
|
|
|
|
::com::sun::star::sdbc::XResultSetMetaDataSupplier,
|
|
|
|
::com::sun::star::lang::XServiceInfo> OPreparedStatement_BASE;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
2008-12-30 13:32:01 +00:00
|
|
|
class OOO_DLLPUBLIC_ODBCBASE OPreparedStatement :
|
|
|
|
public OStatement_BASE2,
|
2000-11-15 15:02:53 +00:00
|
|
|
public OPreparedStatement_BASE
|
2000-09-18 15:18:56 +00:00
|
|
|
{
|
|
|
|
protected:
|
2000-11-15 15:02:53 +00:00
|
|
|
struct Parameter
|
|
|
|
{
|
|
|
|
::com::sun::star::uno::Any aValue;
|
|
|
|
sal_Int32 nDataType;
|
|
|
|
|
|
|
|
Parameter(const ::com::sun::star::uno::Any& rValue,
|
|
|
|
sal_Int32 rDataType) : aValue(rValue),nDataType(rDataType)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
::std::vector< Parameter> m_aParameters;
|
2000-09-18 15:18:56 +00:00
|
|
|
//====================================================================
|
|
|
|
// Data attributes
|
|
|
|
//====================================================================
|
2007-11-01 13:51:49 +00:00
|
|
|
SQLSMALLINT numParams; // Number of parameter markers
|
2000-11-15 15:02:53 +00:00
|
|
|
// for the prepared statement
|
2000-09-18 15:18:56 +00:00
|
|
|
|
2000-11-15 15:02:53 +00:00
|
|
|
OBoundParam* boundParams;
|
2000-09-18 15:18:56 +00:00
|
|
|
// Array of bound parameter
|
|
|
|
// objects. Each parameter
|
|
|
|
// marker will have a
|
|
|
|
// corresponding object to
|
|
|
|
// hold bind information, and
|
|
|
|
// resulting data.
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XResultSetMetaData > m_xMetaData;
|
2000-11-15 15:02:53 +00:00
|
|
|
sal_Bool m_bPrepared;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
void FreeParams();
|
2001-08-06 06:41:49 +00:00
|
|
|
void putParamData (sal_Int32 index) throw(::com::sun::star::sdbc::SQLException);
|
|
|
|
void setStream (sal_Int32 ParameterIndex,const ::com::sun::star::uno::Reference< ::com::sun::star::io::XInputStream>& x,
|
2009-11-11 12:32:55 +01:00
|
|
|
SQLLEN length,sal_Int32 SQLtype) throw(::com::sun::star::sdbc::SQLException);
|
2000-09-18 15:18:56 +00:00
|
|
|
sal_Int32 getParamLength ( sal_Int32 index);
|
|
|
|
sal_Int8* getLengthBuf (sal_Int32 index);
|
|
|
|
sal_Int8* getDataBuf (sal_Int32 index);
|
|
|
|
sal_Int8* allocBindBuf ( sal_Int32 index, sal_Int32 bufLen);
|
2001-08-06 06:41:49 +00:00
|
|
|
void initBoundParam () throw(::com::sun::star::sdbc::SQLException);
|
|
|
|
void setParameter(sal_Int32 parameterIndex,sal_Int32 _nType,sal_Int32 _nSize,void* _pData);
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
sal_Int32 getPrecision ( sal_Int32 sqlType);
|
|
|
|
|
2000-11-15 15:02:53 +00:00
|
|
|
sal_Bool isPrepared() const { return m_bPrepared;}
|
|
|
|
void prepareStatement();
|
2001-06-26 10:31:18 +00:00
|
|
|
void checkParameterIndex(sal_Int32 _parameterIndex);
|
2009-11-11 12:32:55 +01:00
|
|
|
void setDecimal( sal_Int32 parameterIndex, const ::rtl::OUString& x );
|
2000-11-15 15:02:53 +00:00
|
|
|
|
2007-09-26 13:30:59 +00:00
|
|
|
/**
|
|
|
|
creates the driver specific resultset (factory)
|
|
|
|
*/
|
|
|
|
virtual OResultSet* createResulSet();
|
|
|
|
|
2000-11-15 15:02:53 +00:00
|
|
|
protected:
|
|
|
|
virtual void SAL_CALL setFastPropertyValue_NoBroadcast(sal_Int32 nHandle,
|
|
|
|
const ::com::sun::star::uno::Any& rValue)
|
|
|
|
throw (::com::sun::star::uno::Exception);
|
2000-09-18 15:18:56 +00:00
|
|
|
public:
|
|
|
|
DECLARE_SERVICE_INFO();
|
|
|
|
// ein Konstruktor, der fuer das Returnen des Objektes benoetigt wird:
|
2009-09-08 09:50:48 +00:00
|
|
|
OPreparedStatement( OConnection* _pConnection,const ::rtl::OUString& sql);
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
//XInterface
|
2000-11-15 15:02:53 +00:00
|
|
|
virtual ::com::sun::star::uno::Any SAL_CALL queryInterface( const ::com::sun::star::uno::Type & rType ) throw(::com::sun::star::uno::RuntimeException);
|
2001-10-17 12:57:34 +00:00
|
|
|
virtual void SAL_CALL acquire() throw();
|
|
|
|
virtual void SAL_CALL release() throw();
|
2000-09-18 15:18:56 +00:00
|
|
|
//XTypeProvider
|
2000-11-15 15:02:53 +00:00
|
|
|
virtual ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Type > SAL_CALL getTypes( ) throw(::com::sun::star::uno::RuntimeException);
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
// XPreparedStatement
|
|
|
|
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);
|
|
|
|
virtual sal_Int32 SAL_CALL executeUpdate( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
virtual sal_Bool SAL_CALL execute( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
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);
|
|
|
|
// XParameters
|
|
|
|
virtual void SAL_CALL setNull( sal_Int32 parameterIndex, sal_Int32 sqlType ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
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);
|
|
|
|
virtual void SAL_CALL setBoolean( sal_Int32 parameterIndex, sal_Bool x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
virtual void SAL_CALL setByte( sal_Int32 parameterIndex, sal_Int8 x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
virtual void SAL_CALL setShort( sal_Int32 parameterIndex, sal_Int16 x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
virtual void SAL_CALL setInt( sal_Int32 parameterIndex, sal_Int32 x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
virtual void SAL_CALL setLong( sal_Int32 parameterIndex, sal_Int64 x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
virtual void SAL_CALL setFloat( sal_Int32 parameterIndex, float x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
virtual void SAL_CALL setDouble( sal_Int32 parameterIndex, double x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
virtual void SAL_CALL setString( sal_Int32 parameterIndex, const ::rtl::OUString& x ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
virtual void SAL_CALL clearParameters( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
// XPreparedBatchExecution
|
|
|
|
virtual void SAL_CALL addBatch( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
virtual void SAL_CALL clearBatch( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
virtual ::com::sun::star::uno::Sequence< sal_Int32 > SAL_CALL executeBatch( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
|
|
|
// XCloseable
|
2001-01-22 06:24:53 +00:00
|
|
|
virtual void SAL_CALL close( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
|
2000-09-18 15:18:56 +00:00
|
|
|
// XResultSetMetaDataSupplier
|
|
|
|
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);
|
2006-06-20 01:06:07 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
using OStatement_Base::executeQuery;
|
|
|
|
using OStatement_Base::executeUpdate;
|
|
|
|
using OStatement_Base::execute;
|
2000-09-18 15:18:56 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif // _CONNECTIVITY_ODBC_OPREPAREDSTATEMENT_HXX_
|
|
|
|
|