2002-11-11 07:57:05 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 10:39:50 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2002-11-11 07:57:05 +00:00
|
|
|
*
|
2008-04-10 10:39:50 +00:00
|
|
|
* Copyright 2008 by Sun Microsystems, Inc.
|
2002-11-11 07:57:05 +00:00
|
|
|
*
|
2008-04-10 10:39:50 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2002-11-11 07:57:05 +00:00
|
|
|
*
|
2008-04-10 10:39:50 +00:00
|
|
|
* $RCSfile: YTables.hxx,v $
|
|
|
|
* $Revision: 1.5 $
|
2002-11-11 07:57:05 +00:00
|
|
|
*
|
2008-04-10 10:39:50 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2002-11-11 07:57:05 +00:00
|
|
|
*
|
2008-04-10 10:39:50 +00:00
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
2002-11-11 07:57:05 +00:00
|
|
|
*
|
2008-04-10 10:39:50 +00:00
|
|
|
* OpenOffice.org is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Lesser General Public License version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
2002-11-11 07:57:05 +00:00
|
|
|
*
|
2008-04-10 10:39:50 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2002-11-11 07:57:05 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
#ifndef CONNECTIVITY_MYSQL_TABLES_HXX
|
|
|
|
#define CONNECTIVITY_MYSQL_TABLES_HXX
|
|
|
|
|
|
|
|
#include "connectivity/sdbcx/VCollection.hxx"
|
|
|
|
#include <com/sun/star/sdbc/XDatabaseMetaData.hpp>
|
|
|
|
namespace connectivity
|
|
|
|
{
|
|
|
|
namespace mysql
|
|
|
|
{
|
|
|
|
class OTables : public sdbcx::OCollection
|
|
|
|
{
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XDatabaseMetaData > m_xMetaData;
|
|
|
|
|
|
|
|
protected:
|
2005-03-10 14:41:06 +00:00
|
|
|
virtual sdbcx::ObjectType createObject(const ::rtl::OUString& _rName);
|
2002-11-11 07:57:05 +00:00
|
|
|
virtual void impl_refresh() throw(::com::sun::star::uno::RuntimeException);
|
2006-07-10 13:37:27 +00:00
|
|
|
virtual ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet > createDescriptor();
|
|
|
|
virtual sdbcx::ObjectType appendObject( const ::rtl::OUString& _rForName, const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet >& descriptor );
|
2002-11-11 07:57:05 +00:00
|
|
|
virtual void dropObject(sal_Int32 _nPos,const ::rtl::OUString _sElementName);
|
|
|
|
|
|
|
|
void createTable( const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet >& descriptor );
|
2005-03-10 14:41:06 +00:00
|
|
|
virtual ::rtl::OUString getNameForObject(const sdbcx::ObjectType& _xObject);
|
2002-11-11 07:57:05 +00:00
|
|
|
public:
|
|
|
|
OTables(const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XDatabaseMetaData >& _rMetaData,::cppu::OWeakObject& _rParent, ::osl::Mutex& _rMutex,
|
|
|
|
const TStringVector &_rVector) : sdbcx::OCollection(_rParent,sal_True,_rMutex,_rVector)
|
|
|
|
,m_xMetaData(_rMetaData)
|
|
|
|
{}
|
|
|
|
|
|
|
|
// only the name is identical to ::cppu::OComponentHelper
|
|
|
|
virtual void SAL_CALL disposing(void);
|
|
|
|
|
|
|
|
// XDrop
|
|
|
|
void appendNew(const ::rtl::OUString& _rsNewTable);
|
|
|
|
// some helper functions
|
|
|
|
/**
|
|
|
|
returns a sql string which contains the column definition part for create or alter statements
|
|
|
|
*/
|
|
|
|
static ::rtl::OUString getColumnSqlType(const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet >& _rxColProp);
|
|
|
|
/**
|
|
|
|
returns the "not null" part or the default part of the table statement
|
|
|
|
*/
|
|
|
|
static ::rtl::OUString getColumnSqlNotNullDefault(const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet >& _rxColProp);
|
|
|
|
/**
|
|
|
|
returns the corresponding typename
|
|
|
|
can contain () which have to filled with values
|
|
|
|
*/
|
|
|
|
static ::rtl::OUString getTypeString(const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet >& _rxColProp);
|
2010-01-08 08:12:03 +01:00
|
|
|
|
|
|
|
/** convert the sql statement to fit MySQL notation
|
|
|
|
@param _sSql in/out
|
|
|
|
*/
|
|
|
|
static ::rtl::OUString adjustSQL(const ::rtl::OUString& _sSql);
|
2002-11-11 07:57:05 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif // CONNECTIVITY_MYSQL_TABLES_HXX
|
|
|
|
|