| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-10 18:29:29 +00:00
										 |  |  |  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-10 18:29:29 +00:00
										 |  |  |  * Copyright 2008 by Sun Microsystems, Inc. | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-10 18:29:29 +00:00
										 |  |  |  * OpenOffice.org - a multi-platform office productivity suite | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-10 18:29:29 +00:00
										 |  |  |  * $RCSfile: xfldui.cxx,v $ | 
					
						
							|  |  |  |  * $Revision: 1.11 $ | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-10 18:29:29 +00:00
										 |  |  |  * This file is part of OpenOffice.org. | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-10 18:29:29 +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. | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-10 18:29:29 +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). | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-10 18:29:29 +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. | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  ************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-09-16 22:00:22 +00:00
										 |  |  | // MARKER(update_precomp.py): autogen include statement, do not remove
 | 
					
						
							|  |  |  | #include "precompiled_sw.hxx"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <tools/debug.hxx>
 | 
					
						
							|  |  |  | #include <com/sun/star/lang/XMultiServiceFactory.hpp>
 | 
					
						
							|  |  |  | #include <com/sun/star/container/XNameAccess.hpp>
 | 
					
						
							|  |  |  | #include <com/sun/star/sdbc/XDataSource.hpp>
 | 
					
						
							|  |  |  | #include <com/sun/star/sdbc/DataType.hpp>
 | 
					
						
							|  |  |  | #include <com/sun/star/sdbcx/XTablesSupplier.hpp>
 | 
					
						
							|  |  |  | #include <com/sun/star/sdbcx/XColumnsSupplier.hpp>
 | 
					
						
							|  |  |  | #include <com/sun/star/sdb/XQueriesSupplier.hpp>
 | 
					
						
							|  |  |  | #include <com/sun/star/beans/XPropertySet.hpp>
 | 
					
						
							|  |  |  | #include <comphelper/processfactory.hxx>
 | 
					
						
							|  |  |  | #include <fldmgr.hxx>
 | 
					
						
							| 
									
										
										
										
											2001-08-15 07:20:44 +00:00
										 |  |  | #ifndef _DBMGR_HXX
 | 
					
						
							|  |  |  | #include <dbmgr.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #include <wrtsh.hxx>        // Actives Fenster
 | 
					
						
							|  |  |  | #ifndef _VIEW_HXX
 | 
					
						
							|  |  |  | #include <view.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #include <swmodule.hxx>
 | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-27 10:50:14 +00:00
										 |  |  | using namespace ::com::sun::star::uno; | 
					
						
							|  |  |  | using namespace ::com::sun::star::container; | 
					
						
							|  |  |  | using namespace ::com::sun::star::lang; | 
					
						
							|  |  |  | using namespace ::com::sun::star::sdb; | 
					
						
							|  |  |  | using namespace ::com::sun::star::sdbc; | 
					
						
							|  |  |  | using namespace ::com::sun::star::sdbcx; | 
					
						
							|  |  |  | using namespace ::com::sun::star::beans; | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // ---------------------------------------------------------------------------
 | 
					
						
							|  |  |  | // This file contains all routines of the fldui directory, which must compile
 | 
					
						
							|  |  |  | // with exceptions. So we can reduce the code of the other files, which don't
 | 
					
						
							|  |  |  | // need any exception handling.
 | 
					
						
							|  |  |  | // ---------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*--------------------------------------------------------------------
 | 
					
						
							|  |  |  |      Beschreibung: Ist das Datenbankfeld numerisch? | 
					
						
							|  |  |  |      Anm: Im Fehlerfall wird TRUE returnt. | 
					
						
							|  |  |  |  --------------------------------------------------------------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | BOOL SwFldMgr::IsDBNumeric( const String& rDBName, const String& rTblQryName, | 
					
						
							|  |  |  |                             BOOL bIsTable, const String& rFldName) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     BOOL bNumeric = TRUE; | 
					
						
							| 
									
										
										
										
											2001-08-15 07:20:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     SwNewDBMgr* pDBMgr = pWrtShell ? pWrtShell->GetNewDBMgr() : | 
					
						
							|  |  |  |                             ::GetActiveView()->GetWrtShell().GetNewDBMgr(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ::rtl::OUString sSource(rDBName); | 
					
						
							|  |  |  |     Reference< XConnection> xConnection = | 
					
						
							|  |  |  |                     pDBMgr->RegisterConnection(sSource); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if( !xConnection.is() ) | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |         return bNumeric; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Reference<XColumnsSupplier> xColsSupplier; | 
					
						
							|  |  |  |     if(bIsTable) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         Reference<XTablesSupplier> xTSupplier = Reference<XTablesSupplier>(xConnection, UNO_QUERY); | 
					
						
							|  |  |  |         if(xTSupplier.is()) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             Reference<XNameAccess> xTbls = xTSupplier->getTables(); | 
					
						
							| 
									
										
										
										
											2008-11-10 15:06:12 +00:00
										 |  |  |             DBG_ASSERT(xTbls->hasByName(rTblQryName), "table not available anymore?"); | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |             try | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 Any aTable = xTbls->getByName(rTblQryName); | 
					
						
							| 
									
										
										
										
											2001-09-27 09:47:49 +00:00
										 |  |  |                 Reference<XPropertySet> xPropSet; | 
					
						
							|  |  |  |                 aTable >>= xPropSet; | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |                 xColsSupplier = Reference<XColumnsSupplier>(xPropSet, UNO_QUERY); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2001-07-18 12:25:54 +00:00
										 |  |  |             catch(Exception&){} | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         Reference<XQueriesSupplier> xQSupplier = Reference<XQueriesSupplier>(xConnection, UNO_QUERY); | 
					
						
							|  |  |  |         if(xQSupplier.is()) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             Reference<XNameAccess> xQueries = xQSupplier->getQueries(); | 
					
						
							| 
									
										
										
										
											2008-11-10 15:06:12 +00:00
										 |  |  |             DBG_ASSERT(xQueries->hasByName(rTblQryName), "table not available anymore?"); | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |             try | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 Any aQuery = xQueries->getByName(rTblQryName); | 
					
						
							| 
									
										
										
										
											2001-09-27 09:47:49 +00:00
										 |  |  |                 Reference<XPropertySet> xPropSet; | 
					
						
							|  |  |  |                 aQuery >>= xPropSet; | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |                 xColsSupplier = Reference<XColumnsSupplier>(xPropSet, UNO_QUERY); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2001-07-18 12:25:54 +00:00
										 |  |  |             catch(Exception&){} | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if(xColsSupplier.is()) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-07-18 12:25:54 +00:00
										 |  |  |         Reference <XNameAccess> xCols; | 
					
						
							|  |  |  |         try | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             xCols = xColsSupplier->getColumns(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         catch(Exception& ) | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2008-11-10 15:06:12 +00:00
										 |  |  |             DBG_ERROR("Exception in getColumns()"); | 
					
						
							| 
									
										
										
										
											2001-07-18 12:25:54 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |         if(xCols.is() && xCols->hasByName(rFldName)) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             Any aCol = xCols->getByName(rFldName); | 
					
						
							| 
									
										
										
										
											2001-09-27 09:47:49 +00:00
										 |  |  |             Reference <XPropertySet> xCol; | 
					
						
							|  |  |  |             aCol >>= xCol; | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |             Any aType = xCol->getPropertyValue( UniString::CreateFromAscii("Type")); | 
					
						
							| 
									
										
										
										
											2007-11-12 15:31:42 +00:00
										 |  |  |             sal_Int32 eDataType = 0; | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |             aType >>= eDataType; | 
					
						
							|  |  |  |             switch(eDataType) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 case DataType::BIT: | 
					
						
							| 
									
										
										
										
											2005-02-17 09:38:07 +00:00
										 |  |  |                 case DataType::BOOLEAN: | 
					
						
							| 
									
										
										
										
											2001-05-22 07:29:13 +00:00
										 |  |  |                 case DataType::TINYINT: | 
					
						
							|  |  |  |                 case DataType::SMALLINT: | 
					
						
							|  |  |  |                 case DataType::INTEGER: | 
					
						
							|  |  |  |                 case DataType::BIGINT: | 
					
						
							|  |  |  |                 case DataType::FLOAT: | 
					
						
							|  |  |  |                 case DataType::REAL: | 
					
						
							|  |  |  |                 case DataType::DOUBLE: | 
					
						
							|  |  |  |                 case DataType::NUMERIC: | 
					
						
							|  |  |  |                 case DataType::DECIMAL: | 
					
						
							|  |  |  |                 case DataType::DATE: | 
					
						
							|  |  |  |                 case DataType::TIME: | 
					
						
							|  |  |  |                 case DataType::TIMESTAMP: | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 case DataType::BINARY: | 
					
						
							|  |  |  |                 case DataType::VARBINARY: | 
					
						
							|  |  |  |                 case DataType::LONGVARBINARY: | 
					
						
							|  |  |  |                 case DataType::SQLNULL: | 
					
						
							|  |  |  |                 case DataType::OTHER: | 
					
						
							|  |  |  |                 case DataType::OBJECT: | 
					
						
							|  |  |  |                 case DataType::DISTINCT: | 
					
						
							|  |  |  |                 case DataType::STRUCT: | 
					
						
							|  |  |  |                 case DataType::ARRAY: | 
					
						
							|  |  |  |                 case DataType::BLOB: | 
					
						
							|  |  |  |                 case DataType::CLOB: | 
					
						
							|  |  |  |                 case DataType::REF: | 
					
						
							|  |  |  |                 case DataType::CHAR: | 
					
						
							|  |  |  |                 case DataType::VARCHAR: | 
					
						
							|  |  |  |                 case DataType::LONGVARCHAR: | 
					
						
							|  |  |  |                 default: | 
					
						
							|  |  |  |                     bNumeric = FALSE; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return bNumeric; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |