2000-09-18 15:18:56 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2005-09-08 05:33:39 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
2005-09-08 05:33:39 +00:00
|
|
|
* $RCSfile: ODatabaseMetaData.cxx,v $
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
2006-02-03 16:14:56 +00:00
|
|
|
* $Revision: 1.30 $
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
2006-02-03 16:14:56 +00:00
|
|
|
* last change: $Author: kz $ $Date: 2006-02-03 17:14:56 $
|
2000-09-18 15:18:56 +00:00
|
|
|
*
|
2005-09-08 05:33:39 +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:33:39 +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:33:39 +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:33:39 +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:33:39 +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
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _CONNECTIVITY_ODBC_ODATABASEMETADATA_HXX_
|
|
|
|
#include "odbc/ODatabaseMetaData.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _CONNECTIVITY_OTOOLS_HXX_
|
|
|
|
#include "odbc/OTools.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _CONNECTIVITY_ODBC_ORESULTSET_HXX_
|
2000-11-22 13:36:27 +00:00
|
|
|
#include "odbc/ODatabaseMetaDataResultSet.hxx"
|
2000-09-18 15:18:56 +00:00
|
|
|
#endif
|
2001-03-28 10:32:43 +00:00
|
|
|
#ifndef _CONNECTIVITY_FDATABASEMETADATARESULTSET_HXX_
|
|
|
|
#include "FDatabaseMetaDataResultSet.hxx"
|
|
|
|
#endif
|
2000-09-18 15:18:56 +00:00
|
|
|
#ifndef _COM_SUN_STAR_SDBC_DATATYPE_HPP_
|
|
|
|
#include <com/sun/star/sdbc/DataType.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_RESULTSETTYPE_HPP_
|
|
|
|
#include <com/sun/star/sdbc/ResultSetType.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_RESULTSETCONCURRENCY_HPP_
|
|
|
|
#include <com/sun/star/sdbc/ResultSetConcurrency.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _CONNECTIVITY_OFUNCTIONDEFS_HXX_
|
|
|
|
#include "odbc/OFunctiondefs.hxx"
|
|
|
|
#endif
|
2001-10-12 11:02:56 +00:00
|
|
|
#include "stdio.h"
|
2003-04-11 13:41:23 +00:00
|
|
|
#include "TPrivilegesResultSet.hxx"
|
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;
|
|
|
|
|
|
|
|
ODatabaseMetaData::ODatabaseMetaData(const SQLHANDLE _pHandle,OConnection* _pCon)
|
2001-01-09 11:39:52 +00:00
|
|
|
: ::connectivity::ODatabaseMetaDataBase(_pCon)
|
2000-11-03 13:21:22 +00:00
|
|
|
,m_aConnectionHandle(_pHandle)
|
|
|
|
,m_pConnection(_pCon)
|
2001-04-20 12:31:58 +00:00
|
|
|
,m_bUseCatalog(sal_True)
|
2001-07-12 11:14:47 +00:00
|
|
|
,m_bOdbc3(sal_True)
|
2000-09-18 15:18:56 +00:00
|
|
|
{
|
2001-05-15 07:18:32 +00:00
|
|
|
OSL_ENSURE(m_pConnection,"ODatabaseMetaData::ODatabaseMetaData: No connection set!");
|
2001-04-20 12:31:58 +00:00
|
|
|
if(!m_pConnection->isCatalogUsed())
|
|
|
|
{
|
|
|
|
osl_incrementInterlockedCount( &m_refCount );
|
2001-10-08 06:20:00 +00:00
|
|
|
try
|
|
|
|
{
|
|
|
|
m_bUseCatalog = !(usesLocalFiles() || usesLocalFilePerTable());
|
|
|
|
::rtl::OUString sVersion = getDriverVersion();
|
|
|
|
m_bOdbc3 = sVersion != ::rtl::OUString::createFromAscii("02.50") && sVersion != ::rtl::OUString::createFromAscii("02.00");
|
|
|
|
}
|
|
|
|
catch(SQLException& )
|
|
|
|
{ // doesn't matter here
|
|
|
|
}
|
2001-04-20 12:31:58 +00:00
|
|
|
osl_decrementInterlockedCount( &m_refCount );
|
|
|
|
}
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
ODatabaseMetaData::~ODatabaseMetaData()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getTypeInfo( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openTypeInfo();
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setTypeInfoMap();
|
|
|
|
}
|
2001-10-22 10:17:34 +00:00
|
|
|
|
2000-09-18 15:18:56 +00:00
|
|
|
return xRef;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getCatalogs( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-04-20 12:31:58 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
if(!m_bUseCatalog)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setCatalogsMap();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openCatalogs();
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setCatalogsMap();
|
|
|
|
}
|
2001-04-20 12:31:58 +00:00
|
|
|
}
|
2001-10-22 10:17:34 +00:00
|
|
|
|
2000-09-18 15:18:56 +00:00
|
|
|
return xRef;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getCatalogSeparator( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-10-08 06:20:00 +00:00
|
|
|
|
2000-09-18 15:18:56 +00:00
|
|
|
::rtl::OUString aVal;
|
2001-04-20 12:31:58 +00:00
|
|
|
if(m_bUseCatalog)
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CATALOG_NAME_SEPARATOR,aVal,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
return aVal;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getSchemas( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openSchemas();
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setSchemasMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getColumnPrivileges(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schema, const ::rtl::OUString& table,
|
|
|
|
const ::rtl::OUString& columnNamePattern ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openColumnPrivileges(m_bUseCatalog ? catalog : Any(),schema,table,columnNamePattern);
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setColumnPrivilegesMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getColumns(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schemaPattern, const ::rtl::OUString& tableNamePattern,
|
|
|
|
const ::rtl::OUString& columnNamePattern ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openColumns(m_bUseCatalog ? catalog : Any(),schemaPattern,tableNamePattern,columnNamePattern);
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setColumnsMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getTables(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schemaPattern,
|
|
|
|
const ::rtl::OUString& tableNamePattern, const Sequence< ::rtl::OUString >& types ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openTables(m_bUseCatalog ? catalog : Any(),schemaPattern,tableNamePattern,types);
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setTablesMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getProcedureColumns(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schemaPattern,
|
|
|
|
const ::rtl::OUString& procedureNamePattern, const ::rtl::OUString& columnNamePattern ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openProcedureColumns(m_bUseCatalog ? catalog : Any(),schemaPattern,procedureNamePattern,columnNamePattern);
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setProcedureColumnsMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getProcedures(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schemaPattern,
|
|
|
|
const ::rtl::OUString& procedureNamePattern ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openProcedures(m_bUseCatalog ? catalog : Any(),schemaPattern,procedureNamePattern);
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setProceduresMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getVersionColumns(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schema, const ::rtl::OUString& table ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
2006-02-03 16:14:56 +00:00
|
|
|
bool bSuccess = false;
|
2001-11-29 15:35:26 +00:00
|
|
|
try
|
|
|
|
{
|
2006-02-03 16:14:56 +00:00
|
|
|
if ( !m_pConnection->preventGetVersionColumns() )
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openVersionColumns(m_bUseCatalog ? catalog : Any(),schema,table);
|
|
|
|
bSuccess = true;
|
|
|
|
}
|
2001-11-29 15:35:26 +00:00
|
|
|
}
|
|
|
|
catch(SQLException&)
|
2006-02-03 16:14:56 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( !bSuccess )
|
2001-11-29 15:35:26 +00:00
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setVersionColumnsMap();
|
|
|
|
}
|
2001-10-22 10:17:34 +00:00
|
|
|
|
2006-02-03 16:14:56 +00:00
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxBinaryLiteralLength( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_BINARY_LITERAL_LEN,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxRowSize( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_ROW_SIZE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxCatalogNameLength( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_CATALOG_NAME_LEN,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxCharLiteralLength( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_CHAR_LITERAL_LEN,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxColumnNameLength( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_COLUMN_NAME_LEN,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxColumnsInIndex( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_COLUMNS_IN_INDEX,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxCursorNameLength( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_CURSOR_NAME_LEN,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxConnections( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_DRIVER_CONNECTIONS/*SQL_ACTIVE_CONNECTIONS*/,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxColumnsInTable( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_COLUMNS_IN_TABLE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxStatementLength( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_STATEMENT_LEN,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxTableNameLength( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_TABLE_NAME_LEN,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxTablesInSelect( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_TABLES_IN_SELECT,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getExportedKeys(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schema, const ::rtl::OUString& table ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openExportedKeys(m_bUseCatalog ? catalog : Any(),schema,table);
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setExportedKeysMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getImportedKeys(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schema, const ::rtl::OUString& table ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openImportedKeys(m_bUseCatalog ? catalog : Any(),schema,table);
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setImportedKeysMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getPrimaryKeys(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schema, const ::rtl::OUString& table ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openPrimaryKeys(m_bUseCatalog ? catalog : Any(),schema,table);
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setPrimaryKeysMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getIndexInfo(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schema, const ::rtl::OUString& table,
|
|
|
|
sal_Bool unique, sal_Bool approximate ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openIndexInfo(m_bUseCatalog ? catalog : Any(),schema,table,unique,approximate);
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setIndexInfoMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getBestRowIdentifier(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schema, const ::rtl::OUString& table, sal_Int32 scope,
|
|
|
|
sal_Bool nullable ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openBestRowIdentifier(m_bUseCatalog ? catalog : Any(),schema,table,scope,nullable);
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setBestRowIdentifierMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getTablePrivileges(
|
|
|
|
const Any& catalog, const ::rtl::OUString& schemaPattern, const ::rtl::OUString& tableNamePattern ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2003-04-11 13:41:23 +00:00
|
|
|
if ( m_pConnection->isIgnoreDriverPrivilegesEnabled() )
|
|
|
|
{
|
|
|
|
return new OResultSetPrivileges(this,catalog,schemaPattern,tableNamePattern);
|
|
|
|
}
|
2001-08-29 11:13:20 +00:00
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
2000-09-18 15:18:56 +00:00
|
|
|
Reference< XResultSet > xRef = pResult;
|
2001-04-20 12:31:58 +00:00
|
|
|
pResult->openTablePrivileges(m_bUseCatalog ? catalog : Any(),schemaPattern,tableNamePattern);
|
2001-11-29 15:35:26 +00:00
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getCrossReference(
|
|
|
|
const Any& primaryCatalog, const ::rtl::OUString& primarySchema,
|
|
|
|
const ::rtl::OUString& primaryTable, const Any& foreignCatalog,
|
|
|
|
const ::rtl::OUString& foreignSchema, const ::rtl::OUString& foreignTable ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-11-29 15:35:26 +00:00
|
|
|
Reference< XResultSet > xRef;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
ODatabaseMetaDataResultSet* pResult = new ODatabaseMetaDataResultSet(m_pConnection);
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->openForeignKeys(m_bUseCatalog ? primaryCatalog : Any(),primarySchema.toChar() == '%' ? &primarySchema : NULL,&primaryTable,
|
|
|
|
m_bUseCatalog ? foreignCatalog : Any(), foreignSchema.toChar() == '%' ? &foreignSchema : NULL,&foreignTable);
|
|
|
|
}
|
|
|
|
catch(SQLException&)
|
|
|
|
{
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
|
|
|
xRef = pResult;
|
|
|
|
pResult->setCrossReferenceMap();
|
|
|
|
}
|
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::doesMaxRowSizeIncludeBlobs( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aVal;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_ROW_SIZE_INCLUDES_LONG,aVal,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aVal.toChar() == 'Y';
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::storesLowerCaseQuotedIdentifiers( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_QUOTED_IDENTIFIER_CASE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_IC_LOWER;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::storesLowerCaseIdentifiers( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_IDENTIFIER_CASE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_IC_LOWER;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::storesMixedCaseQuotedIdentifiers( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_QUOTED_IDENTIFIER_CASE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_IC_MIXED;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::storesMixedCaseIdentifiers( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_IDENTIFIER_CASE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_IC_MIXED;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::storesUpperCaseQuotedIdentifiers( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_QUOTED_IDENTIFIER_CASE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_IC_UPPER;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::storesUpperCaseIdentifiers( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_IDENTIFIER_CASE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_IC_UPPER;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsAlterTableWithAddColumn( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_ALTER_TABLE,nValue,*this);
|
2001-10-22 09:18:23 +00:00
|
|
|
return (nValue & SQL_AT_ADD_COLUMN) == SQL_AT_ADD_COLUMN;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsAlterTableWithDropColumn( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_ALTER_TABLE,nValue,*this);
|
2001-10-29 10:18:01 +00:00
|
|
|
return ((nValue & SQL_AT_DROP_COLUMN) == SQL_AT_DROP_COLUMN) ||
|
|
|
|
((nValue & SQL_AT_DROP_COLUMN_CASCADE) == SQL_AT_DROP_COLUMN_CASCADE) ||
|
|
|
|
((nValue & SQL_AT_DROP_COLUMN_RESTRICT) == SQL_AT_DROP_COLUMN_RESTRICT);
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxIndexLength( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_INDEX_SIZE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsNonNullableColumns( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_NON_NULLABLE_COLUMNS,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_NNC_NON_NULL;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getCatalogTerm( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aVal;
|
2001-04-20 12:31:58 +00:00
|
|
|
if(m_bUseCatalog)
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CATALOG_TERM,aVal,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aVal;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getIdentifierQuoteString( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aVal;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_IDENTIFIER_QUOTE_CHAR,aVal,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aVal;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getExtraNameCharacters( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aVal;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SPECIAL_CHARACTERS,aVal,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aVal;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsDifferentTableCorrelationNames( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CORRELATION_NAME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue != SQL_CN_NONE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::isCatalogAtStart( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue=0;
|
2001-04-20 12:31:58 +00:00
|
|
|
if(m_bUseCatalog)
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CATALOG_LOCATION,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_CL_START;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::dataDefinitionIgnoredInTransactions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_TXN_CAPABLE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_TC_DDL_IGNORE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::dataDefinitionCausesTransactionCommit( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_TXN_CAPABLE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_TC_DDL_COMMIT;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsDataManipulationTransactionsOnly( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_TXN_CAPABLE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_TC_DML;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsDataDefinitionAndDataManipulationTransactions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_TXN_CAPABLE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_TC_ALL;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsPositionedDelete( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_DYNAMIC_CURSOR_ATTRIBUTES1,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_CA1_POS_DELETE) == SQL_CA1_POS_DELETE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsPositionedUpdate( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_DYNAMIC_CURSOR_ATTRIBUTES1,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_CA1_POS_UPDATE) == SQL_CA1_POS_UPDATE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsOpenStatementsAcrossRollback( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CURSOR_ROLLBACK_BEHAVIOR,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_CB_PRESERVE || nValue == SQL_CB_CLOSE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsOpenStatementsAcrossCommit( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CURSOR_COMMIT_BEHAVIOR,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_CB_PRESERVE || nValue == SQL_CB_CLOSE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsOpenCursorsAcrossCommit( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CURSOR_COMMIT_BEHAVIOR,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_CB_PRESERVE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsOpenCursorsAcrossRollback( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CURSOR_ROLLBACK_BEHAVIOR,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_CB_PRESERVE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsTransactionIsolationLevel( sal_Int32 level ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_TXN_ISOLATION_OPTION,nValue,*this);
|
2001-10-22 09:18:23 +00:00
|
|
|
return (nValue & static_cast<SQLUINTEGER>(level)) == static_cast<SQLUINTEGER>(level);
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsSchemasInDataManipulation( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SCHEMA_USAGE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_SU_DML_STATEMENTS) == SQL_SU_DML_STATEMENTS;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsANSI92FullSQL( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SQL_CONFORMANCE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_SC_SQL92_FULL;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsANSI92EntryLevelSQL( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SQL_CONFORMANCE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_SC_SQL92_ENTRY;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsIntegrityEnhancementFacility( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aStr;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_INTEGRITY,aStr,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aStr.toChar() == 'Y';
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsSchemasInIndexDefinitions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SCHEMA_USAGE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_SU_INDEX_DEFINITION) == SQL_SU_INDEX_DEFINITION;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsSchemasInTableDefinitions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SCHEMA_USAGE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_SU_TABLE_DEFINITION) == SQL_SU_TABLE_DEFINITION;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsCatalogsInTableDefinitions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue=0;
|
2001-04-20 12:31:58 +00:00
|
|
|
if(m_bUseCatalog)
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CATALOG_USAGE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_CU_TABLE_DEFINITION) == SQL_CU_TABLE_DEFINITION;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsCatalogsInIndexDefinitions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue=0;
|
2001-04-20 12:31:58 +00:00
|
|
|
if(m_bUseCatalog)
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CATALOG_USAGE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_CU_INDEX_DEFINITION) == SQL_CU_INDEX_DEFINITION;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsCatalogsInDataManipulation( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue=0;
|
2001-04-20 12:31:58 +00:00
|
|
|
if(m_bUseCatalog)
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CATALOG_USAGE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_CU_DML_STATEMENTS) == SQL_CU_DML_STATEMENTS;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsOuterJoins( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_OJ_CAPABILITIES,nValue,*this);
|
2005-03-18 08:57:23 +00:00
|
|
|
return ((nValue & (SQL_OJ_FULL|SQL_OJ_LEFT|SQL_OJ_RIGHT|SQL_OJ_NESTED|SQL_OJ_NOT_ORDERED|SQL_OJ_ALL_COMPARISON_OPS|SQL_OJ_INNER)) != 0);
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getTableTypes( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-10-22 10:17:34 +00:00
|
|
|
|
2001-03-28 10:32:43 +00:00
|
|
|
// there exists no possibility to get table types so we have to check
|
|
|
|
static ::rtl::OUString sTableTypes[] =
|
|
|
|
{
|
|
|
|
::rtl::OUString::createFromAscii("TABLE"),
|
|
|
|
::rtl::OUString::createFromAscii("VIEW"),
|
|
|
|
::rtl::OUString::createFromAscii("SYSTEM TABLE"),
|
|
|
|
::rtl::OUString::createFromAscii("GLOBAL TEMPORARY"),
|
|
|
|
::rtl::OUString::createFromAscii("LOCAL TEMPORARY"),
|
|
|
|
::rtl::OUString::createFromAscii("ALIAS"),
|
|
|
|
::rtl::OUString::createFromAscii("SYNONYM")
|
|
|
|
};
|
|
|
|
sal_Int32 nSize = sizeof(sTableTypes) / sizeof(::rtl::OUString);
|
|
|
|
::connectivity::ODatabaseMetaDataResultSet* pResult = new ::connectivity::ODatabaseMetaDataResultSet();
|
2000-09-18 15:18:56 +00:00
|
|
|
Reference< XResultSet > xRef = pResult;
|
2001-03-28 10:32:43 +00:00
|
|
|
pResult->setTableTypes();
|
2001-10-08 06:20:00 +00:00
|
|
|
SQLUINTEGER nValue = 0;
|
2002-11-13 11:39:30 +00:00
|
|
|
try
|
|
|
|
{
|
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CREATE_VIEW,nValue,*this);
|
|
|
|
}
|
|
|
|
catch(const Exception&)
|
|
|
|
{
|
|
|
|
}
|
2001-10-08 06:20:00 +00:00
|
|
|
sal_Bool bViewsSupported = (nValue & SQL_CV_CREATE_VIEW) == SQL_CV_CREATE_VIEW;
|
2001-03-28 10:32:43 +00:00
|
|
|
|
2001-08-24 05:19:41 +00:00
|
|
|
::connectivity::ODatabaseMetaDataResultSet::ORows aRows;
|
2001-03-28 10:32:43 +00:00
|
|
|
for(sal_Int32 i=0;i < nSize;++i)
|
|
|
|
{
|
|
|
|
if( !bViewsSupported && i == 1)
|
|
|
|
continue; // no views supported
|
2001-08-24 05:19:41 +00:00
|
|
|
::connectivity::ODatabaseMetaDataResultSet::ORow aRow;
|
|
|
|
aRow.push_back(::connectivity::ODatabaseMetaDataResultSet::getEmptyValue());
|
2001-08-29 11:13:20 +00:00
|
|
|
aRow.push_back(new ::connectivity::ORowSetValueDecorator(sTableTypes[i]));
|
2001-03-28 10:32:43 +00:00
|
|
|
aRows.push_back(aRow);
|
|
|
|
}
|
|
|
|
pResult->setRows(aRows);
|
2001-10-22 10:17:34 +00:00
|
|
|
return xRef;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxStatements( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_CONCURRENT_ACTIVITIES,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxProcedureNameLength( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_PROCEDURE_NAME_LEN,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxSchemaNameLength( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_SCHEMA_NAME_LEN,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsTransactions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_TXN_CAPABLE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue != SQL_TC_NONE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::allProceduresAreCallable( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_ACCESSIBLE_PROCEDURES,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue.toChar() == 'Y';
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsStoredProcedures( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_PROCEDURES,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue.toChar() == 'Y';
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsSelectForUpdate( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_DYNAMIC_CURSOR_ATTRIBUTES1,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_CA1_POSITIONED_UPDATE) == SQL_CA1_POSITIONED_UPDATE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::allTablesAreSelectable( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_ACCESSIBLE_TABLES,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue.toChar() == 'Y';
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::isReadOnly( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-07-17 10:26:05 +00:00
|
|
|
::rtl::OUString aValue;
|
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_DATA_SOURCE_READ_ONLY,aValue,*this,m_pConnection->getTextEncoding());
|
|
|
|
return aValue.toChar() == 'Y';
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::usesLocalFiles( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_FILE_USAGE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_FILE_CATALOG;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::usesLocalFilePerTable( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_FILE_USAGE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_FILE_TABLE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsTypeConversion( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_FUNCTIONS,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_FN_CVT_CONVERT) == SQL_FN_CVT_CONVERT;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::nullPlusNonNullIsNull( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONCAT_NULL_BEHAVIOR,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_CB_NULL;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsColumnAliasing( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_COLUMN_ALIAS,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue.toChar() == 'Y';
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsTableCorrelationNames( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CORRELATION_NAME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue != SQL_CN_NONE;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsConvert( sal_Int32 fromType, sal_Int32 toType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if(fromType == toType)
|
|
|
|
return sal_True;
|
|
|
|
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue=0;
|
2000-09-18 15:18:56 +00:00
|
|
|
switch(fromType)
|
|
|
|
{
|
|
|
|
case DataType::BIT:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_BIT,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::TINYINT:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_TINYINT,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::SMALLINT:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_SMALLINT,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::INTEGER:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_INTEGER,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::BIGINT:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_BIGINT,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::FLOAT:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_FLOAT,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::REAL:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_REAL,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::DOUBLE:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_DOUBLE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::NUMERIC:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_NUMERIC,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::DECIMAL:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_DECIMAL,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::CHAR:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_CHAR,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::VARCHAR:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_VARCHAR,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::LONGVARCHAR:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_LONGVARCHAR,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::DATE:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_DATE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::TIME:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_TIME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::TIMESTAMP:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_TIMESTAMP,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::BINARY:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_BINARY,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::VARBINARY:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_VARBINARY,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::LONGVARBINARY:
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CONVERT_LONGVARBINARY,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::SQLNULL:
|
2001-05-15 07:18:32 +00:00
|
|
|
// OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CORRELATION_NAME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::OTHER:
|
2001-05-15 07:18:32 +00:00
|
|
|
// OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CORRELATION_NAME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::OBJECT:
|
2001-05-15 07:18:32 +00:00
|
|
|
// OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CORRELATION_NAME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::DISTINCT:
|
2001-05-15 07:18:32 +00:00
|
|
|
// OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CORRELATION_NAME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::STRUCT:
|
2001-05-15 07:18:32 +00:00
|
|
|
// OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CORRELATION_NAME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::ARRAY:
|
2001-05-15 07:18:32 +00:00
|
|
|
// OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CORRELATION_NAME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::BLOB:
|
2001-05-15 07:18:32 +00:00
|
|
|
// OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CORRELATION_NAME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::CLOB:
|
2001-05-15 07:18:32 +00:00
|
|
|
// OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CORRELATION_NAME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
case DataType::REF:
|
2001-05-15 07:18:32 +00:00
|
|
|
// OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CORRELATION_NAME,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
sal_Bool bConvert = sal_False;
|
|
|
|
switch(toType)
|
|
|
|
{
|
|
|
|
case DataType::BIT:
|
|
|
|
bConvert = (nValue & SQL_CVT_BIT) == SQL_CVT_BIT;
|
|
|
|
break;
|
|
|
|
case DataType::TINYINT:
|
|
|
|
bConvert = (nValue & SQL_CVT_TINYINT) == SQL_CVT_TINYINT;
|
|
|
|
break;
|
|
|
|
case DataType::SMALLINT:
|
|
|
|
bConvert = (nValue & SQL_CVT_SMALLINT) == SQL_CVT_SMALLINT;
|
|
|
|
break;
|
|
|
|
case DataType::INTEGER:
|
|
|
|
bConvert = (nValue & SQL_CVT_INTEGER) == SQL_CVT_INTEGER;
|
|
|
|
break;
|
|
|
|
case DataType::BIGINT:
|
|
|
|
bConvert = (nValue & SQL_CVT_BIGINT) == SQL_CVT_BIGINT;
|
|
|
|
break;
|
|
|
|
case DataType::FLOAT:
|
|
|
|
bConvert = (nValue & SQL_CVT_FLOAT) == SQL_CVT_FLOAT;
|
|
|
|
break;
|
|
|
|
case DataType::REAL:
|
|
|
|
bConvert = (nValue & SQL_CVT_REAL) == SQL_CVT_REAL;
|
|
|
|
break;
|
|
|
|
case DataType::DOUBLE:
|
|
|
|
bConvert = (nValue & SQL_CVT_DOUBLE) == SQL_CVT_DOUBLE;
|
|
|
|
break;
|
|
|
|
case DataType::NUMERIC:
|
|
|
|
bConvert = (nValue & SQL_CVT_NUMERIC) == SQL_CVT_NUMERIC;
|
|
|
|
break;
|
|
|
|
case DataType::DECIMAL:
|
|
|
|
bConvert = (nValue & SQL_CVT_DECIMAL) == SQL_CVT_DECIMAL;
|
|
|
|
break;
|
|
|
|
case DataType::CHAR:
|
|
|
|
bConvert = (nValue & SQL_CVT_CHAR) == SQL_CVT_CHAR;
|
|
|
|
break;
|
|
|
|
case DataType::VARCHAR:
|
|
|
|
bConvert = (nValue & SQL_CVT_VARCHAR) == SQL_CVT_VARCHAR;
|
|
|
|
break;
|
|
|
|
case DataType::LONGVARCHAR:
|
|
|
|
bConvert = (nValue & SQL_CVT_LONGVARCHAR) == SQL_CVT_LONGVARCHAR;
|
|
|
|
break;
|
|
|
|
case DataType::DATE:
|
|
|
|
bConvert = (nValue & SQL_CVT_DATE) == SQL_CVT_DATE;
|
|
|
|
break;
|
|
|
|
case DataType::TIME:
|
|
|
|
bConvert = (nValue & SQL_CVT_TIME) == SQL_CVT_TIME;
|
|
|
|
break;
|
|
|
|
case DataType::TIMESTAMP:
|
|
|
|
bConvert = (nValue & SQL_CVT_TIMESTAMP) == SQL_CVT_TIMESTAMP;
|
|
|
|
break;
|
|
|
|
case DataType::BINARY:
|
|
|
|
bConvert = (nValue & SQL_CVT_BINARY) == SQL_CVT_BINARY;
|
|
|
|
break;
|
|
|
|
case DataType::VARBINARY:
|
|
|
|
bConvert = (nValue & SQL_CVT_VARBINARY) == SQL_CVT_VARBINARY;
|
|
|
|
break;
|
|
|
|
case DataType::LONGVARBINARY:
|
|
|
|
bConvert = (nValue & SQL_CVT_LONGVARBINARY) == SQL_CVT_LONGVARBINARY;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return bConvert;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsExpressionsInOrderBy( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_EXPRESSIONS_IN_ORDERBY,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue.toChar() == 'Y';
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsGroupBy( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_GROUP_BY,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue != SQL_GB_NOT_SUPPORTED;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsGroupByBeyondSelect( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_GROUP_BY,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue != SQL_GB_GROUP_BY_CONTAINS_SELECT;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsGroupByUnrelated( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_GROUP_BY,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_GB_NO_RELATION;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsMultipleTransactions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MULTIPLE_ACTIVE_TXN,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue.toChar() == 'Y';
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsMultipleResultSets( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MULT_RESULT_SETS,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue.toChar() == 'Y';
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsLikeEscapeClause( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_LIKE_ESCAPE_CLAUSE,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue.toChar() == 'Y';
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsOrderByUnrelated( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_ORDER_BY_COLUMNS_IN_SELECT,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue.toChar() == 'N';
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsUnion( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_UNION,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_U_UNION) == SQL_U_UNION;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsUnionAll( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_UNION,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_U_UNION_ALL) == SQL_U_UNION_ALL;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsMixedCaseIdentifiers( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_IDENTIFIER_CASE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_IC_MIXED;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsMixedCaseQuotedIdentifiers( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_QUOTED_IDENTIFIER_CASE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_IC_MIXED;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::nullsAreSortedAtEnd( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_NULL_COLLATION,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_NC_END;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::nullsAreSortedAtStart( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_NULL_COLLATION,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_NC_START;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::nullsAreSortedHigh( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_NULL_COLLATION,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_NC_HIGH;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::nullsAreSortedLow( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_NULL_COLLATION,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_NC_LOW;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsSchemasInProcedureCalls( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SCHEMA_USAGE,nValue,*this);
|
2001-03-28 10:32:43 +00:00
|
|
|
return (nValue & SQL_SU_PROCEDURE_INVOCATION) == SQL_SU_PROCEDURE_INVOCATION;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsSchemasInPrivilegeDefinitions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SCHEMA_USAGE,nValue,*this);
|
2001-03-28 10:32:43 +00:00
|
|
|
return (nValue & SQL_SU_PRIVILEGE_DEFINITION) == SQL_SU_PRIVILEGE_DEFINITION;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsCatalogsInProcedureCalls( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue=0;
|
2001-04-20 12:31:58 +00:00
|
|
|
if(m_bUseCatalog)
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CATALOG_USAGE,nValue,*this);
|
2001-03-28 10:32:43 +00:00
|
|
|
return (nValue & SQL_CU_PROCEDURE_INVOCATION) == SQL_CU_PROCEDURE_INVOCATION;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsCatalogsInPrivilegeDefinitions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue=0;
|
2001-04-20 12:31:58 +00:00
|
|
|
if(m_bUseCatalog)
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CATALOG_USAGE,nValue,*this);
|
2001-03-28 10:32:43 +00:00
|
|
|
return (nValue & SQL_CU_PRIVILEGE_DEFINITION) == SQL_CU_PRIVILEGE_DEFINITION;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsCorrelatedSubqueries( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SUBQUERIES,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_SQ_CORRELATED_SUBQUERIES) == SQL_SQ_CORRELATED_SUBQUERIES;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsSubqueriesInComparisons( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SUBQUERIES,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_SQ_COMPARISON) == SQL_SQ_COMPARISON;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsSubqueriesInExists( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SUBQUERIES,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_SQ_EXISTS) == SQL_SQ_EXISTS;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsSubqueriesInIns( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SUBQUERIES,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_SQ_IN) == SQL_SQ_IN;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsSubqueriesInQuantifieds( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SUBQUERIES,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_SQ_QUANTIFIED) == SQL_SQ_QUANTIFIED;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsANSI92IntermediateSQL( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SQL_CONFORMANCE,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue == SQL_SC_SQL92_INTERMEDIATE;
|
|
|
|
}
|
2001-07-17 06:23:55 +00:00
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
::rtl::OUString ODatabaseMetaData::getURLImpl()
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_DATA_SOURCE_NAME,aValue,*this,m_pConnection->getTextEncoding());
|
|
|
|
return aValue;
|
|
|
|
}
|
2000-09-18 15:18:56 +00:00
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getURL( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2002-10-25 08:15:59 +00:00
|
|
|
::rtl::OUString aValue = m_pConnection->getURL();
|
|
|
|
if ( !aValue.getLength() )
|
|
|
|
{
|
|
|
|
aValue = ::rtl::OUString::createFromAscii("sdbc:odbc:");
|
|
|
|
aValue += getURLImpl();
|
|
|
|
}
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getUserName( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_USER_NAME,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getDriverName( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_DRIVER_NAME,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
2001-07-12 11:14:47 +00:00
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getDriverVersion() throw(SQLException, RuntimeException)
|
2000-09-18 15:18:56 +00:00
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_DRIVER_ODBC_VER,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getDatabaseProductVersion( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_DRIVER_VER,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getDatabaseProductName( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_DBMS_NAME,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getProcedureTerm( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_PROCEDURE_TERM,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getSchemaTerm( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SCHEMA_TERM,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getDriverMajorVersion( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_DRIVER_VER,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue.copy(0,aValue.indexOf('.')).toInt32();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getDefaultTransactionIsolation( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SUBQUERIES,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getDriverMinorVersion( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_DRIVER_VER,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue.copy(0,aValue.lastIndexOf('.')).toInt32();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getSQLKeywords( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_KEYWORDS,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getSearchStringEscape( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SEARCH_PATTERN_ESCAPE,aValue,*this,m_pConnection->getTextEncoding());
|
2000-09-18 15:18:56 +00:00
|
|
|
return aValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getStringFunctions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2000-09-18 15:18:56 +00:00
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_STRING_FUNCTIONS,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
if(nValue & SQL_FN_STR_ASCII)
|
|
|
|
aValue = ::rtl::OUString::createFromAscii("ASCII,");
|
|
|
|
if(nValue & SQL_FN_STR_BIT_LENGTH)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("BIT_LENGTH,");
|
|
|
|
if(nValue & SQL_FN_STR_CHAR)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("CHAR,");
|
|
|
|
if(nValue & SQL_FN_STR_CHAR_LENGTH)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("CHAR_LENGTH,");
|
|
|
|
if(nValue & SQL_FN_STR_CHARACTER_LENGTH)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("CHARACTER_LENGTH,");
|
|
|
|
if(nValue & SQL_FN_STR_CONCAT)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("CONCAT,");
|
|
|
|
if(nValue & SQL_FN_STR_DIFFERENCE)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("DIFFERENCE,");
|
|
|
|
if(nValue & SQL_FN_STR_INSERT)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("INSERT,");
|
|
|
|
if(nValue & SQL_FN_STR_LCASE)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("LCASE,");
|
|
|
|
if(nValue & SQL_FN_STR_LEFT)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("LEFT,");
|
|
|
|
if(nValue & SQL_FN_STR_LENGTH)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("LENGTH,");
|
|
|
|
if(nValue & SQL_FN_STR_LOCATE)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("LOCATE,");
|
|
|
|
if(nValue & SQL_FN_STR_LOCATE_2)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("LOCATE_2,");
|
|
|
|
if(nValue & SQL_FN_STR_LTRIM)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("LTRIM,");
|
|
|
|
if(nValue & SQL_FN_STR_OCTET_LENGTH)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("OCTET_LENGTH,");
|
|
|
|
if(nValue & SQL_FN_STR_POSITION)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("POSITION,");
|
|
|
|
if(nValue & SQL_FN_STR_REPEAT)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("REPEAT,");
|
|
|
|
if(nValue & SQL_FN_STR_REPLACE)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("REPLACE,");
|
|
|
|
if(nValue & SQL_FN_STR_RIGHT)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("RIGHT,");
|
|
|
|
if(nValue & SQL_FN_STR_RTRIM)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("RTRIM,");
|
|
|
|
if(nValue & SQL_FN_STR_SOUNDEX)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("SOUNDEX,");
|
|
|
|
if(nValue & SQL_FN_STR_SPACE)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("SPACE,");
|
|
|
|
if(nValue & SQL_FN_STR_SUBSTRING)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("SUBSTRING,");
|
|
|
|
if(nValue & SQL_FN_STR_UCASE)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("UCASE,");
|
|
|
|
|
|
|
|
|
|
|
|
return aValue.copy(0,aValue.lastIndexOf(','));
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getTimeDateFunctions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2000-09-18 15:18:56 +00:00
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_TIMEDATE_FUNCTIONS,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
if(nValue & SQL_FN_TD_CURRENT_DATE)
|
|
|
|
aValue = ::rtl::OUString::createFromAscii("CURRENT_DATE,");
|
|
|
|
if(nValue & SQL_FN_TD_CURRENT_TIME)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("CURRENT_TIME,");
|
|
|
|
if(nValue & SQL_FN_TD_CURRENT_TIMESTAMP)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("CURRENT_TIMESTAMP,");
|
|
|
|
if(nValue & SQL_FN_TD_CURDATE)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("CURDATE,");
|
|
|
|
if(nValue & SQL_FN_TD_CURTIME)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("CURTIME,");
|
|
|
|
if(nValue & SQL_FN_TD_DAYNAME)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("DAYNAME,");
|
|
|
|
if(nValue & SQL_FN_TD_DAYOFMONTH)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("DAYOFMONTH,");
|
|
|
|
if(nValue & SQL_FN_TD_DAYOFWEEK)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("DAYOFWEEK,");
|
|
|
|
if(nValue & SQL_FN_TD_DAYOFYEAR)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("DAYOFYEAR,");
|
|
|
|
if(nValue & SQL_FN_TD_EXTRACT)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("EXTRACT,");
|
|
|
|
if(nValue & SQL_FN_TD_HOUR)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("HOUR,");
|
|
|
|
if(nValue & SQL_FN_TD_MINUTE)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("MINUTE,");
|
|
|
|
if(nValue & SQL_FN_TD_MONTH)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("MONTH,");
|
|
|
|
if(nValue & SQL_FN_TD_MONTHNAME)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("MONTHNAME,");
|
|
|
|
if(nValue & SQL_FN_TD_NOW)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("NOW,");
|
|
|
|
if(nValue & SQL_FN_TD_QUARTER)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("QUARTER,");
|
|
|
|
if(nValue & SQL_FN_TD_SECOND)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("SECOND,");
|
|
|
|
if(nValue & SQL_FN_TD_TIMESTAMPADD)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("TIMESTAMPADD,");
|
|
|
|
if(nValue & SQL_FN_TD_TIMESTAMPDIFF)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("TIMESTAMPDIFF,");
|
|
|
|
if(nValue & SQL_FN_TD_WEEK)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("WEEK,");
|
|
|
|
if(nValue & SQL_FN_TD_YEAR)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("YEAR,");
|
|
|
|
|
|
|
|
return aValue.copy(0,aValue.lastIndexOf(','));
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getSystemFunctions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2000-09-18 15:18:56 +00:00
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_SYSTEM_FUNCTIONS,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
if(nValue & SQL_FN_SYS_DBNAME)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("DBNAME,");
|
|
|
|
if(nValue & SQL_FN_SYS_IFNULL)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("IFNULL,");
|
|
|
|
if(nValue & SQL_FN_SYS_USERNAME)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("USERNAME,");
|
|
|
|
|
|
|
|
return aValue.copy(0,aValue.lastIndexOf(','));
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODatabaseMetaData::getNumericFunctions( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2000-09-18 15:18:56 +00:00
|
|
|
::rtl::OUString aValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_NUMERIC_FUNCTIONS,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
if(nValue & SQL_FN_NUM_ABS)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("ABS,");
|
|
|
|
if(nValue & SQL_FN_NUM_ACOS)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("ACOS,");
|
|
|
|
if(nValue & SQL_FN_NUM_ASIN)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("ASIN,");
|
|
|
|
if(nValue & SQL_FN_NUM_ATAN)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("ATAN,");
|
|
|
|
if(nValue & SQL_FN_NUM_ATAN2)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("ATAN2,");
|
|
|
|
if(nValue & SQL_FN_NUM_CEILING)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("CEILING,");
|
|
|
|
if(nValue & SQL_FN_NUM_COS)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("COS,");
|
|
|
|
if(nValue & SQL_FN_NUM_COT)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("COT,");
|
|
|
|
if(nValue & SQL_FN_NUM_DEGREES)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("DEGREES,");
|
|
|
|
if(nValue & SQL_FN_NUM_EXP)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("EXP,");
|
|
|
|
if(nValue & SQL_FN_NUM_FLOOR)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("FLOOR,");
|
|
|
|
if(nValue & SQL_FN_NUM_LOG)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("LOGF,");
|
|
|
|
if(nValue & SQL_FN_NUM_LOG10)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("LOG10,");
|
|
|
|
if(nValue & SQL_FN_NUM_MOD)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("MOD,");
|
|
|
|
if(nValue & SQL_FN_NUM_PI)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("PI,");
|
|
|
|
if(nValue & SQL_FN_NUM_POWER)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("POWER,");
|
|
|
|
if(nValue & SQL_FN_NUM_RADIANS)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("RADIANS,");
|
|
|
|
if(nValue & SQL_FN_NUM_RAND)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("RAND,");
|
|
|
|
if(nValue & SQL_FN_NUM_ROUND)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("ROUND,");
|
|
|
|
if(nValue & SQL_FN_NUM_SIGN)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("SIGN,");
|
|
|
|
if(nValue & SQL_FN_NUM_SIN)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("SIN,");
|
|
|
|
if(nValue & SQL_FN_NUM_SQRT)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("SQRT,");
|
|
|
|
if(nValue & SQL_FN_NUM_TAN)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("TAN,");
|
|
|
|
if(nValue & SQL_FN_NUM_TRUNCATE)
|
|
|
|
aValue += ::rtl::OUString::createFromAscii("TRUNCATE,");
|
|
|
|
|
|
|
|
|
|
|
|
return aValue.copy(0,aValue.lastIndexOf(','));
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsExtendedSQLGrammar( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-07-12 11:14:47 +00:00
|
|
|
if(m_bOdbc3)
|
|
|
|
{
|
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_ODBC_INTERFACE_CONFORMANCE,nValue,*this);
|
|
|
|
return nValue == SQL_OIC_LEVEL2;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_ODBC_INTERFACE_CONFORMANCE,nValue,*this);
|
|
|
|
return nValue == SQL_OAC_LEVEL2;
|
|
|
|
}
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsCoreSQLGrammar( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-07-12 11:14:47 +00:00
|
|
|
if(m_bOdbc3)
|
|
|
|
{
|
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_ODBC_INTERFACE_CONFORMANCE,nValue,*this);
|
2001-11-06 09:58:45 +00:00
|
|
|
return nValue == SQL_OIC_CORE || nValue == SQL_OIC_LEVEL2 || nValue == SQL_OIC_LEVEL1;
|
2001-07-12 11:14:47 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_ODBC_SQL_CONFORMANCE,nValue,*this);
|
2001-11-06 09:11:08 +00:00
|
|
|
return nValue == SQL_OSC_CORE || nValue == SQL_OAC_LEVEL1 || nValue == SQL_OAC_LEVEL2;
|
2001-07-12 11:14:47 +00:00
|
|
|
}
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsMinimumSQLGrammar( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-07-12 11:14:47 +00:00
|
|
|
if(m_bOdbc3)
|
|
|
|
{
|
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_ODBC_INTERFACE_CONFORMANCE,nValue,*this);
|
2001-11-06 09:11:08 +00:00
|
|
|
return nValue == SQL_OIC_LEVEL1 || nValue == SQL_OIC_LEVEL2;
|
2001-07-12 11:14:47 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_ODBC_INTERFACE_CONFORMANCE,nValue,*this);
|
2001-11-06 09:11:08 +00:00
|
|
|
return nValue == SQL_OAC_LEVEL1 || nValue == SQL_OAC_LEVEL2;
|
2001-07-12 11:14:47 +00:00
|
|
|
}
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsFullOuterJoins( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_OJ_CAPABILITIES,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_OJ_FULL) == SQL_OJ_FULL;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsLimitedOuterJoins( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
return supportsFullOuterJoins( );
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxColumnsInGroupBy( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_COLUMNS_IN_GROUP_BY,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxColumnsInOrderBy( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_COLUMNS_IN_ORDER_BY,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxColumnsInSelect( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_COLUMNS_IN_SELECT,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ODatabaseMetaData::getMaxUserNameLength( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUSMALLINT nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_MAX_USER_NAME_LEN,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return nValue;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsResultSetType( sal_Int32 setType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,SQL_CURSOR_SENSITIVITY,nValue,*this);
|
2001-10-22 09:18:23 +00:00
|
|
|
return (nValue & static_cast<SQLUINTEGER>(setType)) == static_cast<SQLUINTEGER>(setType);
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsResultSetConcurrency( sal_Int32 setType, sal_Int32 concurrency ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2000-09-18 15:18:56 +00:00
|
|
|
SQLUSMALLINT nAskFor;
|
|
|
|
switch(setType)
|
|
|
|
{
|
|
|
|
case ResultSetType::FORWARD_ONLY:
|
|
|
|
nAskFor = SQL_FORWARD_ONLY_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
case ResultSetType::SCROLL_INSENSITIVE:
|
|
|
|
nAskFor = SQL_STATIC_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
case ResultSetType::SCROLL_SENSITIVE:
|
|
|
|
nAskFor = SQL_DYNAMIC_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,nAskFor,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
sal_Bool bRet = sal_False;
|
|
|
|
switch(concurrency)
|
|
|
|
{
|
|
|
|
case ResultSetConcurrency::READ_ONLY:
|
|
|
|
bRet = (nValue & SQL_CA2_READ_ONLY_CONCURRENCY) == SQL_CA2_READ_ONLY_CONCURRENCY;
|
|
|
|
break;
|
|
|
|
case ResultSetConcurrency::UPDATABLE:
|
|
|
|
bRet = (nValue & SQL_CA2_OPT_VALUES_CONCURRENCY) == SQL_CA2_OPT_VALUES_CONCURRENCY;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return bRet;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::ownUpdatesAreVisible( sal_Int32 setType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2000-09-18 15:18:56 +00:00
|
|
|
SQLUSMALLINT nAskFor;
|
|
|
|
switch(setType)
|
|
|
|
{
|
|
|
|
case ResultSetType::FORWARD_ONLY:
|
|
|
|
nAskFor = SQL_FORWARD_ONLY_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
case ResultSetType::SCROLL_INSENSITIVE:
|
|
|
|
nAskFor = SQL_STATIC_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
case ResultSetType::SCROLL_SENSITIVE:
|
|
|
|
nAskFor = SQL_DYNAMIC_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,nAskFor,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_CA2_SENSITIVITY_UPDATES) == SQL_CA2_SENSITIVITY_UPDATES;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::ownDeletesAreVisible( sal_Int32 setType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2000-09-18 15:18:56 +00:00
|
|
|
SQLUSMALLINT nAskFor;
|
|
|
|
switch(setType)
|
|
|
|
{
|
|
|
|
case ResultSetType::FORWARD_ONLY:
|
|
|
|
nAskFor = SQL_FORWARD_ONLY_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
case ResultSetType::SCROLL_INSENSITIVE:
|
|
|
|
nAskFor = SQL_STATIC_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
case ResultSetType::SCROLL_SENSITIVE:
|
|
|
|
nAskFor = SQL_DYNAMIC_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,nAskFor,nValue,*this);
|
2005-03-18 08:57:23 +00:00
|
|
|
return (nValue & SQL_CA2_SENSITIVITY_DELETIONS) != SQL_CA2_SENSITIVITY_DELETIONS;
|
2000-09-18 15:18:56 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::ownInsertsAreVisible( sal_Int32 setType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2001-09-18 10:22:34 +00:00
|
|
|
SQLUINTEGER nValue;
|
2000-09-18 15:18:56 +00:00
|
|
|
SQLUSMALLINT nAskFor;
|
|
|
|
switch(setType)
|
|
|
|
{
|
|
|
|
case ResultSetType::FORWARD_ONLY:
|
|
|
|
nAskFor = SQL_FORWARD_ONLY_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
case ResultSetType::SCROLL_INSENSITIVE:
|
|
|
|
nAskFor = SQL_STATIC_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
case ResultSetType::SCROLL_SENSITIVE:
|
|
|
|
nAskFor = SQL_DYNAMIC_CURSOR_ATTRIBUTES2;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2001-05-15 07:18:32 +00:00
|
|
|
OTools::GetInfo(m_pConnection,m_aConnectionHandle,nAskFor,nValue,*this);
|
2000-09-18 15:18:56 +00:00
|
|
|
return (nValue & SQL_CA2_SENSITIVITY_ADDITIONS) == SQL_CA2_SENSITIVITY_ADDITIONS;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::othersUpdatesAreVisible( sal_Int32 setType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
return ownUpdatesAreVisible(setType);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::othersDeletesAreVisible( sal_Int32 setType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
return ownDeletesAreVisible(setType);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::othersInsertsAreVisible( sal_Int32 setType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
return ownInsertsAreVisible(setType);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::updatesAreDetected( sal_Int32 setType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
return sal_False;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::deletesAreDetected( sal_Int32 setType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
return sal_False;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::insertsAreDetected( sal_Int32 setType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
return sal_False;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODatabaseMetaData::supportsBatchUpdates( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
return sal_False;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XResultSet > SAL_CALL ODatabaseMetaData::getUDTs( const Any& catalog, const ::rtl::OUString& schemaPattern, const ::rtl::OUString& typeNamePattern, const Sequence< sal_Int32 >& types ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XConnection > SAL_CALL ODatabaseMetaData::getConnection( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
return (Reference< XConnection >)m_pConnection;//new OConnection(m_aConnectionHandle);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|