1*96de5490SAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*96de5490SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*96de5490SAndrew Rist * or more contributor license agreements. See the NOTICE file 5*96de5490SAndrew Rist * distributed with this work for additional information 6*96de5490SAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*96de5490SAndrew Rist * to you under the Apache License, Version 2.0 (the 8*96de5490SAndrew Rist * "License"); you may not use this file except in compliance 9*96de5490SAndrew Rist * with the License. You may obtain a copy of the License at 10cdf0e10cSrcweir * 11*96de5490SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12cdf0e10cSrcweir * 13*96de5490SAndrew Rist * Unless required by applicable law or agreed to in writing, 14*96de5490SAndrew Rist * software distributed under the License is distributed on an 15*96de5490SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*96de5490SAndrew Rist * KIND, either express or implied. See the License for the 17*96de5490SAndrew Rist * specific language governing permissions and limitations 18*96de5490SAndrew Rist * under the License. 19cdf0e10cSrcweir * 20*96de5490SAndrew Rist *************************************************************/ 21*96de5490SAndrew Rist 22*96de5490SAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 25cdf0e10cSrcweir #include "precompiled_dbaccess.hxx" 26cdf0e10cSrcweir 27cdf0e10cSrcweir #include "DExport.hxx" 28cdf0e10cSrcweir #include "moduledbu.hxx" 29cdf0e10cSrcweir 30cdf0e10cSrcweir #include <com/sun/star/sdbcx/XTablesSupplier.hpp> 31cdf0e10cSrcweir #include <com/sun/star/sdbcx/XDataDescriptorFactory.hpp> 32cdf0e10cSrcweir #include <com/sun/star/sdbcx/XColumnsSupplier.hpp> 33cdf0e10cSrcweir #include <com/sun/star/sdbcx/XAppend.hpp> 34cdf0e10cSrcweir #include <com/sun/star/sdbcx/KeyType.hpp> 35cdf0e10cSrcweir #include <com/sun/star/sdbc/DataType.hpp> 36cdf0e10cSrcweir #include <com/sun/star/sdbc/ColumnValue.hpp> 37cdf0e10cSrcweir #include <com/sun/star/sdb/CommandType.hpp> 38cdf0e10cSrcweir #include <com/sun/star/sdbc/XResultSetMetaDataSupplier.hpp> 39cdf0e10cSrcweir #include <com/sun/star/sdbc/XRow.hpp> 40cdf0e10cSrcweir #include <com/sun/star/util/NumberFormat.hpp> 41cdf0e10cSrcweir #include <com/sun/star/util/XNumberFormatTypes.hpp> 42cdf0e10cSrcweir #include "dbustrings.hrc" 43cdf0e10cSrcweir #include "dbu_misc.hrc" 44cdf0e10cSrcweir #include <connectivity/dbconversion.hxx> 45cdf0e10cSrcweir #include <sfx2/sfxhtml.hxx> 46cdf0e10cSrcweir #include <svl/numuno.hxx> 47cdf0e10cSrcweir #include <connectivity/dbtools.hxx> 48cdf0e10cSrcweir #include <comphelper/extract.hxx> 49cdf0e10cSrcweir #include "TypeInfo.hxx" 50cdf0e10cSrcweir #include "FieldDescriptions.hxx" 51cdf0e10cSrcweir #include "UITools.hxx" 52cdf0e10cSrcweir #include <unotools/configmgr.hxx> 53cdf0e10cSrcweir #include <memory> 54cdf0e10cSrcweir #include <tools/debug.hxx> 55cdf0e10cSrcweir #include <tools/diagnose_ex.h> 56cdf0e10cSrcweir #include <i18npool/mslangid.hxx> 57cdf0e10cSrcweir #include <com/sun/star/awt/FontDescriptor.hpp> 58cdf0e10cSrcweir #include "WCopyTable.hxx" 59cdf0e10cSrcweir #include "WExtendPages.hxx" 60cdf0e10cSrcweir #include "WCPage.hxx" 61cdf0e10cSrcweir #include <unotools/syslocale.hxx> 62cdf0e10cSrcweir #include <svl/zforlist.hxx> 63cdf0e10cSrcweir #include <connectivity/dbexception.hxx> 64cdf0e10cSrcweir #include <connectivity/FValue.hxx> 65cdf0e10cSrcweir #include <com/sun/star/sdbc/SQLWarning.hpp> 66cdf0e10cSrcweir #include <com/sun/star/sdb/SQLContext.hpp> 67cdf0e10cSrcweir #include <com/sun/star/sdb/application/CopyTableOperation.hpp> 68cdf0e10cSrcweir #include "sqlmessage.hxx" 69cdf0e10cSrcweir #include "UpdateHelperImpl.hxx" 70cdf0e10cSrcweir #include <vcl/msgbox.hxx> 71cdf0e10cSrcweir #include <cppuhelper/exc_hlp.hxx> 72cdf0e10cSrcweir #include <rtl/logfile.hxx> 73cdf0e10cSrcweir 74cdf0e10cSrcweir using namespace dbaui; 75cdf0e10cSrcweir using namespace utl; 76cdf0e10cSrcweir using namespace ::com::sun::star::uno; 77cdf0e10cSrcweir using namespace ::com::sun::star::beans; 78cdf0e10cSrcweir using namespace ::com::sun::star::container; 79cdf0e10cSrcweir using namespace ::com::sun::star::util; 80cdf0e10cSrcweir using namespace ::com::sun::star::sdbc; 81cdf0e10cSrcweir using namespace ::com::sun::star::sdbcx; 82cdf0e10cSrcweir using namespace ::com::sun::star::sdb; 83cdf0e10cSrcweir using namespace ::com::sun::star::lang; 84cdf0e10cSrcweir using namespace ::com::sun::star::awt; 85cdf0e10cSrcweir 86cdf0e10cSrcweir namespace CopyTableOperation = ::com::sun::star::sdb::application::CopyTableOperation; 87cdf0e10cSrcweir 88cdf0e10cSrcweir // ========================================================================== 89cdf0e10cSrcweir // ODatabaseExport 90cdf0e10cSrcweir // ========================================================================== 91cdf0e10cSrcweir DBG_NAME(ODatabaseExport) 92cdf0e10cSrcweir ODatabaseExport::ODatabaseExport(sal_Int32 nRows, 93cdf0e10cSrcweir const TPositions &_rColumnPositions, 94cdf0e10cSrcweir const Reference< XNumberFormatter >& _rxNumberF, 95cdf0e10cSrcweir const Reference< ::com::sun::star::lang::XMultiServiceFactory >& _rM, 96cdf0e10cSrcweir const TColumnVector* pList, 97cdf0e10cSrcweir const OTypeInfoMap* _pInfoMap, 98cdf0e10cSrcweir sal_Bool _bAutoIncrementEnabled, 99cdf0e10cSrcweir SvStream& _rInputStream) 100cdf0e10cSrcweir :m_vColumns(_rColumnPositions) 101cdf0e10cSrcweir ,m_aDestColumns(sal_True) 102cdf0e10cSrcweir ,m_xFormatter(_rxNumberF) 103cdf0e10cSrcweir ,m_xFactory(_rM) 104cdf0e10cSrcweir ,m_pFormatter(NULL) 105cdf0e10cSrcweir ,m_rInputStream( _rInputStream ) 106cdf0e10cSrcweir ,m_pTypeInfo() 107cdf0e10cSrcweir ,m_pColumnList(pList) 108cdf0e10cSrcweir ,m_pInfoMap(_pInfoMap) 109cdf0e10cSrcweir ,m_nColumnPos(0) 110cdf0e10cSrcweir ,m_nRows(1) 111cdf0e10cSrcweir ,m_nRowCount(0) 112cdf0e10cSrcweir ,m_nDefToken( gsl_getSystemTextEncoding() ) 113cdf0e10cSrcweir ,m_bError(sal_False) 114cdf0e10cSrcweir ,m_bInTbl(sal_False) 115cdf0e10cSrcweir ,m_bHead(sal_True) 116cdf0e10cSrcweir ,m_bDontAskAgain(sal_False) 117cdf0e10cSrcweir ,m_bIsAutoIncrement(_bAutoIncrementEnabled) 118cdf0e10cSrcweir ,m_bFoundTable(sal_False) 119cdf0e10cSrcweir ,m_bCheckOnly(sal_False) 120cdf0e10cSrcweir ,m_bAppendFirstLine(false) 121cdf0e10cSrcweir { 122cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::ODatabaseExport" ); 123cdf0e10cSrcweir DBG_CTOR(ODatabaseExport,NULL); 124cdf0e10cSrcweir 125cdf0e10cSrcweir m_nRows += nRows; 126cdf0e10cSrcweir sal_Int32 nCount = 0; 127cdf0e10cSrcweir for(sal_Int32 j=0;j < (sal_Int32)m_vColumns.size();++j) 128cdf0e10cSrcweir if ( m_vColumns[j].first != COLUMN_POSITION_NOT_FOUND ) 129cdf0e10cSrcweir ++nCount; 130cdf0e10cSrcweir 131cdf0e10cSrcweir m_vColumnSize.resize(nCount); 132cdf0e10cSrcweir m_vNumberFormat.resize(nCount); 133cdf0e10cSrcweir for(sal_Int32 i=0;i<nCount;++i) 134cdf0e10cSrcweir { 135cdf0e10cSrcweir m_vColumnSize[i] = 0; 136cdf0e10cSrcweir m_vNumberFormat[i] = 0; 137cdf0e10cSrcweir } 138cdf0e10cSrcweir 139cdf0e10cSrcweir try 140cdf0e10cSrcweir { 141cdf0e10cSrcweir SvtSysLocale aSysLocale; 142cdf0e10cSrcweir m_aLocale = aSysLocale.GetLocaleData().getLocale(); 143cdf0e10cSrcweir } 144cdf0e10cSrcweir catch(Exception&) 145cdf0e10cSrcweir { 146cdf0e10cSrcweir } 147cdf0e10cSrcweir 148cdf0e10cSrcweir SetColumnTypes(pList,_pInfoMap); 149cdf0e10cSrcweir } 150cdf0e10cSrcweir //--------------------------------------------------------------------------- 151cdf0e10cSrcweir ODatabaseExport::ODatabaseExport(const SharedConnection& _rxConnection, 152cdf0e10cSrcweir const Reference< XNumberFormatter >& _rxNumberF, 153cdf0e10cSrcweir const Reference< ::com::sun::star::lang::XMultiServiceFactory >& _rM, 154cdf0e10cSrcweir const TColumnVector* pList, 155cdf0e10cSrcweir const OTypeInfoMap* _pInfoMap, 156cdf0e10cSrcweir SvStream& _rInputStream) 157cdf0e10cSrcweir :m_aDestColumns(_rxConnection->getMetaData().is() && _rxConnection->getMetaData()->supportsMixedCaseQuotedIdentifiers() == sal_True) 158cdf0e10cSrcweir ,m_xConnection(_rxConnection) 159cdf0e10cSrcweir ,m_xFormatter(_rxNumberF) 160cdf0e10cSrcweir ,m_xFactory(_rM) 161cdf0e10cSrcweir ,m_pFormatter(NULL) 162cdf0e10cSrcweir ,m_rInputStream( _rInputStream ) 163cdf0e10cSrcweir ,m_pTypeInfo() 164cdf0e10cSrcweir ,m_pColumnList(NULL) 165cdf0e10cSrcweir ,m_pInfoMap(NULL) 166cdf0e10cSrcweir ,m_nColumnPos(0) 167cdf0e10cSrcweir ,m_nRows(1) 168cdf0e10cSrcweir ,m_nRowCount(0) 169cdf0e10cSrcweir ,m_nDefToken( gsl_getSystemTextEncoding() ) 170cdf0e10cSrcweir ,m_bError(sal_False) 171cdf0e10cSrcweir ,m_bInTbl(sal_False) 172cdf0e10cSrcweir ,m_bHead(sal_True) 173cdf0e10cSrcweir ,m_bDontAskAgain(sal_False) 174cdf0e10cSrcweir ,m_bIsAutoIncrement(sal_False) 175cdf0e10cSrcweir ,m_bFoundTable(sal_False) 176cdf0e10cSrcweir ,m_bCheckOnly(sal_False) 177cdf0e10cSrcweir ,m_bAppendFirstLine(false) 178cdf0e10cSrcweir { 179cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::ODatabaseExport" ); 180cdf0e10cSrcweir DBG_CTOR(ODatabaseExport,NULL); 181cdf0e10cSrcweir try 182cdf0e10cSrcweir { 183cdf0e10cSrcweir SvtSysLocale aSysLocale; 184cdf0e10cSrcweir m_aLocale = aSysLocale.GetLocaleData().getLocale(); 185cdf0e10cSrcweir } 186cdf0e10cSrcweir catch(Exception&) 187cdf0e10cSrcweir { 188cdf0e10cSrcweir } 189cdf0e10cSrcweir 190cdf0e10cSrcweir Reference<XTablesSupplier> xTablesSup(m_xConnection,UNO_QUERY); 191cdf0e10cSrcweir if(xTablesSup.is()) 192cdf0e10cSrcweir m_xTables = xTablesSup->getTables(); 193cdf0e10cSrcweir 194cdf0e10cSrcweir Reference<XDatabaseMetaData> xMeta = m_xConnection->getMetaData(); 195cdf0e10cSrcweir Reference<XResultSet> xSet = xMeta.is() ? xMeta->getTypeInfo() : Reference<XResultSet>(); 196cdf0e10cSrcweir if(xSet.is()) 197cdf0e10cSrcweir { 198cdf0e10cSrcweir ::connectivity::ORowSetValue aValue; 199cdf0e10cSrcweir ::std::vector<sal_Int32> aTypes; 200cdf0e10cSrcweir ::std::vector<sal_Bool> aNullable; 201cdf0e10cSrcweir Reference<XResultSetMetaData> xResultSetMetaData = Reference<XResultSetMetaDataSupplier>(xSet,UNO_QUERY_THROW)->getMetaData(); 202cdf0e10cSrcweir Reference<XRow> xRow(xSet,UNO_QUERY_THROW); 203cdf0e10cSrcweir while(xSet->next()) 204cdf0e10cSrcweir { 205cdf0e10cSrcweir if ( aTypes.empty() ) 206cdf0e10cSrcweir { 207cdf0e10cSrcweir sal_Int32 nCount = xResultSetMetaData->getColumnCount(); 208cdf0e10cSrcweir if ( nCount < 1 ) 209cdf0e10cSrcweir nCount = 18; 210cdf0e10cSrcweir aTypes.reserve(nCount+1); 211cdf0e10cSrcweir aNullable.reserve(nCount+1); 212cdf0e10cSrcweir aTypes.push_back(-1); 213cdf0e10cSrcweir aNullable.push_back(sal_False); 214cdf0e10cSrcweir for (sal_Int32 j = 1; j <= nCount ; ++j) 215cdf0e10cSrcweir { 216cdf0e10cSrcweir aNullable.push_back(xResultSetMetaData->isNullable(j) != ColumnValue::NO_NULLS ); 217cdf0e10cSrcweir aTypes.push_back(xResultSetMetaData->getColumnType(j)); 218cdf0e10cSrcweir } 219cdf0e10cSrcweir } 220cdf0e10cSrcweir 221cdf0e10cSrcweir sal_Int32 nPos = 1; 222cdf0e10cSrcweir OSL_ENSURE((nPos) < static_cast<sal_Int32>(aTypes.size()),"aTypes: Illegal index for vector"); 223cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 224cdf0e10cSrcweir ::rtl::OUString sTypeName = aValue; 225cdf0e10cSrcweir ++nPos; 226cdf0e10cSrcweir OSL_ENSURE((nPos) < static_cast<sal_Int32>(aTypes.size()),"aTypes: Illegal index for vector"); 227cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 228cdf0e10cSrcweir sal_Int32 nType = aValue; 229cdf0e10cSrcweir ++nPos; 230cdf0e10cSrcweir 231cdf0e10cSrcweir if( nType == DataType::VARCHAR ) 232cdf0e10cSrcweir { 233cdf0e10cSrcweir m_pTypeInfo = TOTypeInfoSP(new OTypeInfo()); 234cdf0e10cSrcweir 235cdf0e10cSrcweir m_pTypeInfo->aTypeName = sTypeName; 236cdf0e10cSrcweir m_pTypeInfo->nType = nType; 237cdf0e10cSrcweir 238cdf0e10cSrcweir OSL_ENSURE((nPos) < static_cast<sal_Int32>(aTypes.size()),"aTypes: Illegal index for vector"); 239cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 240cdf0e10cSrcweir m_pTypeInfo->nPrecision = aValue; 241cdf0e10cSrcweir ++nPos; 242cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 243cdf0e10cSrcweir m_pTypeInfo->aLiteralPrefix = aValue; 244cdf0e10cSrcweir ++nPos; 245cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 246cdf0e10cSrcweir m_pTypeInfo->aLiteralSuffix = aValue; 247cdf0e10cSrcweir ++nPos; 248cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 249cdf0e10cSrcweir m_pTypeInfo->aCreateParams = aValue; 250cdf0e10cSrcweir ++nPos; 251cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 252cdf0e10cSrcweir m_pTypeInfo->bNullable = (sal_Int32)aValue == ColumnValue::NULLABLE; 253cdf0e10cSrcweir ++nPos; 254cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 255cdf0e10cSrcweir m_pTypeInfo->bCaseSensitive = (sal_Bool)aValue; 256cdf0e10cSrcweir ++nPos; 257cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 258cdf0e10cSrcweir m_pTypeInfo->nSearchType = aValue; 259cdf0e10cSrcweir ++nPos; 260cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 261cdf0e10cSrcweir m_pTypeInfo->bUnsigned = (sal_Bool)aValue; 262cdf0e10cSrcweir ++nPos; 263cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 264cdf0e10cSrcweir m_pTypeInfo->bCurrency = (sal_Bool)aValue; 265cdf0e10cSrcweir ++nPos; 266cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 267cdf0e10cSrcweir m_pTypeInfo->bAutoIncrement = (sal_Bool)aValue; 268cdf0e10cSrcweir ++nPos; 269cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 270cdf0e10cSrcweir m_pTypeInfo->aLocalTypeName = aValue; 271cdf0e10cSrcweir ++nPos; 272cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 273cdf0e10cSrcweir m_pTypeInfo->nMinimumScale = aValue; 274cdf0e10cSrcweir ++nPos; 275cdf0e10cSrcweir aValue.fill(nPos,aTypes[nPos],aNullable[nPos],xRow); 276cdf0e10cSrcweir m_pTypeInfo->nMaximumScale = aValue; 277cdf0e10cSrcweir 278cdf0e10cSrcweir // check if values are less than zero like it happens in a oracle jdbc driver 279cdf0e10cSrcweir if( m_pTypeInfo->nPrecision < 0) 280cdf0e10cSrcweir m_pTypeInfo->nPrecision = 0; 281cdf0e10cSrcweir if( m_pTypeInfo->nMinimumScale < 0) 282cdf0e10cSrcweir m_pTypeInfo->nMinimumScale = 0; 283cdf0e10cSrcweir if( m_pTypeInfo->nMaximumScale < 0) 284cdf0e10cSrcweir m_pTypeInfo->nMaximumScale = 0; 285cdf0e10cSrcweir break; 286cdf0e10cSrcweir } 287cdf0e10cSrcweir } 288cdf0e10cSrcweir } // if(xSet.is()) 289cdf0e10cSrcweir if ( !m_pTypeInfo ) 290cdf0e10cSrcweir m_pTypeInfo = TOTypeInfoSP(new OTypeInfo()); 291cdf0e10cSrcweir SetColumnTypes(pList,_pInfoMap); 292cdf0e10cSrcweir } 293cdf0e10cSrcweir //--------------------------------------------------------------------------- 294cdf0e10cSrcweir ODatabaseExport::~ODatabaseExport() 295cdf0e10cSrcweir { 296cdf0e10cSrcweir DBG_DTOR(ODatabaseExport,NULL); 297cdf0e10cSrcweir m_pFormatter = NULL; 298cdf0e10cSrcweir ODatabaseExport::TColumns::iterator aIter = m_aDestColumns.begin(); 299cdf0e10cSrcweir ODatabaseExport::TColumns::iterator aEnd = m_aDestColumns.end(); 300cdf0e10cSrcweir 301cdf0e10cSrcweir for(;aIter != aEnd;++aIter) 302cdf0e10cSrcweir delete aIter->second; 303cdf0e10cSrcweir m_vDestVector.clear(); 304cdf0e10cSrcweir m_aDestColumns.clear(); 305cdf0e10cSrcweir } 306cdf0e10cSrcweir // ----------------------------------------------------------------------------- 307cdf0e10cSrcweir void ODatabaseExport::insertValueIntoColumn() 308cdf0e10cSrcweir { 309cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::insertValueIntoColumn" ); 310cdf0e10cSrcweir DBG_CHKTHIS(ODatabaseExport,NULL); 311cdf0e10cSrcweir if(m_nColumnPos < sal_Int32(m_vDestVector.size())) 312cdf0e10cSrcweir { 313cdf0e10cSrcweir OFieldDescription* pField = m_vDestVector[m_nColumnPos]->second; 314cdf0e10cSrcweir if(pField) 315cdf0e10cSrcweir { 316cdf0e10cSrcweir sal_Int32 nNewPos = m_bIsAutoIncrement ? m_nColumnPos+1 : m_nColumnPos; 317cdf0e10cSrcweir OSL_ENSURE((nNewPos) < static_cast<sal_Int32>(m_vColumns.size()),"m_vColumns: Illegal index for vector"); 318cdf0e10cSrcweir 319cdf0e10cSrcweir if ( (nNewPos) < static_cast<sal_Int32>(m_vColumns.size() ) ) 320cdf0e10cSrcweir { 321cdf0e10cSrcweir sal_Int32 nPos = m_vColumns[nNewPos].first; 322cdf0e10cSrcweir if ( nPos != COLUMN_POSITION_NOT_FOUND ) 323cdf0e10cSrcweir { 324cdf0e10cSrcweir // if(m_nDefToken != LANGUAGE_DONTKNOW) // falls Sprache anders als Systemsprache 325cdf0e10cSrcweir // m_pNF->ChangeIntl((LanguageType)m_nDefToken); 326cdf0e10cSrcweir 327cdf0e10cSrcweir if ( !m_sTextToken.Len() && pField->IsNullable() ) 328cdf0e10cSrcweir m_pUpdateHelper->updateNull(nPos,pField->GetType()); 329cdf0e10cSrcweir else 330cdf0e10cSrcweir { 331cdf0e10cSrcweir sal_Int32 nNumberFormat = 0; 332cdf0e10cSrcweir double fOutNumber = 0.0; 333cdf0e10cSrcweir OSL_ENSURE((nNewPos) < static_cast<sal_Int32>(m_vColumnTypes.size()),"Illegal index for vector"); 334cdf0e10cSrcweir if (m_vColumnTypes[nNewPos] != DataType::VARCHAR && m_vColumnTypes[nNewPos] != DataType::CHAR && m_vColumnTypes[nNewPos] != DataType::LONGVARCHAR ) 335cdf0e10cSrcweir { 336cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_TRACE( aLogger, "ODatabaseExport::insertValueIntoColumn != DataType::VARCHAR" ); 337cdf0e10cSrcweir ensureFormatter(); 338cdf0e10cSrcweir bool bNumberFormatError = false; 339cdf0e10cSrcweir if ( m_pFormatter && m_sNumToken.Len() ) 340cdf0e10cSrcweir { 341cdf0e10cSrcweir LanguageType eNumLang = LANGUAGE_NONE; 342cdf0e10cSrcweir sal_uInt32 nNumberFormat2( nNumberFormat ); 343cdf0e10cSrcweir fOutNumber = SfxHTMLParser::GetTableDataOptionsValNum(nNumberFormat2,eNumLang,m_sTextToken,m_sNumToken,*m_pFormatter); 344cdf0e10cSrcweir if ( eNumLang != LANGUAGE_NONE ) 345cdf0e10cSrcweir { 346cdf0e10cSrcweir nNumberFormat2 = m_pFormatter->GetFormatForLanguageIfBuiltIn( nNumberFormat2, eNumLang ); 347cdf0e10cSrcweir m_pFormatter->IsNumberFormat( m_sTextToken, nNumberFormat2, fOutNumber ); 348cdf0e10cSrcweir } 349cdf0e10cSrcweir nNumberFormat = static_cast<sal_Int32>(nNumberFormat2); 350cdf0e10cSrcweir } 351cdf0e10cSrcweir else 352cdf0e10cSrcweir { 353cdf0e10cSrcweir Reference< XNumberFormatsSupplier > xSupplier = m_xFormatter->getNumberFormatsSupplier(); 354cdf0e10cSrcweir Reference<XNumberFormatTypes> xNumType(xSupplier->getNumberFormats(),UNO_QUERY); 355cdf0e10cSrcweir sal_Int16 nFormats[] = { 356cdf0e10cSrcweir NumberFormat::DATETIME 357cdf0e10cSrcweir ,NumberFormat::DATE 358cdf0e10cSrcweir ,NumberFormat::TIME 359cdf0e10cSrcweir ,NumberFormat::CURRENCY 360cdf0e10cSrcweir ,NumberFormat::NUMBER 361cdf0e10cSrcweir ,NumberFormat::LOGICAL 362cdf0e10cSrcweir }; 363cdf0e10cSrcweir for (size_t i = 0; i < sizeof(nFormats)/sizeof(nFormats[0]); ++i) 364cdf0e10cSrcweir { 365cdf0e10cSrcweir try 366cdf0e10cSrcweir { 367cdf0e10cSrcweir nNumberFormat = m_xFormatter->detectNumberFormat(xNumType->getStandardFormat(nFormats[i],m_aLocale),m_sTextToken); 368cdf0e10cSrcweir break; 369cdf0e10cSrcweir } 370cdf0e10cSrcweir catch(Exception&) 371cdf0e10cSrcweir { 372cdf0e10cSrcweir } 373cdf0e10cSrcweir } 374cdf0e10cSrcweir try 375cdf0e10cSrcweir { 376cdf0e10cSrcweir fOutNumber = m_xFormatter->convertStringToNumber(nNumberFormat,m_sTextToken); 377cdf0e10cSrcweir } 378cdf0e10cSrcweir catch(Exception&) 379cdf0e10cSrcweir { 380cdf0e10cSrcweir bNumberFormatError = true; 381cdf0e10cSrcweir m_pUpdateHelper->updateString(nPos,m_sTextToken); 382cdf0e10cSrcweir } 383cdf0e10cSrcweir } 384cdf0e10cSrcweir if ( !bNumberFormatError ) 385cdf0e10cSrcweir { 386cdf0e10cSrcweir try 387cdf0e10cSrcweir { 388cdf0e10cSrcweir Reference< XNumberFormatsSupplier > xSupplier = m_xFormatter->getNumberFormatsSupplier(); 389cdf0e10cSrcweir Reference< XNumberFormats > xFormats = xSupplier->getNumberFormats(); 390cdf0e10cSrcweir Reference<XPropertySet> xProp = xFormats->getByKey(nNumberFormat); 391cdf0e10cSrcweir sal_Int16 nType = 0; 392cdf0e10cSrcweir xProp->getPropertyValue(PROPERTY_TYPE) >>= nType; 393cdf0e10cSrcweir switch(nType) 394cdf0e10cSrcweir { 395cdf0e10cSrcweir case NumberFormat::DATE: 396cdf0e10cSrcweir m_pUpdateHelper->updateDate(nPos,::dbtools::DBTypeConversion::toDate(fOutNumber,m_aNullDate)); 397cdf0e10cSrcweir break; 398cdf0e10cSrcweir case NumberFormat::DATETIME: 399cdf0e10cSrcweir m_pUpdateHelper->updateTimestamp(nPos,::dbtools::DBTypeConversion::toDateTime(fOutNumber,m_aNullDate)); 400cdf0e10cSrcweir break; 401cdf0e10cSrcweir case NumberFormat::TIME: 402cdf0e10cSrcweir m_pUpdateHelper->updateTime(nPos,::dbtools::DBTypeConversion::toTime(fOutNumber)); 403cdf0e10cSrcweir break; 404cdf0e10cSrcweir default: 405cdf0e10cSrcweir m_pUpdateHelper->updateDouble(nPos,fOutNumber); 406cdf0e10cSrcweir } 407cdf0e10cSrcweir } 408cdf0e10cSrcweir catch(Exception&) 409cdf0e10cSrcweir { 410cdf0e10cSrcweir m_pUpdateHelper->updateString(nPos,m_sTextToken); 411cdf0e10cSrcweir } 412cdf0e10cSrcweir } 413cdf0e10cSrcweir 414cdf0e10cSrcweir } 415cdf0e10cSrcweir else 416cdf0e10cSrcweir m_pUpdateHelper->updateString(nPos,m_sTextToken); 417cdf0e10cSrcweir } 418cdf0e10cSrcweir } 419cdf0e10cSrcweir } 420cdf0e10cSrcweir eraseTokens(); 421cdf0e10cSrcweir } 422cdf0e10cSrcweir } 423cdf0e10cSrcweir } 424cdf0e10cSrcweir // ----------------------------------------------------------------------------- 425cdf0e10cSrcweir sal_Int16 ODatabaseExport::CheckString(const String& aCheckToken, sal_Int16 _nOldNumberFormat) 426cdf0e10cSrcweir { 427cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::CheckString" ); 428cdf0e10cSrcweir DBG_CHKTHIS(ODatabaseExport,NULL); 429cdf0e10cSrcweir double fOutNumber = 0.0; 430cdf0e10cSrcweir sal_Int16 nNumberFormat = 0; 431cdf0e10cSrcweir 432cdf0e10cSrcweir try 433cdf0e10cSrcweir { 434cdf0e10cSrcweir Reference< XNumberFormatsSupplier > xSupplier = m_xFormatter->getNumberFormatsSupplier(); 435cdf0e10cSrcweir Reference< XNumberFormats > xFormats = xSupplier->getNumberFormats(); 436cdf0e10cSrcweir 437cdf0e10cSrcweir ensureFormatter(); 438cdf0e10cSrcweir if ( m_pFormatter && m_sNumToken.Len() ) 439cdf0e10cSrcweir { 440cdf0e10cSrcweir LanguageType eNumLang; 441cdf0e10cSrcweir sal_uInt32 nFormatKey(0); 442cdf0e10cSrcweir fOutNumber = SfxHTMLParser::GetTableDataOptionsValNum(nFormatKey,eNumLang,m_sTextToken,m_sNumToken,*m_pFormatter); 443cdf0e10cSrcweir if ( eNumLang != LANGUAGE_NONE ) 444cdf0e10cSrcweir { 445cdf0e10cSrcweir nFormatKey = m_pFormatter->GetFormatForLanguageIfBuiltIn( nFormatKey, eNumLang ); 446cdf0e10cSrcweir if ( !m_pFormatter->IsNumberFormat( m_sTextToken, nFormatKey, fOutNumber ) ) 447cdf0e10cSrcweir return NumberFormat::TEXT; 448cdf0e10cSrcweir } 449cdf0e10cSrcweir Reference<XPropertySet> xProp = xFormats->getByKey(nFormatKey); 450cdf0e10cSrcweir xProp->getPropertyValue(PROPERTY_TYPE) >>= nNumberFormat; 451cdf0e10cSrcweir } 452cdf0e10cSrcweir else 453cdf0e10cSrcweir { 454cdf0e10cSrcweir Reference<XNumberFormatTypes> xNumType(xFormats,UNO_QUERY); 455cdf0e10cSrcweir sal_Int32 nFormatKey = m_xFormatter->detectNumberFormat(xNumType->getStandardFormat(NumberFormat::ALL,m_aLocale),aCheckToken); 456cdf0e10cSrcweir fOutNumber = m_xFormatter->convertStringToNumber(nFormatKey,aCheckToken); 457cdf0e10cSrcweir 458cdf0e10cSrcweir Reference<XPropertySet> xProp = xFormats->getByKey(nFormatKey); 459cdf0e10cSrcweir sal_Int16 nType = 0; 460cdf0e10cSrcweir xProp->getPropertyValue(PROPERTY_TYPE) >>= nType; 461cdf0e10cSrcweir 462cdf0e10cSrcweir switch(nType) 463cdf0e10cSrcweir { 464cdf0e10cSrcweir case NumberFormat::ALL: 465cdf0e10cSrcweir nNumberFormat = NumberFormat::ALL; 466cdf0e10cSrcweir break; 467cdf0e10cSrcweir case NumberFormat::DEFINED: 468cdf0e10cSrcweir nNumberFormat = NumberFormat::TEXT; 469cdf0e10cSrcweir break; 470cdf0e10cSrcweir case NumberFormat::DATE: 471cdf0e10cSrcweir switch(_nOldNumberFormat) 472cdf0e10cSrcweir { 473cdf0e10cSrcweir case NumberFormat::DATETIME: 474cdf0e10cSrcweir case NumberFormat::TEXT: 475cdf0e10cSrcweir case NumberFormat::DATE: 476cdf0e10cSrcweir nNumberFormat = _nOldNumberFormat; 477cdf0e10cSrcweir break; 478cdf0e10cSrcweir case NumberFormat::ALL: 479cdf0e10cSrcweir nNumberFormat = NumberFormat::DATE; 480cdf0e10cSrcweir break; 481cdf0e10cSrcweir default: 482cdf0e10cSrcweir nNumberFormat = NumberFormat::TEXT; 483cdf0e10cSrcweir 484cdf0e10cSrcweir } 485cdf0e10cSrcweir break; 486cdf0e10cSrcweir case NumberFormat::TIME: 487cdf0e10cSrcweir switch(_nOldNumberFormat) 488cdf0e10cSrcweir { 489cdf0e10cSrcweir case NumberFormat::DATETIME: 490cdf0e10cSrcweir case NumberFormat::TEXT: 491cdf0e10cSrcweir case NumberFormat::TIME: 492cdf0e10cSrcweir nNumberFormat = _nOldNumberFormat; 493cdf0e10cSrcweir break; 494cdf0e10cSrcweir case NumberFormat::ALL: 495cdf0e10cSrcweir nNumberFormat = NumberFormat::TIME; 496cdf0e10cSrcweir break; 497cdf0e10cSrcweir default: 498cdf0e10cSrcweir nNumberFormat = NumberFormat::TEXT; 499cdf0e10cSrcweir break; 500cdf0e10cSrcweir } 501cdf0e10cSrcweir break; 502cdf0e10cSrcweir case NumberFormat::CURRENCY: 503cdf0e10cSrcweir switch(_nOldNumberFormat) 504cdf0e10cSrcweir { 505cdf0e10cSrcweir case NumberFormat::NUMBER: 506cdf0e10cSrcweir nNumberFormat = NumberFormat::CURRENCY; 507cdf0e10cSrcweir break; 508cdf0e10cSrcweir case NumberFormat::CURRENCY: 509cdf0e10cSrcweir nNumberFormat = _nOldNumberFormat; 510cdf0e10cSrcweir break; 511cdf0e10cSrcweir case NumberFormat::ALL: 512cdf0e10cSrcweir nNumberFormat = NumberFormat::CURRENCY; 513cdf0e10cSrcweir break; 514cdf0e10cSrcweir default: 515cdf0e10cSrcweir nNumberFormat = NumberFormat::TEXT; 516cdf0e10cSrcweir break; 517cdf0e10cSrcweir } 518cdf0e10cSrcweir break; 519cdf0e10cSrcweir case NumberFormat::NUMBER: 520cdf0e10cSrcweir case NumberFormat::SCIENTIFIC: 521cdf0e10cSrcweir case NumberFormat::FRACTION: 522cdf0e10cSrcweir case NumberFormat::PERCENT: 523cdf0e10cSrcweir switch(_nOldNumberFormat) 524cdf0e10cSrcweir { 525cdf0e10cSrcweir case NumberFormat::NUMBER: 526cdf0e10cSrcweir nNumberFormat = _nOldNumberFormat; 527cdf0e10cSrcweir break; 528cdf0e10cSrcweir case NumberFormat::CURRENCY: 529cdf0e10cSrcweir nNumberFormat = NumberFormat::CURRENCY; 530cdf0e10cSrcweir break; 531cdf0e10cSrcweir case NumberFormat::ALL: 532cdf0e10cSrcweir nNumberFormat = nType; 533cdf0e10cSrcweir break; 534cdf0e10cSrcweir default: 535cdf0e10cSrcweir nNumberFormat = NumberFormat::TEXT; 536cdf0e10cSrcweir break; 537cdf0e10cSrcweir } 538cdf0e10cSrcweir break; 539cdf0e10cSrcweir case NumberFormat::TEXT: 540cdf0e10cSrcweir case NumberFormat::UNDEFINED: 541cdf0e10cSrcweir case NumberFormat::LOGICAL: 542cdf0e10cSrcweir nNumberFormat = NumberFormat::TEXT; // Text "uberschreibt alles 543cdf0e10cSrcweir break; 544cdf0e10cSrcweir case NumberFormat::DATETIME: 545cdf0e10cSrcweir switch(_nOldNumberFormat) 546cdf0e10cSrcweir { 547cdf0e10cSrcweir case NumberFormat::DATETIME: 548cdf0e10cSrcweir case NumberFormat::TEXT: 549cdf0e10cSrcweir case NumberFormat::TIME: 550cdf0e10cSrcweir nNumberFormat = _nOldNumberFormat; 551cdf0e10cSrcweir break; 552cdf0e10cSrcweir case NumberFormat::ALL: 553cdf0e10cSrcweir nNumberFormat = NumberFormat::DATETIME; 554cdf0e10cSrcweir break; 555cdf0e10cSrcweir default: 556cdf0e10cSrcweir nNumberFormat = NumberFormat::TEXT; 557cdf0e10cSrcweir break; 558cdf0e10cSrcweir } 559cdf0e10cSrcweir break; 560cdf0e10cSrcweir default: 561cdf0e10cSrcweir OSL_ENSURE(0,"ODatabaseExport: Unbekanntes Format"); 562cdf0e10cSrcweir } 563cdf0e10cSrcweir } 564cdf0e10cSrcweir } 565cdf0e10cSrcweir catch(Exception&) 566cdf0e10cSrcweir { 567cdf0e10cSrcweir nNumberFormat = NumberFormat::TEXT; // Text "uberschreibt alles 568cdf0e10cSrcweir } 569cdf0e10cSrcweir 570cdf0e10cSrcweir return nNumberFormat; 571cdf0e10cSrcweir } 572cdf0e10cSrcweir // ----------------------------------------------------------------------------- 573cdf0e10cSrcweir void ODatabaseExport::SetColumnTypes(const TColumnVector* _pList,const OTypeInfoMap* _pInfoMap) 574cdf0e10cSrcweir { 575cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::SetColumnTypes" ); 576cdf0e10cSrcweir DBG_CHKTHIS(ODatabaseExport,NULL); 577cdf0e10cSrcweir if(_pList && _pInfoMap) 578cdf0e10cSrcweir { 579cdf0e10cSrcweir OSL_ENSURE(m_vNumberFormat.size() == m_vColumnSize.size() && m_vColumnSize.size() == _pList->size(),"Illegal columns in list"); 580cdf0e10cSrcweir Reference< XNumberFormatsSupplier > xSupplier = m_xFormatter->getNumberFormatsSupplier(); 581cdf0e10cSrcweir Reference< XNumberFormats > xFormats = xSupplier->getNumberFormats(); 582cdf0e10cSrcweir TColumnVector::const_iterator aIter = _pList->begin(); 583cdf0e10cSrcweir TColumnVector::const_iterator aEnd = _pList->end(); 584cdf0e10cSrcweir for(sal_Int32 i= 0;aIter != aEnd && (i) < static_cast<sal_Int32>(m_vNumberFormat.size()) && (i) < static_cast<sal_Int32>(m_vColumnSize.size()) ;++aIter,++i) 585cdf0e10cSrcweir { 586cdf0e10cSrcweir sal_Int32 nDataType; 587cdf0e10cSrcweir sal_Int32 nLength(0),nScale(0); 588cdf0e10cSrcweir sal_Int16 nType = m_vNumberFormat[i] & ~NumberFormat::DEFINED; 589cdf0e10cSrcweir 590cdf0e10cSrcweir switch ( nType ) 591cdf0e10cSrcweir { 592cdf0e10cSrcweir case NumberFormat::ALL: 593cdf0e10cSrcweir nDataType = DataType::DOUBLE; 594cdf0e10cSrcweir break; 595cdf0e10cSrcweir case NumberFormat::DEFINED: 596cdf0e10cSrcweir nDataType = DataType::VARCHAR; 597cdf0e10cSrcweir nLength = ((m_vColumnSize[i] % 10 ) ? m_vColumnSize[i]/ 10 + 1: m_vColumnSize[i]/ 10) * 10; 598cdf0e10cSrcweir break; 599cdf0e10cSrcweir case NumberFormat::DATE: 600cdf0e10cSrcweir nDataType = DataType::DATE; 601cdf0e10cSrcweir break; 602cdf0e10cSrcweir case NumberFormat::TIME: 603cdf0e10cSrcweir nDataType = DataType::TIME; 604cdf0e10cSrcweir break; 605cdf0e10cSrcweir case NumberFormat::DATETIME: 606cdf0e10cSrcweir nDataType = DataType::TIMESTAMP; 607cdf0e10cSrcweir break; 608cdf0e10cSrcweir case NumberFormat::CURRENCY: 609cdf0e10cSrcweir nDataType = DataType::NUMERIC; 610cdf0e10cSrcweir nScale = 4; 611cdf0e10cSrcweir nLength = 19; 612cdf0e10cSrcweir break; 613cdf0e10cSrcweir case NumberFormat::NUMBER: 614cdf0e10cSrcweir case NumberFormat::SCIENTIFIC: 615cdf0e10cSrcweir case NumberFormat::FRACTION: 616cdf0e10cSrcweir case NumberFormat::PERCENT: 617cdf0e10cSrcweir nDataType = DataType::DOUBLE; 618cdf0e10cSrcweir break; 619cdf0e10cSrcweir case NumberFormat::TEXT: 620cdf0e10cSrcweir case NumberFormat::UNDEFINED: 621cdf0e10cSrcweir case NumberFormat::LOGICAL: 622cdf0e10cSrcweir default: 623cdf0e10cSrcweir nDataType = DataType::VARCHAR; 624cdf0e10cSrcweir nLength = ((m_vColumnSize[i] % 10 ) ? m_vColumnSize[i]/ 10 + 1: m_vColumnSize[i]/ 10) * 10; 625cdf0e10cSrcweir break; 626cdf0e10cSrcweir } 627cdf0e10cSrcweir OTypeInfoMap::const_iterator aFind = _pInfoMap->find(nDataType); 628cdf0e10cSrcweir if(aFind != _pInfoMap->end()) 629cdf0e10cSrcweir { 630cdf0e10cSrcweir (*aIter)->second->SetType(aFind->second); 631cdf0e10cSrcweir (*aIter)->second->SetPrecision(::std::min<sal_Int32>(aFind->second->nPrecision,nLength)); 632cdf0e10cSrcweir (*aIter)->second->SetScale(::std::min<sal_Int32>(aFind->second->nMaximumScale,nScale)); 633cdf0e10cSrcweir 634cdf0e10cSrcweir sal_Int32 nFormatKey = ::dbtools::getDefaultNumberFormat( nDataType, 635cdf0e10cSrcweir (*aIter)->second->GetScale(), 636cdf0e10cSrcweir (*aIter)->second->IsCurrency(), 637cdf0e10cSrcweir Reference< XNumberFormatTypes>(xFormats,UNO_QUERY), 638cdf0e10cSrcweir m_aLocale); 639cdf0e10cSrcweir 640cdf0e10cSrcweir (*aIter)->second->SetFormatKey(nFormatKey); 641cdf0e10cSrcweir } 642cdf0e10cSrcweir } 643cdf0e10cSrcweir } 644cdf0e10cSrcweir } 645cdf0e10cSrcweir // ----------------------------------------------------------------------------- 646cdf0e10cSrcweir void ODatabaseExport::CreateDefaultColumn(const ::rtl::OUString& _rColumnName) 647cdf0e10cSrcweir { 648cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::CreateDefaultColumn" ); 649cdf0e10cSrcweir DBG_CHKTHIS(ODatabaseExport,NULL); 650cdf0e10cSrcweir Reference< XDatabaseMetaData> xDestMetaData(m_xConnection->getMetaData()); 651cdf0e10cSrcweir sal_Int32 nMaxNameLen(xDestMetaData->getMaxColumnNameLength()); 652cdf0e10cSrcweir ::rtl::OUString aAlias = _rColumnName; 653cdf0e10cSrcweir if ( isSQL92CheckEnabled(m_xConnection) ) 654cdf0e10cSrcweir aAlias = ::dbtools::convertName2SQLName(_rColumnName,xDestMetaData->getExtraNameCharacters()); 655cdf0e10cSrcweir 656cdf0e10cSrcweir if(nMaxNameLen && aAlias.getLength() > nMaxNameLen) 657cdf0e10cSrcweir aAlias = aAlias.copy(0, ::std::min<sal_Int32>( nMaxNameLen-1, aAlias.getLength() ) ); 658cdf0e10cSrcweir 659cdf0e10cSrcweir ::rtl::OUString sName(aAlias); 660cdf0e10cSrcweir if(m_aDestColumns.find(sName) != m_aDestColumns.end()) 661cdf0e10cSrcweir { 662cdf0e10cSrcweir sal_Int32 nPos = 0; 663cdf0e10cSrcweir sal_Int32 nCount = 2; 664cdf0e10cSrcweir while(m_aDestColumns.find(sName) != m_aDestColumns.end()) 665cdf0e10cSrcweir { 666cdf0e10cSrcweir sName = aAlias; 667cdf0e10cSrcweir sName += ::rtl::OUString::valueOf(++nPos); 668cdf0e10cSrcweir if(nMaxNameLen && sName.getLength() > nMaxNameLen) 669cdf0e10cSrcweir { 670cdf0e10cSrcweir aAlias = aAlias.copy(0,::std::min<sal_Int32>( nMaxNameLen-nCount, aAlias.getLength() )); 671cdf0e10cSrcweir sName = aAlias; 672cdf0e10cSrcweir sName += ::rtl::OUString::valueOf(nPos); 673cdf0e10cSrcweir ++nCount; 674cdf0e10cSrcweir } 675cdf0e10cSrcweir } 676cdf0e10cSrcweir } 677cdf0e10cSrcweir aAlias = sName; 678cdf0e10cSrcweir // now create a column 679cdf0e10cSrcweir OFieldDescription* pField = new OFieldDescription(); 680cdf0e10cSrcweir pField->SetType(m_pTypeInfo); 681cdf0e10cSrcweir pField->SetName(aAlias); 682cdf0e10cSrcweir pField->SetPrecision(::std::min<sal_Int32>((sal_Int32)255,m_pTypeInfo->nPrecision)); 683cdf0e10cSrcweir pField->SetScale(0); 684cdf0e10cSrcweir pField->SetIsNullable(ColumnValue::NULLABLE); 685cdf0e10cSrcweir pField->SetAutoIncrement(sal_False); 686cdf0e10cSrcweir pField->SetPrimaryKey(sal_False); 687cdf0e10cSrcweir pField->SetCurrency(sal_False); 688cdf0e10cSrcweir 689cdf0e10cSrcweir TColumns::iterator aFind = m_aDestColumns.find( aAlias ); 690cdf0e10cSrcweir if ( aFind != m_aDestColumns.end() ) 691cdf0e10cSrcweir { 692cdf0e10cSrcweir delete aFind->second; 693cdf0e10cSrcweir m_aDestColumns.erase(aFind); 694cdf0e10cSrcweir } 695cdf0e10cSrcweir 696cdf0e10cSrcweir m_vDestVector.push_back(m_aDestColumns.insert(TColumns::value_type(aAlias,pField)).first); 697cdf0e10cSrcweir } 698cdf0e10cSrcweir // ----------------------------------------------------------------------------- 699cdf0e10cSrcweir sal_Bool ODatabaseExport::createRowSet() 700cdf0e10cSrcweir { 701cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::createRowSet" ); 702cdf0e10cSrcweir DBG_CHKTHIS(ODatabaseExport,NULL); 703cdf0e10cSrcweir m_pUpdateHelper.reset(new OParameterUpdateHelper(createPreparedStatment(m_xConnection->getMetaData(),m_xTable,m_vColumns))); 704cdf0e10cSrcweir 705cdf0e10cSrcweir return m_pUpdateHelper.get() != NULL; 706cdf0e10cSrcweir } 707cdf0e10cSrcweir // ----------------------------------------------------------------------------- 708cdf0e10cSrcweir sal_Bool ODatabaseExport::executeWizard(const ::rtl::OUString& _rTableName,const Any& _aTextColor,const FontDescriptor& _rFont) 709cdf0e10cSrcweir { 710cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::executeWizard" ); 711cdf0e10cSrcweir DBG_CHKTHIS(ODatabaseExport,NULL); 712cdf0e10cSrcweir 713cdf0e10cSrcweir bool bHaveDefaultTable = ( m_sDefaultTableName.getLength() != 0 ); 714cdf0e10cSrcweir ::rtl::OUString sTableName( bHaveDefaultTable ? m_sDefaultTableName : _rTableName ); 715cdf0e10cSrcweir OCopyTableWizard aWizard( 716cdf0e10cSrcweir NULL, 717cdf0e10cSrcweir sTableName, 718cdf0e10cSrcweir bHaveDefaultTable ? CopyTableOperation::AppendData : CopyTableOperation::CopyDefinitionAndData, 719cdf0e10cSrcweir m_aDestColumns, 720cdf0e10cSrcweir m_vDestVector, 721cdf0e10cSrcweir m_xConnection, 722cdf0e10cSrcweir m_xFormatter, 723cdf0e10cSrcweir getTypeSelectionPageFactory(), 724cdf0e10cSrcweir m_rInputStream, 725cdf0e10cSrcweir m_xFactory 726cdf0e10cSrcweir ); 727cdf0e10cSrcweir 728cdf0e10cSrcweir sal_Bool bError = sal_False; 729cdf0e10cSrcweir try 730cdf0e10cSrcweir { 731cdf0e10cSrcweir if (aWizard.Execute()) 732cdf0e10cSrcweir { 733cdf0e10cSrcweir switch(aWizard.getOperation()) 734cdf0e10cSrcweir { 735cdf0e10cSrcweir case CopyTableOperation::CopyDefinitionAndData: 736cdf0e10cSrcweir case CopyTableOperation::AppendData: 737cdf0e10cSrcweir { 738cdf0e10cSrcweir m_xTable = aWizard.createTable(); 739cdf0e10cSrcweir bError = !m_xTable.is(); 740cdf0e10cSrcweir if(m_xTable.is()) 741cdf0e10cSrcweir { 742cdf0e10cSrcweir m_xTable->setPropertyValue(PROPERTY_FONT,makeAny(_rFont)); 743cdf0e10cSrcweir if(_aTextColor.hasValue()) 744cdf0e10cSrcweir m_xTable->setPropertyValue(PROPERTY_TEXTCOLOR,_aTextColor); 745cdf0e10cSrcweir } 746cdf0e10cSrcweir m_bIsAutoIncrement = aWizard.shouldCreatePrimaryKey(); 747cdf0e10cSrcweir m_vColumns = aWizard.GetColumnPositions(); 748cdf0e10cSrcweir m_vColumnTypes = aWizard.GetColumnTypes(); 749cdf0e10cSrcweir m_bAppendFirstLine = !aWizard.UseHeaderLine(); 750cdf0e10cSrcweir } 751cdf0e10cSrcweir break; 752cdf0e10cSrcweir default: 753cdf0e10cSrcweir bError = sal_True; // there is no error but I have nothing more to do 754cdf0e10cSrcweir } 755cdf0e10cSrcweir } 756cdf0e10cSrcweir else 757cdf0e10cSrcweir bError = sal_True; 758cdf0e10cSrcweir 759cdf0e10cSrcweir if(!bError) 760cdf0e10cSrcweir bError = !createRowSet(); 761cdf0e10cSrcweir } 762cdf0e10cSrcweir catch( const SQLException&) 763cdf0e10cSrcweir { 764cdf0e10cSrcweir ::dbaui::showError( ::dbtools::SQLExceptionInfo( ::cppu::getCaughtException() ), &aWizard, m_xFactory ); 765cdf0e10cSrcweir bError = sal_True; 766cdf0e10cSrcweir } 767cdf0e10cSrcweir catch( const Exception& ) 768cdf0e10cSrcweir { 769cdf0e10cSrcweir DBG_UNHANDLED_EXCEPTION(); 770cdf0e10cSrcweir } 771cdf0e10cSrcweir 772cdf0e10cSrcweir return bError; 773cdf0e10cSrcweir } 774cdf0e10cSrcweir //--------------------------------------------------------------------------------- 775cdf0e10cSrcweir void ODatabaseExport::showErrorDialog(const ::com::sun::star::sdbc::SQLException& e) 776cdf0e10cSrcweir { 777cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::showErrorDialog" ); 778cdf0e10cSrcweir if(!m_bDontAskAgain) 779cdf0e10cSrcweir { 780cdf0e10cSrcweir String aMsg(e.Message); 781cdf0e10cSrcweir aMsg += '\n'; 782cdf0e10cSrcweir aMsg += String( ModuleRes( STR_QRY_CONTINUE ) ); 783cdf0e10cSrcweir OSQLWarningBox aBox( NULL, aMsg, WB_YES_NO | WB_DEF_NO ); 784cdf0e10cSrcweir 785cdf0e10cSrcweir if (aBox.Execute() == RET_YES) 786cdf0e10cSrcweir m_bDontAskAgain = sal_True; 787cdf0e10cSrcweir else 788cdf0e10cSrcweir m_bError = sal_True; 789cdf0e10cSrcweir } // if(!m_bDontAskAgain) 790cdf0e10cSrcweir } 791cdf0e10cSrcweir // ----------------------------------------------------------------------------- 792cdf0e10cSrcweir void ODatabaseExport::adjustFormat() 793cdf0e10cSrcweir { 794cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::adjustFormat" ); 795cdf0e10cSrcweir if ( m_sTextToken.Len() ) 796cdf0e10cSrcweir { 797cdf0e10cSrcweir sal_Int32 nNewPos = m_bIsAutoIncrement ? m_nColumnPos+1 : m_nColumnPos; 798cdf0e10cSrcweir OSL_ENSURE((nNewPos) < static_cast<sal_Int32>(m_vColumns.size()),"Illegal index for vector"); 799cdf0e10cSrcweir if ( (nNewPos) < static_cast<sal_Int32>(m_vColumns.size()) ) 800cdf0e10cSrcweir { 801cdf0e10cSrcweir sal_Int32 nColPos = m_vColumns[nNewPos].first; 802cdf0e10cSrcweir if( nColPos != sal::static_int_cast< long >(CONTAINER_ENTRY_NOTFOUND)) 803cdf0e10cSrcweir { 804cdf0e10cSrcweir --nColPos; 805cdf0e10cSrcweir OSL_ENSURE((nColPos) < static_cast<sal_Int32>(m_vNumberFormat.size()),"m_vFormatKey: Illegal index for vector"); 806cdf0e10cSrcweir OSL_ENSURE((nColPos) < static_cast<sal_Int32>(m_vColumnSize.size()),"m_vColumnSize: Illegal index for vector"); 807cdf0e10cSrcweir m_vNumberFormat[nColPos] = CheckString(m_sTextToken,m_vNumberFormat[nColPos]); 808cdf0e10cSrcweir m_vColumnSize[nColPos] = ::std::max<sal_Int32>((sal_Int32)m_vColumnSize[nColPos],(sal_Int32)m_sTextToken.Len()); 809cdf0e10cSrcweir } 810cdf0e10cSrcweir } 811cdf0e10cSrcweir eraseTokens(); 812cdf0e10cSrcweir } 813cdf0e10cSrcweir } 814cdf0e10cSrcweir // ----------------------------------------------------------------------------- 815cdf0e10cSrcweir void ODatabaseExport::eraseTokens() 816cdf0e10cSrcweir { 817cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::eraseTokens" ); 818cdf0e10cSrcweir m_sTextToken.Erase(); 819cdf0e10cSrcweir m_sNumToken.Erase(); 820cdf0e10cSrcweir m_sValToken.Erase(); 821cdf0e10cSrcweir } 822cdf0e10cSrcweir // ----------------------------------------------------------------------------- 823cdf0e10cSrcweir void ODatabaseExport::ensureFormatter() 824cdf0e10cSrcweir { 825cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::ensureFormatter" ); 826cdf0e10cSrcweir if ( !m_pFormatter ) 827cdf0e10cSrcweir { 828cdf0e10cSrcweir Reference< XNumberFormatsSupplier > xSupplier = m_xFormatter->getNumberFormatsSupplier(); 829cdf0e10cSrcweir Reference< XUnoTunnel > xTunnel(xSupplier,UNO_QUERY); 830cdf0e10cSrcweir SvNumberFormatsSupplierObj* pSupplierImpl = (SvNumberFormatsSupplierObj*)sal::static_int_cast< sal_IntPtr >(xTunnel->getSomething(SvNumberFormatsSupplierObj::getUnoTunnelId())); 831cdf0e10cSrcweir m_pFormatter = pSupplierImpl ? pSupplierImpl->GetNumberFormatter() : NULL; 832cdf0e10cSrcweir Reference<XPropertySet> xNumberFormatSettings = xSupplier->getNumberFormatSettings(); 833cdf0e10cSrcweir xNumberFormatSettings->getPropertyValue(::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("NullDate"))) >>= m_aNullDate; 834cdf0e10cSrcweir } 835cdf0e10cSrcweir } 836cdf0e10cSrcweir // ----------------------------------------------------------------------------- 837cdf0e10cSrcweir Reference< XPreparedStatement > ODatabaseExport::createPreparedStatment( const Reference<XDatabaseMetaData>& _xMetaData 838cdf0e10cSrcweir ,const Reference<XPropertySet>& _xDestTable 839cdf0e10cSrcweir ,const TPositions& _rvColumns) 840cdf0e10cSrcweir { 841cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "misc", "Ocke.Janssen@sun.com", "ODatabaseExport::createPreparedStatment" ); 842cdf0e10cSrcweir ::rtl::OUString aSql(::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("INSERT INTO "))); 843cdf0e10cSrcweir ::rtl::OUString sComposedTableName = ::dbtools::composeTableName( _xMetaData, _xDestTable, ::dbtools::eInDataManipulation, false, false, true ); 844cdf0e10cSrcweir 845cdf0e10cSrcweir aSql += sComposedTableName; 846cdf0e10cSrcweir aSql += ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(" ( ")); 847cdf0e10cSrcweir // set values and column names 848cdf0e10cSrcweir ::rtl::OUString aValues(RTL_CONSTASCII_USTRINGPARAM(" VALUES ( ")); 849cdf0e10cSrcweir static ::rtl::OUString aPara(RTL_CONSTASCII_USTRINGPARAM("?,")); 850cdf0e10cSrcweir static ::rtl::OUString aComma(RTL_CONSTASCII_USTRINGPARAM(",")); 851cdf0e10cSrcweir 852cdf0e10cSrcweir ::rtl::OUString aQuote; 853cdf0e10cSrcweir if ( _xMetaData.is() ) 854cdf0e10cSrcweir aQuote = _xMetaData->getIdentifierQuoteString(); 855cdf0e10cSrcweir 856cdf0e10cSrcweir Reference<XColumnsSupplier> xDestColsSup(_xDestTable,UNO_QUERY_THROW); 857cdf0e10cSrcweir 858cdf0e10cSrcweir // create sql string and set column types 859cdf0e10cSrcweir Sequence< ::rtl::OUString> aDestColumnNames = xDestColsSup->getColumns()->getElementNames(); 860cdf0e10cSrcweir if ( aDestColumnNames.getLength() == 0 ) 861cdf0e10cSrcweir { 862cdf0e10cSrcweir return Reference< XPreparedStatement > (); 863cdf0e10cSrcweir } 864cdf0e10cSrcweir const ::rtl::OUString* pIter = aDestColumnNames.getConstArray(); 865cdf0e10cSrcweir ::std::vector< ::rtl::OUString> aInsertList; 866cdf0e10cSrcweir aInsertList.resize(aDestColumnNames.getLength()+1); 867cdf0e10cSrcweir sal_Int32 i = 0; 868cdf0e10cSrcweir for(sal_uInt32 j=0; j < aInsertList.size() ;++i,++j) 869cdf0e10cSrcweir { 870cdf0e10cSrcweir ODatabaseExport::TPositions::const_iterator aFind = ::std::find_if(_rvColumns.begin(),_rvColumns.end(), 871cdf0e10cSrcweir ::std::compose1(::std::bind2nd(::std::equal_to<sal_Int32>(),i+1),::std::select2nd<ODatabaseExport::TPositions::value_type>())); 872cdf0e10cSrcweir if ( _rvColumns.end() != aFind && aFind->second != sal::static_int_cast< long >(CONTAINER_ENTRY_NOTFOUND) && aFind->first != sal::static_int_cast< long >(CONTAINER_ENTRY_NOTFOUND) ) 873cdf0e10cSrcweir { 874cdf0e10cSrcweir OSL_ENSURE((aFind->first) < static_cast<sal_Int32>(aInsertList.size()),"aInsertList: Illegal index for vector"); 875cdf0e10cSrcweir aInsertList[aFind->first] = ::dbtools::quoteName( aQuote,*(pIter+i)); 876cdf0e10cSrcweir } 877cdf0e10cSrcweir } 878cdf0e10cSrcweir 879cdf0e10cSrcweir i = 1; 880cdf0e10cSrcweir // create the sql string 881cdf0e10cSrcweir ::std::vector< ::rtl::OUString>::iterator aInsertEnd = aInsertList.end(); 882cdf0e10cSrcweir for (::std::vector< ::rtl::OUString>::iterator aInsertIter = aInsertList.begin(); aInsertIter != aInsertEnd; ++aInsertIter) 883cdf0e10cSrcweir { 884cdf0e10cSrcweir if ( aInsertIter->getLength() ) 885cdf0e10cSrcweir { 886cdf0e10cSrcweir aSql += *aInsertIter; 887cdf0e10cSrcweir aSql += aComma; 888cdf0e10cSrcweir aValues += aPara; 889cdf0e10cSrcweir } 890cdf0e10cSrcweir } 891cdf0e10cSrcweir 892cdf0e10cSrcweir aSql = aSql.replaceAt(aSql.getLength()-1,1,::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(")"))); 893cdf0e10cSrcweir aValues = aValues.replaceAt(aValues.getLength()-1,1,::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(")"))); 894cdf0e10cSrcweir 895cdf0e10cSrcweir aSql += aValues; 896cdf0e10cSrcweir // now create,fill and execute the prepared statement 897cdf0e10cSrcweir return Reference< XPreparedStatement >(_xMetaData->getConnection()->prepareStatement(aSql)); 898cdf0e10cSrcweir } 899cdf0e10cSrcweir // ----------------------------------------------------------------------------- 900cdf0e10cSrcweir 901cdf0e10cSrcweir 902