| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2005-09-08 05:35:56 +00:00
										 |  |  |  *  OpenOffice.org - a multi-platform office productivity suite | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2005-09-08 05:35:56 +00:00
										 |  |  |  *  $RCSfile: OStatement.cxx,v $ | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |  *  $Revision: 1.35 $ | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |  *  last change: $Author: hr $ $Date: 2006-06-20 01:56:39 $ | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2005-09-08 05:35:56 +00:00
										 |  |  |  *  The Contents of this file are made available subject to | 
					
						
							|  |  |  |  *  the terms of GNU Lesser General Public License Version 2.1. | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2005-09-08 05:35:56 +00:00
										 |  |  |  *    GNU Lesser General Public License Version 2.1 | 
					
						
							|  |  |  |  *    ============================================= | 
					
						
							|  |  |  |  *    Copyright 2005 by Sun Microsystems, Inc. | 
					
						
							|  |  |  |  *    901 San Antonio Road, Palo Alto, CA 94303, USA | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2005-09-08 05:35:56 +00:00
										 |  |  |  *    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. | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2005-09-08 05:35:56 +00:00
										 |  |  |  *    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. | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2005-09-08 05:35:56 +00:00
										 |  |  |  *    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 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  ************************************************************************/ | 
					
						
							| 
									
										
										
										
											2000-11-29 11:39:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <stdio.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | #ifndef _OSL_DIAGNOSE_H_
 | 
					
						
							|  |  |  | #include <osl/diagnose.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _CONNECTIVITY_ODBC_OSTATEMENT_HXX_
 | 
					
						
							|  |  |  | #include "odbc/OStatement.hxx"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _CONNECTIVITY_ODBC_OCONNECTION_HXX_
 | 
					
						
							|  |  |  | #include "odbc/OConnection.hxx"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _CONNECTIVITY_ODBC_ORESULTSET_HXX_
 | 
					
						
							|  |  |  | #include "odbc/OResultSet.hxx"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2000-10-11 09:48:50 +00:00
										 |  |  | #ifndef _COMPHELPER_PROPERTY_HXX_
 | 
					
						
							|  |  |  | #include <comphelper/property.hxx>
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _CONNECTIVITY_OTOOLS_HXX_
 | 
					
						
							|  |  |  | #include "odbc/OTools.hxx"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2000-10-11 09:48:50 +00:00
										 |  |  | #ifndef _COMPHELPER_UNO3_HXX_
 | 
					
						
							|  |  |  | #include <comphelper/uno3.hxx>
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _OSL_THREAD_H_
 | 
					
						
							|  |  |  | #include <osl/thread.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _COM_SUN_STAR_SDBC_RESULTSETCONCURRENCY_HPP_
 | 
					
						
							|  |  |  | #include <com/sun/star/sdbc/ResultSetConcurrency.hpp>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _COM_SUN_STAR_SDBC_RESULTSETTYPE_HPP_
 | 
					
						
							|  |  |  | #include <com/sun/star/sdbc/ResultSetType.hpp>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  | #ifndef _COM_SUN_STAR_SDBC_FETCHDIRECTION_HPP_
 | 
					
						
							|  |  |  | #include <com/sun/star/sdbc/FetchDirection.hpp>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | #ifndef _COM_SUN_STAR_LANG_DISPOSEDEXCEPTION_HPP_
 | 
					
						
							|  |  |  | #include <com/sun/star/lang/DisposedException.hpp>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2000-10-11 09:48:50 +00:00
										 |  |  | #ifndef _COMPHELPER_SEQUENCE_HXX_
 | 
					
						
							|  |  |  | #include <comphelper/sequence.hxx>
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _CPPUHELPER_TYPEPROVIDER_HXX_
 | 
					
						
							|  |  |  | #include <cppuhelper/typeprovider.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-03-15 08:02:28 +00:00
										 |  |  | #ifndef _COMPHELPER_EXTRACT_HXX_
 | 
					
						
							|  |  |  | #include <comphelper/extract.hxx>
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-05-18 07:33:49 +00:00
										 |  |  | #ifndef _COMPHELPER_TYPES_HXX_
 | 
					
						
							|  |  |  | #include <comphelper/types.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  | #ifndef CONNECTIVITY_DIAGNOSE_EX_H
 | 
					
						
							|  |  |  | #include "diagnose_ex.h"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-07-25 11:54:48 +00:00
										 |  |  | #include <algorithm>
 | 
					
						
							| 
									
										
										
										
											2001-05-18 07:33:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | using namespace ::comphelper; | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define THROW_SQL(x) \
 | 
					
						
							| 
									
										
										
										
											2001-05-15 07:18:32 +00:00
										 |  |  |     OTools::ThrowException(m_pConnection,x,m_aStatementHandle,SQL_HANDLE_STMT,*this) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-04-15 16:39:23 +00:00
										 |  |  | #if OSL_DEBUG_LEVEL > 1
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | #define DEBUG_THROW                 \
 | 
					
						
							|  |  |  |     try                                 \ | 
					
						
							|  |  |  |     {                                   \ | 
					
						
							|  |  |  |         THROW_SQL(nRetCode);            \ | 
					
						
							|  |  |  |     }                                   \ | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  |     catch(SQLException&)                \ | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     {                                   \ | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |         OSL_ENSURE(0,"Exception in odbc catched"); \ | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-10-24 15:34:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | using namespace connectivity::odbc; | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | using namespace com::sun::star::uno; | 
					
						
							|  |  |  | using namespace com::sun::star::lang; | 
					
						
							|  |  |  | using namespace com::sun::star::beans; | 
					
						
							|  |  |  | using namespace com::sun::star::sdbc; | 
					
						
							|  |  |  | using namespace com::sun::star::sdbcx; | 
					
						
							|  |  |  | using namespace com::sun::star::container; | 
					
						
							|  |  |  | using namespace com::sun::star::io; | 
					
						
							|  |  |  | using namespace com::sun::star::util; | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-08-29 11:13:20 +00:00
										 |  |  | OStatement_Base::OStatement_Base(OConnection* _pConnection ) | 
					
						
							|  |  |  |     :OStatement_BASE(m_aMutex) | 
					
						
							|  |  |  |     ,OPropertySetHelper(OStatement_BASE::rBHelper) | 
					
						
							|  |  |  |     ,m_pConnection(_pConnection) | 
					
						
							|  |  |  |     ,m_aStatementHandle(SQL_NULL_HANDLE) | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     ,m_pRowStatusArray(0) | 
					
						
							|  |  |  |     ,rBHelper(OStatement_BASE::rBHelper) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-10-02 12:12:32 +00:00
										 |  |  |     osl_incrementInterlockedCount( &m_refCount ); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     m_pConnection->acquire(); | 
					
						
							| 
									
										
										
										
											2001-08-29 11:13:20 +00:00
										 |  |  |     m_aStatementHandle = m_pConnection->createStatementHandle(); | 
					
						
							| 
									
										
										
										
											2004-08-02 16:10:19 +00:00
										 |  |  |     setMaxFieldSize(0); | 
					
						
							| 
									
										
										
										
											2001-10-02 12:12:32 +00:00
										 |  |  |     osl_decrementInterlockedCount( &m_refCount ); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-05-23 13:05:55 +00:00
										 |  |  | // -----------------------------------------------------------------------------
 | 
					
						
							|  |  |  | OStatement_Base::~OStatement_Base() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-10-12 11:02:56 +00:00
										 |  |  |     OSL_ENSURE(!m_aStatementHandle,"Sohould ne null here!"); | 
					
						
							| 
									
										
										
										
											2001-05-23 13:05:55 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | //------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | void OStatement_Base::disposeResultSet() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     // free the cursor if alive
 | 
					
						
							|  |  |  |     Reference< XComponent > xComp(m_xResultSet.get(), UNO_QUERY); | 
					
						
							|  |  |  |     if (xComp.is()) | 
					
						
							|  |  |  |         xComp->dispose(); | 
					
						
							|  |  |  |     m_xResultSet = Reference< XResultSet>(); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2001-10-12 11:02:56 +00:00
										 |  |  | // -----------------------------------------------------------------------------
 | 
					
						
							|  |  |  | void SAL_CALL OStatement_Base::disposing(void) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard(m_aMutex); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     disposeResultSet(); | 
					
						
							| 
									
										
										
										
											2002-07-25 06:21:56 +00:00
										 |  |  |     ::comphelper::disposeComponent(m_xGeneratedStatement); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"OStatement_BASE2::disposing: StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     if (m_pConnection) | 
					
						
							| 
									
										
										
										
											2001-10-02 12:12:32 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         m_pConnection->freeStatementHandle(m_aStatementHandle); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |         m_pConnection->release(); | 
					
						
							| 
									
										
										
										
											2001-10-02 12:12:32 +00:00
										 |  |  |         m_pConnection = NULL; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-10-12 11:02:56 +00:00
										 |  |  |     OSL_ENSURE(!m_aStatementHandle,"Sohould ne null here!"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     OStatement_BASE::disposing(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | void OStatement_BASE2::disposing() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard(m_aMutex); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     dispose_ChildImpl(); | 
					
						
							|  |  |  |     OStatement_Base::disposing(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //-----------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-10-17 13:55:07 +00:00
										 |  |  | void SAL_CALL OStatement_BASE2::release() throw() | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     relase_ChildImpl(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //-----------------------------------------------------------------------------
 | 
					
						
							|  |  |  | Any SAL_CALL OStatement_Base::queryInterface( const Type & rType ) throw(RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2002-07-25 06:21:56 +00:00
										 |  |  |     if ( m_pConnection && !m_pConnection->isAutoRetrievingEnabled() && rType == ::getCppuType( (const Reference< XGeneratedResultSet > *)0 ) ) | 
					
						
							|  |  |  |         return Any(); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     Any aRet = OStatement_BASE::queryInterface(rType); | 
					
						
							| 
									
										
										
										
											2001-08-24 05:19:41 +00:00
										 |  |  |     return aRet.hasValue() ? aRet : OPropertySetHelper::queryInterface(rType); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | Sequence< Type > SAL_CALL OStatement_Base::getTypes(  ) throw(RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::cppu::OTypeCollection aTypes( ::getCppuType( (const Reference< XMultiPropertySet > *)0 ), | 
					
						
							|  |  |  |                                     ::getCppuType( (const Reference< XFastPropertySet > *)0 ), | 
					
						
							|  |  |  |                                     ::getCppuType( (const Reference< XPropertySet > *)0 )); | 
					
						
							| 
									
										
										
										
											2002-07-25 06:21:56 +00:00
										 |  |  |     Sequence< Type > aOldTypes = OStatement_BASE::getTypes(); | 
					
						
							|  |  |  |     if ( m_pConnection && !m_pConnection->isAutoRetrievingEnabled() ) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |         ::std::remove(aOldTypes.getArray(),aOldTypes.getArray() + aOldTypes.getLength(), | 
					
						
							| 
									
										
										
										
											2002-07-25 06:21:56 +00:00
										 |  |  |                         ::getCppuType( (const Reference< XGeneratedResultSet > *)0 )); | 
					
						
							|  |  |  |         aOldTypes.realloc(aOldTypes.getLength() - 1); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-07-25 06:21:56 +00:00
										 |  |  |     return ::comphelper::concatSequences(aTypes.getTypes(),aOldTypes); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2002-07-25 06:21:56 +00:00
										 |  |  | Reference< XResultSet > SAL_CALL OStatement_Base::getGeneratedValues(  ) throw (SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     OSL_ENSURE( m_pConnection && m_pConnection->isAutoRetrievingEnabled(),"Illegal call here. isAutoRetrievingEnabled is false!"); | 
					
						
							|  |  |  |     Reference< XResultSet > xRes; | 
					
						
							|  |  |  |     if ( m_pConnection ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         ::rtl::OUString sStmt = m_pConnection->getTransformedGeneratedStatement(m_sSqlStatement); | 
					
						
							|  |  |  |         if ( sStmt.getLength() ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             ::comphelper::disposeComponent(m_xGeneratedStatement); | 
					
						
							|  |  |  |             m_xGeneratedStatement = m_pConnection->createStatement(); | 
					
						
							|  |  |  |             xRes = m_xGeneratedStatement->executeQuery(sStmt); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return xRes; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -----------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | void SAL_CALL OStatement_Base::cancel(  ) throw(RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2001-05-15 07:18:32 +00:00
										 |  |  |     OTools::ThrowException(m_pConnection,N3SQLCancel(m_aStatementHandle),m_aStatementHandle,SQL_HANDLE_STMT,*this); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void SAL_CALL OStatement_Base::close(  ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |         checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     dispose(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void SAL_CALL OStatement::clearBatch(  ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void OStatement_Base::reset() throw (SQLException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     clearWarnings (); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (m_xResultSet.get().is()) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         clearMyResultSet(); | 
					
						
							| 
									
										
										
										
											2001-01-23 07:19:48 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     if(m_aStatementHandle) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |         THROW_SQL(N3SQLFreeStmt(m_aStatementHandle, SQL_CLOSE)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | // clearMyResultSet
 | 
					
						
							|  |  |  | // If a ResultSet was created for this Statement, close it
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void OStatement_Base::clearMyResultSet () throw (SQLException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     Reference<XCloseable> xCloseable; | 
					
						
							| 
									
										
										
										
											2000-10-11 09:48:50 +00:00
										 |  |  |     if(::comphelper::query_interface(m_xResultSet.get(),xCloseable)) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |         xCloseable->close(); | 
					
						
							|  |  |  |     m_xResultSet = Reference< XResultSet>(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | sal_Int32 OStatement_Base::getRowCount () throw( SQLException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     sal_Int32   numRows = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     try { | 
					
						
							|  |  |  |         THROW_SQL(N3SQLRowCount(m_aStatementHandle,&numRows)); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  |     catch (SQLException&) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return numRows; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | // lockIfNecessary
 | 
					
						
							|  |  |  | // If the given SQL statement contains a 'FOR UPDATE' clause, change
 | 
					
						
							|  |  |  | // the concurrency to lock so that the row can then be updated.  Returns
 | 
					
						
							|  |  |  | // true if the concurrency has been changed
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | sal_Bool OStatement_Base::lockIfNecessary (const ::rtl::OUString& sql) throw( SQLException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     sal_Bool rc = sal_False; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // First, convert the statement to upper case
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-05-11 16:59:22 +00:00
										 |  |  |     ::rtl::OUString sqlStatement = sql.toAsciiUpperCase (); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // Now, look for the FOR UPDATE keywords.  If there is any extra white
 | 
					
						
							|  |  |  |     // space between the FOR and UPDATE, this will fail.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     sal_Int32 index = sqlStatement.indexOf(::rtl::OUString::createFromAscii(" FOR UPDATE")); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // We found it.  Change our concurrency level to ensure that the
 | 
					
						
							|  |  |  |     // row can be updated.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (index > 0) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |         OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |         try | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             SQLINTEGER nLock = SQL_CONCUR_LOCK; | 
					
						
							|  |  |  |             THROW_SQL(N3SQLSetStmtAttr(m_aStatementHandle, SQL_CONCURRENCY,(SQLPOINTER)nLock,SQL_IS_UINTEGER)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         catch (SQLWarning& warn) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             // Catch any warnings and place on the warning stack
 | 
					
						
							|  |  |  |             setWarning (warn); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         rc = sal_True; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return rc; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | // setWarning
 | 
					
						
							|  |  |  | // Sets the warning
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void OStatement_Base::setWarning (const SQLWarning &ex) throw( SQLException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     m_aLastWarning = ex; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | // getColumnCount
 | 
					
						
							|  |  |  | // Return the number of columns in the ResultSet
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | sal_Int32 OStatement_Base::getColumnCount () throw( SQLException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     sal_Int16   numCols = 0; | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     try { | 
					
						
							|  |  |  |         THROW_SQL(N3SQLNumResultCols(m_aStatementHandle,&numCols)); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  |     catch (SQLException&) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return numCols; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | sal_Bool SAL_CALL OStatement_Base::execute( const ::rtl::OUString& sql ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							| 
									
										
										
										
											2002-07-25 06:21:56 +00:00
										 |  |  |     m_sSqlStatement = sql; | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-02-05 11:26:42 +00:00
										 |  |  |     ::rtl::OString aSql(::rtl::OUStringToOString(sql,getOwnConnection()->getTextEncoding())); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     sal_Bool hasResultSet = sal_False; | 
					
						
							|  |  |  |     SQLWarning aWarning; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Reset the statement handle and warning
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     reset(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Check for a 'FOR UPDATE' statement.  If present, change
 | 
					
						
							|  |  |  |     // the concurrency to lock
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lockIfNecessary (sql); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Call SQLExecDirect
 | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     try { | 
					
						
							|  |  |  |         THROW_SQL(N3SQLExecDirect(m_aStatementHandle, (SDB_ODBC_CHAR*)aSql.getStr(),aSql.getLength())); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     catch (SQLWarning& ex) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Save pointer to warning and save with ResultSet
 | 
					
						
							|  |  |  |         // object once it is created.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         aWarning = ex; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Now determine if there is a result set associated with
 | 
					
						
							|  |  |  |     // the SQL statement that was executed.  Get the column
 | 
					
						
							|  |  |  |     // count, and if it is not zero, there is a result set.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (getColumnCount () > 0) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         hasResultSet = sal_True; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return hasResultSet; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | // getResultSet
 | 
					
						
							|  |  |  | // getResultSet returns the current result as a ResultSet.  It
 | 
					
						
							|  |  |  | // returns NULL if the current result is not a ResultSet.
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | Reference< XResultSet > OStatement_Base::getResultSet (sal_Bool checkCount) throw( SQLException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (m_xResultSet.get().is())  // if resultset already retrieved,
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // throw exception to avoid sequence error
 | 
					
						
							|  |  |  |         throw SQLException(::rtl::OUString::createFromAscii("Invalid state for getResultSet"),*this, | 
					
						
							|  |  |  |             ::rtl::OUString(),0,Any()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     OResultSet* pRs = NULL; | 
					
						
							|  |  |  |     sal_Int32 numCols = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // If we already know we have result columns, checkCount
 | 
					
						
							|  |  |  |     // is false.  This is an optimization to prevent unneeded
 | 
					
						
							|  |  |  |     // calls to getColumnCount
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (checkCount) | 
					
						
							|  |  |  |         numCols = getColumnCount (); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Only return a result set if there are result columns
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (numCols > 0) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |         OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2001-08-02 09:41:53 +00:00
										 |  |  |         pRs = createResulSet(); | 
					
						
							|  |  |  |         pRs->construct(); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // Save a copy of our last result set
 | 
					
						
							|  |  |  |         // Changed to save copy at getResultSet.
 | 
					
						
							|  |  |  |         //m_xResultSet = rs;
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |         clearMyResultSet (); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return pRs; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | // getStmtOption
 | 
					
						
							|  |  |  | // Invoke SQLGetStmtOption with the given option.
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | sal_Int32 OStatement_Base::getStmtOption (short fOption) const | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     sal_Int32   result = 0; | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |     N3SQLGetStmtAttr(m_aStatementHandle, fOption,&result,SQL_IS_INTEGER,NULL); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     return result; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Reference< XResultSet > SAL_CALL OStatement_Base::executeQuery( const ::rtl::OUString& sql ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     Reference< XResultSet > xRS = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Execute the statement.  If execute returns true, a result
 | 
					
						
							|  |  |  |     // set exists.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (execute (sql)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         xRS = getResultSet (sal_False); | 
					
						
							| 
									
										
										
										
											2001-06-22 11:42:30 +00:00
										 |  |  |         m_xResultSet = xRS; | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // No ResultSet was produced.  Raise an exception
 | 
					
						
							|  |  |  |         throw SQLException(::rtl::OUString::createFromAscii("No ResultSet was produced"),*this, | 
					
						
							|  |  |  |             ::rtl::OUString(),0,Any()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return xRS; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Reference< XConnection > SAL_CALL OStatement_Base::getConnection(  ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     return (Reference< XConnection >)m_pConnection; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Any SAL_CALL OStatement::queryInterface( const Type & rType ) throw(RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     Any aRet = ::cppu::queryInterface(rType,static_cast< XBatchExecution*> (this)); | 
					
						
							| 
									
										
										
										
											2001-08-24 05:19:41 +00:00
										 |  |  |     return aRet.hasValue() ? aRet : OStatement_Base::queryInterface(rType); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void SAL_CALL OStatement::addBatch( const ::rtl::OUString& sql ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     m_aBatchList.push_back(sql); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | Sequence< sal_Int32 > SAL_CALL OStatement::executeBatch(  ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ::rtl::OString aBatchSql; | 
					
						
							|  |  |  |     sal_Int32 nLen = 0; | 
					
						
							|  |  |  |     for(::std::list< ::rtl::OUString>::const_iterator i=m_aBatchList.begin();i != m_aBatchList.end();++i,++nLen) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-02-05 11:26:42 +00:00
										 |  |  |         aBatchSql += ::rtl::OUStringToOString(*i,getOwnConnection()->getTextEncoding()); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |         aBatchSql += ";"; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     THROW_SQL(N3SQLExecDirect(m_aStatementHandle, (SDB_ODBC_CHAR*)aBatchSql.getStr(),aBatchSql.getLength())); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Sequence< sal_Int32 > aRet(nLen); | 
					
						
							|  |  |  |     sal_Int32* pArray = aRet.getArray(); | 
					
						
							|  |  |  |     for(sal_Int32 j=0;j<nLen;++j) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SQLRETURN nError = N3SQLMoreResults(m_aStatementHandle); | 
					
						
							|  |  |  |         if(nError == SQL_SUCCESS) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             N3SQLRowCount(m_aStatementHandle,&pArray[j]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return aRet; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | sal_Int32 SAL_CALL OStatement_Base::executeUpdate( const ::rtl::OUString& sql ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     sal_Int32 numRows = -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Execute the statement.  If execute returns false, a
 | 
					
						
							|  |  |  |     // row count exists.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!execute (sql)) { | 
					
						
							|  |  |  |         numRows = getUpdateCount(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // No update count was produced (a ResultSet was).  Raise
 | 
					
						
							|  |  |  |         // an exception
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         throw new SQLException (::rtl::OUString::createFromAscii("No row count was produced"),*this, | 
					
						
							|  |  |  |             ::rtl::OUString(),0,Any()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return numRows; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Reference< XResultSet > SAL_CALL OStatement_Base::getResultSet(  ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     m_xResultSet = getResultSet(sal_True); | 
					
						
							|  |  |  |     return m_xResultSet; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | sal_Int32 SAL_CALL OStatement_Base::getUpdateCount(  ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     sal_Int32 rowCount = -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Only return a row count for SQL statements that did not
 | 
					
						
							|  |  |  |     // return a result set.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (getColumnCount () == 0) | 
					
						
							|  |  |  |         rowCount = getRowCount (); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return rowCount; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | sal_Bool SAL_CALL OStatement_Base::getMoreResults(  ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     SQLWarning  warning; | 
					
						
							|  |  |  |     sal_Bool hasResultSet = sal_False; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // clear previous warnings
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     clearWarnings (); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Call SQLMoreResults
 | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     try { | 
					
						
							|  |  |  |         hasResultSet = N3SQLMoreResults(m_aStatementHandle) == SQL_SUCCESS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     catch (SQLWarning &ex) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Save pointer to warning and save with ResultSet
 | 
					
						
							|  |  |  |         // object once it is created.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         warning = ex; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // There are more results (it may not be a result set, though)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (hasResultSet) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Now determine if there is a result set associated
 | 
					
						
							|  |  |  |         // with the SQL statement that was executed.  Get the
 | 
					
						
							|  |  |  |         // column count, and if it is zero, there is not a
 | 
					
						
							|  |  |  |         // result set.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (getColumnCount () == 0) | 
					
						
							|  |  |  |             hasResultSet = sal_False; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Set the warning for the statement, if one was generated
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     setWarning (warning); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Return the result set indicator
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return hasResultSet; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | Any SAL_CALL OStatement_Base::getWarnings(  ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return makeAny(m_aLastWarning); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | void SAL_CALL OStatement_Base::clearWarnings(  ) throw(SQLException, RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::osl::MutexGuard aGuard( m_aMutex ); | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     checkDisposed(OStatement_BASE::rBHelper.bDisposed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     m_aLastWarning = SQLWarning(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | sal_Int32 OStatement_Base::getQueryTimeOut() const | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     return getStmtOption(SQL_ATTR_QUERY_TIMEOUT); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | sal_Int32 OStatement_Base::getMaxRows() const | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     return getStmtOption(SQL_ATTR_MAX_ROWS); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | sal_Int32 OStatement_Base::getResultSetConcurrency() const | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     sal_uInt32 nValue; | 
					
						
							|  |  |  |     SQLRETURN nRetCode = N3SQLGetStmtAttr(m_aStatementHandle,SQL_ATTR_CONCURRENCY,&nValue,SQL_IS_UINTEGER,0); | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     OSL_UNUSED( nRetCode ); | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  |     if(nValue == SQL_CONCUR_READ_ONLY) | 
					
						
							|  |  |  |         nValue = ResultSetConcurrency::READ_ONLY; | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |         nValue = ResultSetConcurrency::UPDATABLE; | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     return nValue; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | sal_Int32 OStatement_Base::getResultSetType() const | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  |     sal_uInt32 nValue = SQL_CURSOR_FORWARD_ONLY; | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     SQLRETURN nRetCode = N3SQLGetStmtAttr(m_aStatementHandle,SQL_ATTR_CURSOR_SENSITIVITY,&nValue,SQL_IS_UINTEGER,0); | 
					
						
							|  |  |  |     nRetCode = N3SQLGetStmtAttr(m_aStatementHandle,SQL_ATTR_CURSOR_TYPE,&nValue,SQL_IS_UINTEGER,0); | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  |     switch(nValue) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         case SQL_CURSOR_FORWARD_ONLY: | 
					
						
							|  |  |  |             nValue = ResultSetType::FORWARD_ONLY; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case SQL_CURSOR_KEYSET_DRIVEN: | 
					
						
							|  |  |  |         case SQL_CURSOR_STATIC: | 
					
						
							|  |  |  |             nValue = ResultSetType::SCROLL_INSENSITIVE; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case SQL_CURSOR_DYNAMIC: | 
					
						
							|  |  |  |             nValue = ResultSetType::SCROLL_SENSITIVE; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     return nValue; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | sal_Int32 OStatement_Base::getFetchDirection() const | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  |     sal_uInt32 nValue = 0; | 
					
						
							|  |  |  |     SQLRETURN nRetCode = N3SQLGetStmtAttr(m_aStatementHandle,SQL_ATTR_CURSOR_SCROLLABLE,&nValue,SQL_IS_UINTEGER,0); | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     OSL_UNUSED( nRetCode ); | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     switch(nValue) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         case SQL_SCROLLABLE: | 
					
						
							|  |  |  |             nValue = FetchDirection::REVERSE; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         default: | 
					
						
							|  |  |  |             nValue = FetchDirection::FORWARD; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     return nValue; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | sal_Int32 OStatement_Base::getFetchSize() const | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     sal_uInt32 nValue; | 
					
						
							|  |  |  |     SQLRETURN nRetCode = N3SQLGetStmtAttr(m_aStatementHandle,SQL_ATTR_ROW_ARRAY_SIZE,&nValue,SQL_IS_UINTEGER,0); | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     OSL_UNUSED( nRetCode ); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     return nValue; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | sal_Int32 OStatement_Base::getMaxFieldSize() const | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     return getStmtOption(SQL_ATTR_MAX_LENGTH); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | ::rtl::OUString OStatement_Base::getCursorName() const | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     SQLCHAR pName[258]; | 
					
						
							|  |  |  |     SQLSMALLINT nRealLen = 0; | 
					
						
							|  |  |  |     SQLRETURN nRetCode = N3SQLGetCursorName(m_aStatementHandle,(SQLCHAR*)pName,256,&nRealLen); | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     OSL_UNUSED( nRetCode ); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     return ::rtl::OUString::createFromAscii((const char*)pName); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | void OStatement_Base::setQueryTimeOut(sal_Int32 seconds) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     SQLRETURN nRetCode = N3SQLSetStmtAttr(m_aStatementHandle, SQL_ATTR_QUERY_TIMEOUT,(SQLPOINTER)seconds,SQL_IS_UINTEGER); | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     OSL_UNUSED( nRetCode ); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | void OStatement_Base::setMaxRows(sal_Int32 _par0) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     SQLRETURN nRetCode = N3SQLSetStmtAttr(m_aStatementHandle, SQL_ATTR_MAX_ROWS, (SQLPOINTER)_par0,SQL_IS_UINTEGER); | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     OSL_UNUSED( nRetCode ); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | void OStatement_Base::setResultSetConcurrency(sal_Int32 _par0) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     SQLINTEGER nSet; | 
					
						
							|  |  |  |     if(_par0 == ResultSetConcurrency::READ_ONLY) | 
					
						
							|  |  |  |         nSet = SQL_CONCUR_READ_ONLY; | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |         nSet = SQL_CONCUR_VALUES; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |     N3SQLSetStmtAttr(m_aStatementHandle, SQL_ATTR_CONCURRENCY,(SQLPOINTER)nSet,SQL_IS_UINTEGER); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | void OStatement_Base::setResultSetType(sal_Int32 _par0) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     SQLRETURN nRetCode = N3SQLSetStmtAttr(m_aStatementHandle, SQL_ATTR_ROW_BIND_TYPE,(SQLPOINTER)SQL_BIND_BY_COLUMN,SQL_IS_UINTEGER); | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     OSL_UNUSED( nRetCode ); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-11-29 15:35:26 +00:00
										 |  |  |     sal_Bool bUseBookmark = isUsingBookmarks(); | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     SQLUINTEGER nSet( SQL_UNSPECIFIED ); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     switch(_par0) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         case ResultSetType::FORWARD_ONLY: | 
					
						
							|  |  |  |             nSet =  SQL_UNSPECIFIED; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case ResultSetType::SCROLL_INSENSITIVE: | 
					
						
							|  |  |  |             nSet =  SQL_INSENSITIVE; | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |             N3SQLSetStmtAttr(m_aStatementHandle, SQL_ATTR_CURSOR_TYPE,(SQLPOINTER)SQL_CURSOR_KEYSET_DRIVEN,SQL_IS_UINTEGER); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |             break; | 
					
						
							|  |  |  |         case ResultSetType::SCROLL_SENSITIVE: | 
					
						
							| 
									
										
										
										
											2001-11-29 15:35:26 +00:00
										 |  |  |             if(bUseBookmark) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 SQLUINTEGER nCurProp = getCursorProperties(SQL_CURSOR_DYNAMIC,sal_True); | 
					
						
							|  |  |  |                 if((nCurProp & SQL_CA1_BOOKMARK) != SQL_CA1_BOOKMARK) // check if bookmark for this type isn't supported
 | 
					
						
							|  |  |  |                 { // we have to test the next one
 | 
					
						
							|  |  |  |                     nCurProp = getCursorProperties(SQL_CURSOR_KEYSET_DRIVEN,sal_True); | 
					
						
							|  |  |  |                     sal_Bool bNotBookmarks = ((nCurProp & SQL_CA1_BOOKMARK) != SQL_CA1_BOOKMARK); | 
					
						
							|  |  |  |                     nCurProp = getCursorProperties(SQL_CURSOR_KEYSET_DRIVEN,sal_False); | 
					
						
							|  |  |  |                     nSet = SQL_CURSOR_KEYSET_DRIVEN; | 
					
						
							| 
									
										
										
										
											2001-11-30 13:09:45 +00:00
										 |  |  |                     if( bNotBookmarks || | 
					
						
							|  |  |  |                         ((nCurProp & SQL_CA2_SENSITIVITY_DELETIONS) != SQL_CA2_SENSITIVITY_DELETIONS) || | 
					
						
							|  |  |  |                         ((nCurProp & SQL_CA2_SENSITIVITY_ADDITIONS) != SQL_CA2_SENSITIVITY_ADDITIONS)) | 
					
						
							| 
									
										
										
										
											2001-11-29 15:35:26 +00:00
										 |  |  |                     { | 
					
						
							|  |  |  |                         // bookmarks for keyset isn't supported so reset bookmark setting
 | 
					
						
							|  |  |  |                         setUsingBookmarks(sal_False); | 
					
						
							|  |  |  |                         nSet = SQL_CURSOR_DYNAMIC; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                     nSet = SQL_CURSOR_DYNAMIC; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |                 nSet = SQL_CURSOR_DYNAMIC; | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |             if(N3SQLSetStmtAttr(m_aStatementHandle, SQL_ATTR_CURSOR_TYPE,(SQLPOINTER)nSet,SQL_IS_UINTEGER) != SQL_SUCCESS) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 nSet = SQL_CURSOR_KEYSET_DRIVEN; | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |                 N3SQLSetStmtAttr(m_aStatementHandle, SQL_ATTR_CURSOR_TYPE,(SQLPOINTER)nSet,SQL_IS_UINTEGER); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |             } | 
					
						
							|  |  |  |             nSet =  SQL_SENSITIVE; | 
					
						
							|  |  |  |             break; | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |         default: | 
					
						
							|  |  |  |             OSL_ENSURE( false, "OStatement_Base::setResultSetType: invalid result set type!" ); | 
					
						
							|  |  |  |             break; | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |     N3SQLSetStmtAttr(m_aStatementHandle, SQL_ATTR_CURSOR_SENSITIVITY,(SQLPOINTER)nSet,SQL_IS_UINTEGER); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | void OStatement_Base::setFetchDirection(sal_Int32 _par0) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  |     sal_Int32 nCursType = 0; | 
					
						
							|  |  |  |     SQLRETURN nRetCode  = SQL_SUCCESS; | 
					
						
							|  |  |  |     if(_par0 == FetchDirection::FORWARD) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         nCursType = SQL_NONSCROLLABLE; | 
					
						
							|  |  |  |         nRetCode = N3SQLSetStmtAttr(m_aStatementHandle,SQL_ATTR_CURSOR_SCROLLABLE,(SQLPOINTER)nCursType,SQL_IS_UINTEGER); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else if(_par0 == FetchDirection::REVERSE) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         nCursType = SQL_SCROLLABLE; | 
					
						
							|  |  |  |         nRetCode = N3SQLSetStmtAttr(m_aStatementHandle,SQL_ATTR_CURSOR_SCROLLABLE,(SQLPOINTER)nCursType,SQL_IS_UINTEGER); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     OSL_UNUSED( nRetCode ); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | void OStatement_Base::setFetchSize(sal_Int32 _par0) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-11-15 15:02:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     SQLRETURN nRetCode = N3SQLSetStmtAttr(m_aStatementHandle,SQL_ATTR_ROW_ARRAY_SIZE,(SQLPOINTER)_par0,SQL_IS_UINTEGER); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     delete m_pRowStatusArray; | 
					
						
							|  |  |  |     m_pRowStatusArray = new SQLUSMALLINT[_par0]; | 
					
						
							|  |  |  |     nRetCode = N3SQLSetStmtAttr(m_aStatementHandle,SQL_ATTR_ROW_STATUS_PTR,m_pRowStatusArray,SQL_IS_POINTER); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | void OStatement_Base::setMaxFieldSize(sal_Int32 _par0) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |     N3SQLSetStmtAttr(m_aStatementHandle,SQL_ATTR_MAX_LENGTH,(SQLPOINTER)_par0,SQL_IS_UINTEGER); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | //------------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | void OStatement_Base::setCursorName(const ::rtl::OUString &_par0) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2001-02-05 11:26:42 +00:00
										 |  |  |     ::rtl::OString aName(::rtl::OUStringToOString(_par0,getOwnConnection()->getTextEncoding())); | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |     N3SQLSetCursorName(m_aStatementHandle,(SDB_ODBC_CHAR*)aName.getStr(),(SQLSMALLINT)aName.getLength()); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | sal_Bool OStatement_Base::isUsingBookmarks() const | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     sal_uInt32 nValue = SQL_UB_OFF; | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     SQLRETURN nRetCode = N3SQLGetStmtAttr(m_aStatementHandle,SQL_ATTR_USE_BOOKMARKS,&nValue,SQL_IS_UINTEGER,NULL); | 
					
						
							|  |  |  |     OSL_UNUSED( nRetCode ); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     return nValue != SQL_UB_OFF; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  | void OStatement_Base::setUsingBookmarks(sal_Bool _bUseBookmark) | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-03-20 15:54:34 +00:00
										 |  |  |     OSL_ENSURE(m_aStatementHandle,"StatementHandle is null!"); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     sal_uInt32 nValue = _bUseBookmark ? SQL_UB_VARIABLE : SQL_UB_OFF; | 
					
						
							| 
									
										
										
										
											2006-06-20 00:56:39 +00:00
										 |  |  |     SQLRETURN nRetCode = N3SQLSetStmtAttr(m_aStatementHandle,SQL_ATTR_USE_BOOKMARKS,(SQLPOINTER)nValue,SQL_IS_UINTEGER); | 
					
						
							|  |  |  |     OSL_UNUSED( nRetCode ); | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | ::cppu::IPropertyArrayHelper* OStatement_Base::createArrayHelper( ) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     Sequence< Property > aProps(10); | 
					
						
							|  |  |  |     Property* pProperties = aProps.getArray(); | 
					
						
							|  |  |  |     sal_Int32 nPos = 0; | 
					
						
							|  |  |  |     DECL_PROP0(CURSORNAME,  ::rtl::OUString); | 
					
						
							|  |  |  |     DECL_BOOL_PROP0(ESCAPEPROCESSING); | 
					
						
							|  |  |  |     DECL_PROP0(FETCHDIRECTION,sal_Int32); | 
					
						
							|  |  |  |     DECL_PROP0(FETCHSIZE,   sal_Int32); | 
					
						
							|  |  |  |     DECL_PROP0(MAXFIELDSIZE,sal_Int32); | 
					
						
							|  |  |  |     DECL_PROP0(MAXROWS,     sal_Int32); | 
					
						
							|  |  |  |     DECL_PROP0(QUERYTIMEOUT,sal_Int32); | 
					
						
							|  |  |  |     DECL_PROP0(RESULTSETCONCURRENCY,sal_Int32); | 
					
						
							|  |  |  |     DECL_PROP0(RESULTSETTYPE,sal_Int32); | 
					
						
							|  |  |  |     DECL_BOOL_PROP0(USEBOOKMARKS); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return new ::cppu::OPropertyArrayHelper(aProps); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | ::cppu::IPropertyArrayHelper & OStatement_Base::getInfoHelper() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return *const_cast<OStatement_Base*>(this)->getArrayHelper(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | sal_Bool OStatement_Base::convertFastPropertyValue( | 
					
						
							|  |  |  |                             Any & rConvertedValue, | 
					
						
							|  |  |  |                             Any & rOldValue, | 
					
						
							|  |  |  |                             sal_Int32 nHandle, | 
					
						
							|  |  |  |                             const Any& rValue ) | 
					
						
							|  |  |  |                                 throw (::com::sun::star::lang::IllegalArgumentException) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     sal_Bool bConverted = sal_False; | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |     try | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |         switch(nHandle) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             case PROPERTY_ID_QUERYTIMEOUT: | 
					
						
							|  |  |  |                 bConverted = ::comphelper::tryPropertyValue(rConvertedValue, rOldValue, rValue, getQueryTimeOut()); | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2001-08-06 09:55:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |             case PROPERTY_ID_MAXFIELDSIZE: | 
					
						
							|  |  |  |                 bConverted = ::comphelper::tryPropertyValue(rConvertedValue, rOldValue, rValue, getMaxFieldSize()); | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2001-08-06 09:55:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |             case PROPERTY_ID_MAXROWS: | 
					
						
							|  |  |  |                 bConverted = ::comphelper::tryPropertyValue(rConvertedValue, rOldValue, rValue, getMaxRows()); | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2001-08-06 09:55:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |             case PROPERTY_ID_CURSORNAME: | 
					
						
							|  |  |  |                 bConverted = ::comphelper::tryPropertyValue(rConvertedValue, rOldValue, rValue, getCursorName()); | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2001-08-06 09:55:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |             case PROPERTY_ID_RESULTSETCONCURRENCY: | 
					
						
							|  |  |  |                 bConverted = ::comphelper::tryPropertyValue(rConvertedValue, rOldValue, rValue, getResultSetConcurrency()); | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2001-08-06 09:55:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |             case PROPERTY_ID_RESULTSETTYPE: | 
					
						
							|  |  |  |                 bConverted = ::comphelper::tryPropertyValue(rConvertedValue, rOldValue, rValue, getResultSetType()); | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2001-08-06 09:55:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |             case PROPERTY_ID_FETCHDIRECTION: | 
					
						
							|  |  |  |                 bConverted = ::comphelper::tryPropertyValue(rConvertedValue, rOldValue, rValue, getFetchDirection()); | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2001-08-06 09:55:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |             case PROPERTY_ID_FETCHSIZE: | 
					
						
							|  |  |  |                 bConverted = ::comphelper::tryPropertyValue(rConvertedValue, rOldValue, rValue, getFetchSize()); | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2001-08-06 09:55:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |             case PROPERTY_ID_USEBOOKMARKS: | 
					
						
							|  |  |  |                 bConverted = ::comphelper::tryPropertyValue(rConvertedValue, rOldValue, rValue, isUsingBookmarks()); | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |             default: | 
					
						
							|  |  |  |                 ; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     catch(const SQLException&) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         //  throw Exception(e.Message,*this);
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-05-14 10:55:19 +00:00
										 |  |  |     return bConverted; | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | void OStatement_Base::setFastPropertyValue_NoBroadcast(sal_Int32 nHandle,const Any& rValue) throw (Exception) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |     try | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-09-18 10:22:34 +00:00
										 |  |  |         switch(nHandle) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             case PROPERTY_ID_QUERYTIMEOUT: | 
					
						
							|  |  |  |                 setQueryTimeOut(comphelper::getINT32(rValue)); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case PROPERTY_ID_MAXFIELDSIZE: | 
					
						
							|  |  |  |                 setMaxFieldSize(comphelper::getINT32(rValue)); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case PROPERTY_ID_MAXROWS: | 
					
						
							|  |  |  |                 setMaxRows(comphelper::getINT32(rValue)); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case PROPERTY_ID_CURSORNAME: | 
					
						
							|  |  |  |                 setCursorName(comphelper::getString(rValue)); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case PROPERTY_ID_RESULTSETCONCURRENCY: | 
					
						
							|  |  |  |                 setResultSetConcurrency(comphelper::getINT32(rValue)); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case PROPERTY_ID_RESULTSETTYPE: | 
					
						
							|  |  |  |                 setResultSetType(comphelper::getINT32(rValue)); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case PROPERTY_ID_FETCHDIRECTION: | 
					
						
							|  |  |  |                 setFetchDirection(comphelper::getINT32(rValue)); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case PROPERTY_ID_FETCHSIZE: | 
					
						
							|  |  |  |                 setFetchSize(comphelper::getINT32(rValue)); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case PROPERTY_ID_USEBOOKMARKS: | 
					
						
							|  |  |  |                 setUsingBookmarks(comphelper::getBOOL(rValue)); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             default: | 
					
						
							|  |  |  |                 ; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     catch(const SQLException& ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         //  throw Exception(e.Message,*this);
 | 
					
						
							| 
									
										
										
										
											2000-09-18 15:18:56 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | void OStatement_Base::getFastPropertyValue(Any& rValue,sal_Int32 nHandle) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     switch(nHandle) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         case PROPERTY_ID_QUERYTIMEOUT: | 
					
						
							|  |  |  |             rValue <<= getQueryTimeOut(); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case PROPERTY_ID_MAXFIELDSIZE: | 
					
						
							|  |  |  |             rValue <<= getMaxFieldSize(); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case PROPERTY_ID_MAXROWS: | 
					
						
							|  |  |  |             rValue <<= getMaxRows(); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case PROPERTY_ID_CURSORNAME: | 
					
						
							|  |  |  |             rValue <<= getCursorName(); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case PROPERTY_ID_RESULTSETCONCURRENCY: | 
					
						
							|  |  |  |             rValue <<= getResultSetConcurrency(); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case PROPERTY_ID_RESULTSETTYPE: | 
					
						
							|  |  |  |             rValue <<= getResultSetType(); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case PROPERTY_ID_FETCHDIRECTION: | 
					
						
							|  |  |  |             rValue <<= getFetchDirection(); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case PROPERTY_ID_FETCHSIZE: | 
					
						
							|  |  |  |             rValue <<= getFetchSize(); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case PROPERTY_ID_USEBOOKMARKS: | 
					
						
							|  |  |  |             rValue <<= cppu::bool2any(isUsingBookmarks()); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         default: | 
					
						
							|  |  |  |             ; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -------------------------------------------------------------------------
 | 
					
						
							|  |  |  | IMPLEMENT_SERVICE_INFO(OStatement,"com.sun.star.sdbcx.OStatement","com.sun.star.sdbc.Statement"); | 
					
						
							| 
									
										
										
										
											2001-04-30 09:16:19 +00:00
										 |  |  | // -----------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-10-17 13:55:07 +00:00
										 |  |  | void SAL_CALL OStatement_Base::acquire() throw() | 
					
						
							| 
									
										
										
										
											2001-04-30 09:16:19 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     OStatement_BASE::acquire(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -----------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-10-17 13:55:07 +00:00
										 |  |  | void SAL_CALL OStatement_Base::release() throw() | 
					
						
							| 
									
										
										
										
											2001-04-30 09:16:19 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     OStatement_BASE::release(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -----------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-10-17 13:55:07 +00:00
										 |  |  | void SAL_CALL OStatement::acquire() throw() | 
					
						
							| 
									
										
										
										
											2001-04-30 09:16:19 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     OStatement_BASE2::acquire(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -----------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-10-17 13:55:07 +00:00
										 |  |  | void SAL_CALL OStatement::release() throw() | 
					
						
							| 
									
										
										
										
											2001-04-30 09:16:19 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     OStatement_BASE2::release(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -----------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-08-02 09:41:53 +00:00
										 |  |  | OResultSet* OStatement_Base::createResulSet() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return new OResultSet(m_aStatementHandle,this); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -----------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-04-30 09:16:19 +00:00
										 |  |  | Reference< ::com::sun::star::beans::XPropertySetInfo > SAL_CALL OStatement_Base::getPropertySetInfo(  ) throw(RuntimeException) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return ::cppu::OPropertySetHelper::createPropertySetInfo(getInfoHelper()); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -----------------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2001-11-29 15:35:26 +00:00
										 |  |  | SQLUINTEGER OStatement_Base::getCursorProperties(SQLINTEGER _nCursorType,sal_Bool bFirst) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     SQLUINTEGER nValueLen = 0; | 
					
						
							|  |  |  |     try | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SQLUSMALLINT nAskFor = SQL_FORWARD_ONLY_CURSOR_ATTRIBUTES2; | 
					
						
							|  |  |  |         if(SQL_CURSOR_KEYSET_DRIVEN == _nCursorType) | 
					
						
							|  |  |  |             nAskFor = bFirst ? SQL_KEYSET_CURSOR_ATTRIBUTES1 : SQL_KEYSET_CURSOR_ATTRIBUTES2; | 
					
						
							|  |  |  |         else if(SQL_CURSOR_STATIC  == _nCursorType) | 
					
						
							|  |  |  |             nAskFor = bFirst ? SQL_STATIC_CURSOR_ATTRIBUTES1 : SQL_STATIC_CURSOR_ATTRIBUTES2; | 
					
						
							|  |  |  |         else if(SQL_CURSOR_FORWARD_ONLY == _nCursorType) | 
					
						
							|  |  |  |             nAskFor = bFirst ? SQL_FORWARD_ONLY_CURSOR_ATTRIBUTES1 : SQL_FORWARD_ONLY_CURSOR_ATTRIBUTES2; | 
					
						
							|  |  |  |         else if(SQL_CURSOR_DYNAMIC == _nCursorType) | 
					
						
							|  |  |  |             nAskFor = bFirst ? SQL_DYNAMIC_CURSOR_ATTRIBUTES1 : SQL_DYNAMIC_CURSOR_ATTRIBUTES2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         OTools::GetInfo(getOwnConnection(),getConnectionHandle(),nAskFor,nValueLen,NULL); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     catch(Exception&) | 
					
						
							|  |  |  |     { // we don't want our result destroy here
 | 
					
						
							|  |  |  |         nValueLen = 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return nValueLen; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // -----------------------------------------------------------------------------
 |