2000-09-18 15:18:56 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: OPreparedStatement.hxx,v $
|
|
|
|
*
|
2001-06-26 10:31:18 +00:00
|
|
|
* $Revision: 1.6 $
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
2001-06-26 10:31:18 +00:00
|
|
|
* last change: $Author: oj $ $Date: 2001-06-26 11:31:18 $
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
|
|
|
* The Contents of this file are made available subject to the terms of
|
|
|
|
* either of the following licenses
|
|
|
|
*
|
|
|
|
* - GNU Lesser General Public License Version 2.1
|
|
|
|
* - Sun Industry Standards Source License Version 1.1
|
|
|
|
*
|
|
|
|
* Sun Microsystems Inc., October, 2000
|
|
|
|
*
|
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
* =============================================
|
|
|
|
* Copyright 2000 by Sun Microsystems, Inc.
|
|
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License version 2.1, as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This library 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 for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
|
|
* MA 02111-1307 USA
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Sun Industry Standards Source License Version 1.1
|
|
|
|
* =================================================
|
|
|
|
* The contents of this file are subject to the Sun Industry Standards
|
|
|
|
* Source License Version 1.1 (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.openoffice.org/license.html.
|
|
|
|
*
|
|
|
|
* Software provided under this License is provided on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
|
|
|
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
|
|
|
|
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
|
|
|
|
* See the License for the specific provisions governing your rights and
|
|
|
|
* obligations concerning the Software.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* Copyright: 2000 by Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s): _______________________________________
|
|
|
|
*
|
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _CONNECTIVITY_ODBC_OPREPAREDSTATEMENT_HXX_
|
|
|
|
#define _CONNECTIVITY_ODBC_OPREPAREDSTATEMENT_HXX_
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef _CONNECTIVITY_ODBC_OSTATEMENT_HXX_
|
|
|
|
#include "odbc/OStatement.hxx"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_XPREPAREDSTATEMENT_HPP_
|
|
|
|
#include <com/sun/star/sdbc/XPreparedStatement.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_XPARAMETERS_HPP_
|
|
|
|
#include <com/sun/star/sdbc/XParameters.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_XRESULTSETMETADATASUPPLIER_HPP_
|
|
|
|
#include <com/sun/star/sdbc/XResultSetMetaDataSupplier.hpp>
|
|
|
|
#endif
|
|
|
|
// #include <com/sun/star/sdbc/XClearParameters.hpp>
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_XPREPAREDBATCHEXECUTION_HPP_
|
|
|
|
#include <com/sun/star/sdbc/XPreparedBatchExecution.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_IO_XINPUTSTREAM_HPP_
|
|
|
|
#include <com/sun/star/io/XInputStream.hpp>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
class 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
|
|
|
|
//====================================================================
|
2001-05-02 11:57:37 +00:00
|
|
|
TTypeInfoVector m_aTypeInfo; // Hashtable containing an entry
|
2000-09-18 15:18:56 +00:00
|
|
|
// for each row returned by
|
|
|
|
// DatabaseMetaData.getTypeInfo.
|
|
|
|
|
2000-11-15 15:02:53 +00:00
|
|
|
int numParams; // Number of parameter markers
|
|
|
|
// 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.
|
2000-11-15 15:02:53 +00:00
|
|
|
::rtl::OUString m_sSqlStatement;
|
2000-09-18 15:18:56 +00:00
|
|
|
::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();
|
|
|
|
void putParamData (sal_Int32 index) throw(::com::sun::star::sdbc::SQLException);
|
|
|
|
void setChar(sal_Int32 parameterIndex,sal_Int32 SQLtype,sal_Int32 scale,const ::rtl::OUString& x) throw(::com::sun::star::sdbc::SQLException);
|
|
|
|
void setBinary(sal_Int32 parameterIndex,sal_Int32 SQLtype,const ::com::sun::star::uno::Sequence< sal_Int8 >& x) throw(::com::sun::star::sdbc::SQLException);
|
|
|
|
void setStream (sal_Int32 ParameterIndex,const ::com::sun::star::uno::Reference< ::com::sun::star::io::XInputStream>& x,
|
|
|
|
sal_Int32 length,sal_Int32 SQLtype,sal_Int32 streamType) throw(::com::sun::star::sdbc::SQLException);
|
|
|
|
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);
|
|
|
|
void initBoundParam () throw(::com::sun::star::sdbc::SQLException);
|
|
|
|
|
|
|
|
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);
|
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:
|
2001-05-02 11:57:37 +00:00
|
|
|
OPreparedStatement( OConnection* _pConnection,const TTypeInfoVector& _TypeInfo,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-04-30 08:59:56 +00:00
|
|
|
virtual void SAL_CALL acquire() throw(::com::sun::star::uno::RuntimeException);
|
|
|
|
virtual void SAL_CALL release() throw(::com::sun::star::uno::RuntimeException);
|
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);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif // _CONNECTIVITY_ODBC_OPREPAREDSTATEMENT_HXX_
|
|
|
|
|