1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_connectivity.hxx"
26*b1cdbd2cSJim Jagielski #include "FDatabaseMetaDataResultSetMetaData.hxx"
27*b1cdbd2cSJim Jagielski #include <com/sun/star/sdbc/DataType.hpp>
28*b1cdbd2cSJim Jagielski #include <com/sun/star/sdbc/ProcedureResult.hpp>
29*b1cdbd2cSJim Jagielski #include <com/sun/star/sdbc/ColumnValue.hpp>
30*b1cdbd2cSJim Jagielski 
31*b1cdbd2cSJim Jagielski using namespace connectivity;
32*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::beans;
33*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::uno;
34*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::sdbcx;
35*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::sdbc;
36*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::container;
37*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::lang;
38*b1cdbd2cSJim Jagielski 
39*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
~ODatabaseMetaDataResultSetMetaData()40*b1cdbd2cSJim Jagielski ODatabaseMetaDataResultSetMetaData::~ODatabaseMetaDataResultSetMetaData()
41*b1cdbd2cSJim Jagielski {
42*b1cdbd2cSJim Jagielski }
43*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getColumnDisplaySize(sal_Int32 column)44*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL ODatabaseMetaDataResultSetMetaData::getColumnDisplaySize( sal_Int32 column ) throw(SQLException, RuntimeException)
45*b1cdbd2cSJim Jagielski {
46*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
47*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.getColumnDisplaySize();
48*b1cdbd2cSJim Jagielski 
49*b1cdbd2cSJim Jagielski 	return 0;
50*b1cdbd2cSJim Jagielski }
51*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
52*b1cdbd2cSJim Jagielski 
getColumnType(sal_Int32 column)53*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL ODatabaseMetaDataResultSetMetaData::getColumnType( sal_Int32 column ) throw(SQLException, RuntimeException)
54*b1cdbd2cSJim Jagielski {
55*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
56*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.getColumnType();
57*b1cdbd2cSJim Jagielski 	return 1;
58*b1cdbd2cSJim Jagielski }
59*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
60*b1cdbd2cSJim Jagielski 
getColumnCount()61*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL ODatabaseMetaDataResultSetMetaData::getColumnCount(  ) throw(SQLException, RuntimeException)
62*b1cdbd2cSJim Jagielski {
63*b1cdbd2cSJim Jagielski 	return m_mColumns.size();
64*b1cdbd2cSJim Jagielski }
65*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
66*b1cdbd2cSJim Jagielski 
isCaseSensitive(sal_Int32 column)67*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL ODatabaseMetaDataResultSetMetaData::isCaseSensitive( sal_Int32 column ) throw(SQLException, RuntimeException)
68*b1cdbd2cSJim Jagielski {
69*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
70*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.isCaseSensitive();
71*b1cdbd2cSJim Jagielski 	return sal_True;
72*b1cdbd2cSJim Jagielski }
73*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
74*b1cdbd2cSJim Jagielski 
getSchemaName(sal_Int32)75*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL ODatabaseMetaDataResultSetMetaData::getSchemaName( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
76*b1cdbd2cSJim Jagielski {
77*b1cdbd2cSJim Jagielski 	return ::rtl::OUString();
78*b1cdbd2cSJim Jagielski }
79*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
80*b1cdbd2cSJim Jagielski 
getColumnName(sal_Int32 column)81*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL ODatabaseMetaDataResultSetMetaData::getColumnName( sal_Int32 column ) throw(SQLException, RuntimeException)
82*b1cdbd2cSJim Jagielski {
83*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
84*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.getColumnName();
85*b1cdbd2cSJim Jagielski 	return ::rtl::OUString();
86*b1cdbd2cSJim Jagielski }
87*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getTableName(sal_Int32 column)88*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL ODatabaseMetaDataResultSetMetaData::getTableName( sal_Int32 column ) throw(SQLException, RuntimeException)
89*b1cdbd2cSJim Jagielski {
90*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
91*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.getTableName();
92*b1cdbd2cSJim Jagielski 	return ::rtl::OUString();
93*b1cdbd2cSJim Jagielski }
94*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getCatalogName(sal_Int32)95*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL ODatabaseMetaDataResultSetMetaData::getCatalogName( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
96*b1cdbd2cSJim Jagielski {
97*b1cdbd2cSJim Jagielski 	return ::rtl::OUString();
98*b1cdbd2cSJim Jagielski }
99*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getColumnTypeName(sal_Int32 column)100*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL ODatabaseMetaDataResultSetMetaData::getColumnTypeName( sal_Int32 column ) throw(SQLException, RuntimeException)
101*b1cdbd2cSJim Jagielski {
102*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
103*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.getColumnTypeName();
104*b1cdbd2cSJim Jagielski 	return ::rtl::OUString();
105*b1cdbd2cSJim Jagielski }
106*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getColumnLabel(sal_Int32 column)107*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL ODatabaseMetaDataResultSetMetaData::getColumnLabel( sal_Int32 column ) throw(SQLException, RuntimeException)
108*b1cdbd2cSJim Jagielski {
109*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
110*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.getColumnLabel();
111*b1cdbd2cSJim Jagielski 	return getColumnName(column);
112*b1cdbd2cSJim Jagielski }
113*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getColumnServiceName(sal_Int32 column)114*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL ODatabaseMetaDataResultSetMetaData::getColumnServiceName( sal_Int32 column ) throw(SQLException, RuntimeException)
115*b1cdbd2cSJim Jagielski {
116*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
117*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.getColumnServiceName();
118*b1cdbd2cSJim Jagielski 	return ::rtl::OUString();
119*b1cdbd2cSJim Jagielski }
120*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
121*b1cdbd2cSJim Jagielski 
isCurrency(sal_Int32 column)122*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL ODatabaseMetaDataResultSetMetaData::isCurrency( sal_Int32 column ) throw(SQLException, RuntimeException)
123*b1cdbd2cSJim Jagielski {
124*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
125*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.isCurrency();
126*b1cdbd2cSJim Jagielski 	return sal_False;
127*b1cdbd2cSJim Jagielski }
128*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
129*b1cdbd2cSJim Jagielski 
isAutoIncrement(sal_Int32 column)130*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL ODatabaseMetaDataResultSetMetaData::isAutoIncrement( sal_Int32 column ) throw(SQLException, RuntimeException)
131*b1cdbd2cSJim Jagielski {
132*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
133*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.isAutoIncrement();
134*b1cdbd2cSJim Jagielski 	return sal_False;
135*b1cdbd2cSJim Jagielski }
136*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
137*b1cdbd2cSJim Jagielski 
138*b1cdbd2cSJim Jagielski 
isSigned(sal_Int32 column)139*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL ODatabaseMetaDataResultSetMetaData::isSigned( sal_Int32 column ) throw(SQLException, RuntimeException)
140*b1cdbd2cSJim Jagielski {
141*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
142*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.isSigned();
143*b1cdbd2cSJim Jagielski 	return sal_False;
144*b1cdbd2cSJim Jagielski }
145*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getPrecision(sal_Int32 column)146*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL ODatabaseMetaDataResultSetMetaData::getPrecision( sal_Int32 column ) throw(SQLException, RuntimeException)
147*b1cdbd2cSJim Jagielski {
148*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
149*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.getPrecision();
150*b1cdbd2cSJim Jagielski 	return 0;
151*b1cdbd2cSJim Jagielski }
152*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getScale(sal_Int32 column)153*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL ODatabaseMetaDataResultSetMetaData::getScale( sal_Int32 column ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException)
154*b1cdbd2cSJim Jagielski {
155*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
156*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.getScale();
157*b1cdbd2cSJim Jagielski 
158*b1cdbd2cSJim Jagielski 	return 0;
159*b1cdbd2cSJim Jagielski }
160*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
161*b1cdbd2cSJim Jagielski 
isNullable(sal_Int32 column)162*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL ODatabaseMetaDataResultSetMetaData::isNullable( sal_Int32 column ) throw(SQLException, RuntimeException)
163*b1cdbd2cSJim Jagielski {
164*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
165*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.isNullable();
166*b1cdbd2cSJim Jagielski 
167*b1cdbd2cSJim Jagielski 	return sal_False;
168*b1cdbd2cSJim Jagielski }
169*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
170*b1cdbd2cSJim Jagielski 
isSearchable(sal_Int32 column)171*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL ODatabaseMetaDataResultSetMetaData::isSearchable( sal_Int32 column ) throw(SQLException, RuntimeException)
172*b1cdbd2cSJim Jagielski {
173*b1cdbd2cSJim Jagielski 	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
174*b1cdbd2cSJim Jagielski 		return (*m_mColumnsIter).second.isSearchable();
175*b1cdbd2cSJim Jagielski 	return sal_True;
176*b1cdbd2cSJim Jagielski }
177*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
178*b1cdbd2cSJim Jagielski 
isReadOnly(sal_Int32)179*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL ODatabaseMetaDataResultSetMetaData::isReadOnly( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
180*b1cdbd2cSJim Jagielski {
181*b1cdbd2cSJim Jagielski //	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
182*b1cdbd2cSJim Jagielski //		return (*m_mColumnsIter).second.isReadOnly();
183*b1cdbd2cSJim Jagielski 
184*b1cdbd2cSJim Jagielski 	return sal_True;
185*b1cdbd2cSJim Jagielski }
186*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
187*b1cdbd2cSJim Jagielski 
isDefinitelyWritable(sal_Int32)188*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL ODatabaseMetaDataResultSetMetaData::isDefinitelyWritable( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
189*b1cdbd2cSJim Jagielski {
190*b1cdbd2cSJim Jagielski //	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
191*b1cdbd2cSJim Jagielski //		return (*m_mColumnsIter).second.isDefinitelyWritable();
192*b1cdbd2cSJim Jagielski 
193*b1cdbd2cSJim Jagielski 	return sal_False;
194*b1cdbd2cSJim Jagielski ;
195*b1cdbd2cSJim Jagielski }
196*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
isWritable(sal_Int32 column)197*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL ODatabaseMetaDataResultSetMetaData::isWritable( sal_Int32 column ) throw(SQLException, RuntimeException)
198*b1cdbd2cSJim Jagielski {
199*b1cdbd2cSJim Jagielski //	if(m_mColumns.size() && (m_mColumnsIter = m_mColumns.find(column)) != m_mColumns.end())
200*b1cdbd2cSJim Jagielski //		return (*m_mColumnsIter).second.isWritable();
201*b1cdbd2cSJim Jagielski 	return isDefinitelyWritable(column);
202*b1cdbd2cSJim Jagielski }
203*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setColumnPrivilegesMap()204*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setColumnPrivilegesMap()
205*b1cdbd2cSJim Jagielski {
206*b1cdbd2cSJim Jagielski     setColumnMap();
207*b1cdbd2cSJim Jagielski 	m_mColumns[5] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("GRANTOR"),
208*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
209*b1cdbd2cSJim Jagielski 		3,3,0,
210*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
211*b1cdbd2cSJim Jagielski 	m_mColumns[6] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("GRANTEE"),
212*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
213*b1cdbd2cSJim Jagielski 		3,3,0,
214*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
215*b1cdbd2cSJim Jagielski 	m_mColumns[7] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PRIVILEGE"),
216*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
217*b1cdbd2cSJim Jagielski 		3,3,0,
218*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
219*b1cdbd2cSJim Jagielski 	m_mColumns[8] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("IS_GRANTABLE"),
220*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
221*b1cdbd2cSJim Jagielski 		3,3,0,
222*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
223*b1cdbd2cSJim Jagielski }
224*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------------
setTableNameMap()225*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setTableNameMap()
226*b1cdbd2cSJim Jagielski {
227*b1cdbd2cSJim Jagielski     m_mColumns[1] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TABLE_CAT"),
228*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
229*b1cdbd2cSJim Jagielski 		3,3,0,
230*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
231*b1cdbd2cSJim Jagielski 	m_mColumns[2] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TABLE_SCHEM"),
232*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
233*b1cdbd2cSJim Jagielski 		3,3,0,
234*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
235*b1cdbd2cSJim Jagielski 	m_mColumns[3] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TABLE_NAME"),
236*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
237*b1cdbd2cSJim Jagielski 		3,3,0,
238*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
239*b1cdbd2cSJim Jagielski }
240*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------------
setColumnMap()241*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setColumnMap()
242*b1cdbd2cSJim Jagielski {
243*b1cdbd2cSJim Jagielski     setTableNameMap();
244*b1cdbd2cSJim Jagielski 	m_mColumns[4] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("COLUMN_NAME"),
245*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
246*b1cdbd2cSJim Jagielski 		3,3,0,
247*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
248*b1cdbd2cSJim Jagielski }
249*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setColumnsMap()250*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setColumnsMap()
251*b1cdbd2cSJim Jagielski {
252*b1cdbd2cSJim Jagielski     setColumnMap();
253*b1cdbd2cSJim Jagielski 
254*b1cdbd2cSJim Jagielski 	m_mColumns[5] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("DATA_TYPE"),
255*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
256*b1cdbd2cSJim Jagielski 		0,0,0,
257*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
258*b1cdbd2cSJim Jagielski 	m_mColumns[6] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TYPE_NAME"),
259*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
260*b1cdbd2cSJim Jagielski 		0,0,0,
261*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
262*b1cdbd2cSJim Jagielski 	m_mColumns[7] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("COLUMN_SIZE"),
263*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
264*b1cdbd2cSJim Jagielski 		3,3,0,
265*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
266*b1cdbd2cSJim Jagielski 	m_mColumns[8] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("BUFFER_LENGTH"),
267*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
268*b1cdbd2cSJim Jagielski 		3,3,0,
269*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
270*b1cdbd2cSJim Jagielski 	m_mColumns[9] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("DECIMAL_DIGITS"),
271*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
272*b1cdbd2cSJim Jagielski 		0,0,0,
273*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
274*b1cdbd2cSJim Jagielski 	m_mColumns[10] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("NUM_PREC_RADIX"),
275*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
276*b1cdbd2cSJim Jagielski 		0,0,0,
277*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
278*b1cdbd2cSJim Jagielski 	m_mColumns[11] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("NULLABLE"),
279*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
280*b1cdbd2cSJim Jagielski 		1,1,0,
281*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
282*b1cdbd2cSJim Jagielski 	m_mColumns[12] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("REMARKS"),
283*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
284*b1cdbd2cSJim Jagielski 		0,0,0,
285*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
286*b1cdbd2cSJim Jagielski 	m_mColumns[13] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("COLUMN_DEF"),
287*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
288*b1cdbd2cSJim Jagielski 		0,0,0,
289*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
290*b1cdbd2cSJim Jagielski 	m_mColumns[14] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("SQL_DATA_TYPE"),
291*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
292*b1cdbd2cSJim Jagielski 		1,1,0,
293*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
294*b1cdbd2cSJim Jagielski 	m_mColumns[15] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("SQL_DATETIME_SUB"),
295*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
296*b1cdbd2cSJim Jagielski 		1,1,0,
297*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
298*b1cdbd2cSJim Jagielski 	m_mColumns[16] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("CHAR_OCTET_LENGTH"),
299*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
300*b1cdbd2cSJim Jagielski 		1,1,0,
301*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
302*b1cdbd2cSJim Jagielski 	m_mColumns[17] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("ORDINAL_POSITION"),
303*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
304*b1cdbd2cSJim Jagielski 		1,1,0,
305*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
306*b1cdbd2cSJim Jagielski 	m_mColumns[18] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("IS_NULLABLE"),
307*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
308*b1cdbd2cSJim Jagielski 		1,1,0,
309*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
310*b1cdbd2cSJim Jagielski }
311*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setTablesMap()312*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setTablesMap()
313*b1cdbd2cSJim Jagielski {
314*b1cdbd2cSJim Jagielski     setTableNameMap();
315*b1cdbd2cSJim Jagielski 	m_mColumns[4] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TABLE_TYPE"),
316*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
317*b1cdbd2cSJim Jagielski 		0,0,0,
318*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
319*b1cdbd2cSJim Jagielski 	m_mColumns[5] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("REMARKS"),
320*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
321*b1cdbd2cSJim Jagielski 		0,0,0,
322*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
323*b1cdbd2cSJim Jagielski }
324*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setProcedureNameMap()325*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setProcedureNameMap()
326*b1cdbd2cSJim Jagielski {
327*b1cdbd2cSJim Jagielski    m_mColumns[1] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PROCEDURE_CAT"),
328*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
329*b1cdbd2cSJim Jagielski 		0,0,0,
330*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
331*b1cdbd2cSJim Jagielski 	m_mColumns[2] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PROCEDURE_SCHEM"),
332*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
333*b1cdbd2cSJim Jagielski 		0,0,0,
334*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
335*b1cdbd2cSJim Jagielski 	m_mColumns[3] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PROCEDURE_NAME"),
336*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
337*b1cdbd2cSJim Jagielski 		0,0,0,
338*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
339*b1cdbd2cSJim Jagielski }
340*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setProcedureColumnsMap()341*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setProcedureColumnsMap()
342*b1cdbd2cSJim Jagielski {
343*b1cdbd2cSJim Jagielski     setProcedureNameMap();
344*b1cdbd2cSJim Jagielski 	m_mColumns[4] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("COLUMN_NAME"),
345*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
346*b1cdbd2cSJim Jagielski 		0,0,0,
347*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
348*b1cdbd2cSJim Jagielski 	m_mColumns[5] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("COLUMN_TYPE"),
349*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
350*b1cdbd2cSJim Jagielski 		0,0,0,
351*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
352*b1cdbd2cSJim Jagielski 	m_mColumns[6] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("DATA_TYPE"),
353*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
354*b1cdbd2cSJim Jagielski 		0,0,0,
355*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
356*b1cdbd2cSJim Jagielski 	m_mColumns[7] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TYPE_NAME"),
357*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
358*b1cdbd2cSJim Jagielski 		0,0,0,
359*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
360*b1cdbd2cSJim Jagielski 	m_mColumns[8] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PRECISION"),
361*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
362*b1cdbd2cSJim Jagielski 		0,0,0,
363*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
364*b1cdbd2cSJim Jagielski 	m_mColumns[9] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("LENGTH"),
365*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
366*b1cdbd2cSJim Jagielski 		0,0,0,
367*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
368*b1cdbd2cSJim Jagielski 	m_mColumns[10] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("SCALE"),
369*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
370*b1cdbd2cSJim Jagielski 		0,0,0,
371*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
372*b1cdbd2cSJim Jagielski 	m_mColumns[11] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("RADIX"),
373*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
374*b1cdbd2cSJim Jagielski 		0,0,0,
375*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
376*b1cdbd2cSJim Jagielski 	m_mColumns[12] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("NULLABLE"),
377*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
378*b1cdbd2cSJim Jagielski 		0,0,0,
379*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
380*b1cdbd2cSJim Jagielski 	m_mColumns[13] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("REMARKS"),
381*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
382*b1cdbd2cSJim Jagielski 		0,0,0,
383*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
384*b1cdbd2cSJim Jagielski 
385*b1cdbd2cSJim Jagielski }
386*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setPrimaryKeysMap()387*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setPrimaryKeysMap()
388*b1cdbd2cSJim Jagielski {
389*b1cdbd2cSJim Jagielski     setColumnMap();
390*b1cdbd2cSJim Jagielski 	m_mColumns[5] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("KEY_SEQ"),
391*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
392*b1cdbd2cSJim Jagielski 		1,1,0,
393*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
394*b1cdbd2cSJim Jagielski 	m_mColumns[6] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PK_NAME"),
395*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
396*b1cdbd2cSJim Jagielski 		0,0,0,
397*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
398*b1cdbd2cSJim Jagielski }
399*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setIndexInfoMap()400*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setIndexInfoMap()
401*b1cdbd2cSJim Jagielski {
402*b1cdbd2cSJim Jagielski     setTableNameMap();
403*b1cdbd2cSJim Jagielski 	m_mColumns[4] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("NON_UNIQUE"),
404*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
405*b1cdbd2cSJim Jagielski 		1,1,0,
406*b1cdbd2cSJim Jagielski                 DataType::BIT);
407*b1cdbd2cSJim Jagielski 	m_mColumns[5] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("INDEX_QUALIFIER"),
408*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
409*b1cdbd2cSJim Jagielski 		0,0,0,
410*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
411*b1cdbd2cSJim Jagielski 	m_mColumns[6] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("INDEX_NAME"),
412*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
413*b1cdbd2cSJim Jagielski 		0,0,0,
414*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
415*b1cdbd2cSJim Jagielski 	m_mColumns[7] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TYPE"),
416*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
417*b1cdbd2cSJim Jagielski 		0,0,0,
418*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
419*b1cdbd2cSJim Jagielski 	m_mColumns[8] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("ORDINAL_POSITION"),
420*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
421*b1cdbd2cSJim Jagielski 		0,0,0,
422*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
423*b1cdbd2cSJim Jagielski 	m_mColumns[9] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("COLUMN_NAME"),
424*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
425*b1cdbd2cSJim Jagielski 		0,0,0,
426*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
427*b1cdbd2cSJim Jagielski 	m_mColumns[10] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("ASC_OR_DESC"),
428*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
429*b1cdbd2cSJim Jagielski 		0,0,0,
430*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
431*b1cdbd2cSJim Jagielski 	m_mColumns[11] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("CARDINALITY"),
432*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
433*b1cdbd2cSJim Jagielski 		0,0,0,
434*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
435*b1cdbd2cSJim Jagielski 	m_mColumns[12] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PAGES"),
436*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
437*b1cdbd2cSJim Jagielski 		0,0,0,
438*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
439*b1cdbd2cSJim Jagielski 	m_mColumns[13] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("FILTER_CONDITION"),
440*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
441*b1cdbd2cSJim Jagielski 		0,0,0,
442*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
443*b1cdbd2cSJim Jagielski }
444*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setTablePrivilegesMap()445*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setTablePrivilegesMap()
446*b1cdbd2cSJim Jagielski {
447*b1cdbd2cSJim Jagielski     setTableNameMap();
448*b1cdbd2cSJim Jagielski 	m_mColumns[4] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("GRANTOR"),
449*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
450*b1cdbd2cSJim Jagielski 		0,0,0,
451*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
452*b1cdbd2cSJim Jagielski 	m_mColumns[5] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("GRANTEE"),
453*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
454*b1cdbd2cSJim Jagielski 		0,0,0,
455*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
456*b1cdbd2cSJim Jagielski 	m_mColumns[6] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PRIVILEGE"),
457*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
458*b1cdbd2cSJim Jagielski 		0,0,0,
459*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
460*b1cdbd2cSJim Jagielski 	m_mColumns[7] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("IS_GRANTABLE"),
461*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
462*b1cdbd2cSJim Jagielski 		0,0,0,
463*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
464*b1cdbd2cSJim Jagielski }
465*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setCrossReferenceMap()466*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setCrossReferenceMap()
467*b1cdbd2cSJim Jagielski {
468*b1cdbd2cSJim Jagielski 	m_mColumns[1] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PKTABLE_CAT"),
469*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
470*b1cdbd2cSJim Jagielski 		0,0,0,
471*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
472*b1cdbd2cSJim Jagielski 	m_mColumns[2] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PKTABLE_SCHEM"),
473*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
474*b1cdbd2cSJim Jagielski 		0,0,0,
475*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
476*b1cdbd2cSJim Jagielski 	m_mColumns[3] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PKTABLE_NAME"),
477*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
478*b1cdbd2cSJim Jagielski 		0,0,0,
479*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
480*b1cdbd2cSJim Jagielski 	m_mColumns[4] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PKCOLUMN_NAME"),
481*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
482*b1cdbd2cSJim Jagielski 		0,0,0,
483*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
484*b1cdbd2cSJim Jagielski 	m_mColumns[5] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("FKTABLE_CAT"),
485*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
486*b1cdbd2cSJim Jagielski 		0,0,0,
487*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
488*b1cdbd2cSJim Jagielski 	m_mColumns[6] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("FKTABLE_SCHEM"),
489*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
490*b1cdbd2cSJim Jagielski 		0,0,0,
491*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
492*b1cdbd2cSJim Jagielski 	m_mColumns[7] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("FKTABLE_NAME"),
493*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
494*b1cdbd2cSJim Jagielski 		0,0,0,
495*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
496*b1cdbd2cSJim Jagielski 	m_mColumns[8] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("FKCOLUMN_NAME"),
497*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
498*b1cdbd2cSJim Jagielski 		0,0,0,
499*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
500*b1cdbd2cSJim Jagielski 
501*b1cdbd2cSJim Jagielski 	m_mColumns[9] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("KEY_SEQ"),
502*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
503*b1cdbd2cSJim Jagielski 		1,1,0,
504*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
505*b1cdbd2cSJim Jagielski 	m_mColumns[10] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("UPDATE_RULE"),
506*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
507*b1cdbd2cSJim Jagielski 		1,1,0,
508*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
509*b1cdbd2cSJim Jagielski 	m_mColumns[11] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("DELETE_RULE"),
510*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
511*b1cdbd2cSJim Jagielski 		1,1,0,
512*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
513*b1cdbd2cSJim Jagielski 	m_mColumns[12] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("FK_NAME"),
514*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
515*b1cdbd2cSJim Jagielski 		0,0,0,
516*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
517*b1cdbd2cSJim Jagielski 	m_mColumns[13] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PK_NAME"),
518*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
519*b1cdbd2cSJim Jagielski 		0,0,0,
520*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
521*b1cdbd2cSJim Jagielski 	m_mColumns[14] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("DEFERRABILITY"),
522*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
523*b1cdbd2cSJim Jagielski 		1,1,0,
524*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
525*b1cdbd2cSJim Jagielski }
526*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setTypeInfoMap()527*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setTypeInfoMap()
528*b1cdbd2cSJim Jagielski {
529*b1cdbd2cSJim Jagielski 	m_mColumns[1] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TYPE_NAME"),
530*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
531*b1cdbd2cSJim Jagielski 		0,0,0,
532*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
533*b1cdbd2cSJim Jagielski 	m_mColumns[2] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("DATA_TYPE"),
534*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
535*b1cdbd2cSJim Jagielski 		1,1,0,
536*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
537*b1cdbd2cSJim Jagielski 	m_mColumns[3] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PRECISION"),
538*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
539*b1cdbd2cSJim Jagielski 		1,1,0,
540*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
541*b1cdbd2cSJim Jagielski 	m_mColumns[4] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("LITERAL_PREFIX"),
542*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
543*b1cdbd2cSJim Jagielski 		0,0,0,
544*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
545*b1cdbd2cSJim Jagielski 	m_mColumns[5] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("LITERAL_SUFFIX"),
546*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
547*b1cdbd2cSJim Jagielski 		0,0,0,
548*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
549*b1cdbd2cSJim Jagielski 	m_mColumns[6] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("CREATE_PARAMS"),
550*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
551*b1cdbd2cSJim Jagielski 		0,0,0,
552*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
553*b1cdbd2cSJim Jagielski 	m_mColumns[7] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("NULLABLE"),
554*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
555*b1cdbd2cSJim Jagielski 		1,1,0,
556*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
557*b1cdbd2cSJim Jagielski 	m_mColumns[8] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("CASE_SENSITIVE"),
558*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
559*b1cdbd2cSJim Jagielski 		1,1,0,
560*b1cdbd2cSJim Jagielski                 DataType::BIT);
561*b1cdbd2cSJim Jagielski 	m_mColumns[9] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("SEARCHABLE"),
562*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
563*b1cdbd2cSJim Jagielski 		1,1,0,
564*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
565*b1cdbd2cSJim Jagielski 	m_mColumns[10] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("UNSIGNED_ATTRIBUTE"),
566*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
567*b1cdbd2cSJim Jagielski 		1,1,0,
568*b1cdbd2cSJim Jagielski                 DataType::BIT);
569*b1cdbd2cSJim Jagielski 	m_mColumns[11] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("FIXED_PREC_SCALE"),
570*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
571*b1cdbd2cSJim Jagielski 		1,1,0,
572*b1cdbd2cSJim Jagielski                 DataType::BIT);
573*b1cdbd2cSJim Jagielski 	m_mColumns[12] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("AUTO_INCREMENT"),
574*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
575*b1cdbd2cSJim Jagielski 		1,1,0,
576*b1cdbd2cSJim Jagielski                 DataType::BIT);
577*b1cdbd2cSJim Jagielski 	m_mColumns[13] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("LOCAL_TYPE_NAME"),
578*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
579*b1cdbd2cSJim Jagielski 		0,0,0,
580*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
581*b1cdbd2cSJim Jagielski 	m_mColumns[14] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("MINIMUM_SCALE"),
582*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
583*b1cdbd2cSJim Jagielski 		0,0,0,
584*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
585*b1cdbd2cSJim Jagielski 	m_mColumns[15] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("MAXIMUM_SCALE"),
586*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
587*b1cdbd2cSJim Jagielski 		0,0,0,
588*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
589*b1cdbd2cSJim Jagielski 	m_mColumns[16] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("SQL_DATA_TYPE"),
590*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
591*b1cdbd2cSJim Jagielski 		1,1,0,
592*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
593*b1cdbd2cSJim Jagielski 	m_mColumns[17] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("SQL_DATETIME_SUB"),
594*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
595*b1cdbd2cSJim Jagielski 		1,1,0,
596*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
597*b1cdbd2cSJim Jagielski 	m_mColumns[18] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("NUM_PREC_RADIX"),
598*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
599*b1cdbd2cSJim Jagielski 		1,1,0,
600*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
601*b1cdbd2cSJim Jagielski }
602*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setProceduresMap()603*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setProceduresMap()
604*b1cdbd2cSJim Jagielski {
605*b1cdbd2cSJim Jagielski 	setProcedureNameMap();
606*b1cdbd2cSJim Jagielski 	m_mColumns[4] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("RESERVED1"),
607*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
608*b1cdbd2cSJim Jagielski 		0,0,0,
609*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
610*b1cdbd2cSJim Jagielski 	m_mColumns[5] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("RESERVED2"),
611*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
612*b1cdbd2cSJim Jagielski 		0,0,0,
613*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
614*b1cdbd2cSJim Jagielski 	m_mColumns[6] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("RESERVED3"),
615*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
616*b1cdbd2cSJim Jagielski 		0,0,0,
617*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
618*b1cdbd2cSJim Jagielski 	m_mColumns[7] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("REMARKS"),
619*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
620*b1cdbd2cSJim Jagielski 		0,0,0,
621*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
622*b1cdbd2cSJim Jagielski 	m_mColumns[8] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PROCEDURE_TYPE"),
623*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
624*b1cdbd2cSJim Jagielski 		1,1,0,
625*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
626*b1cdbd2cSJim Jagielski }
627*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setTableTypes()628*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setTableTypes()
629*b1cdbd2cSJim Jagielski {
630*b1cdbd2cSJim Jagielski 	m_mColumns[1] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TABLE_TYPE"),
631*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
632*b1cdbd2cSJim Jagielski 		0,0,0,
633*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
634*b1cdbd2cSJim Jagielski }
635*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setCatalogsMap()636*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setCatalogsMap()
637*b1cdbd2cSJim Jagielski {
638*b1cdbd2cSJim Jagielski 	m_mColumns[1] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TABLE_CAT"),
639*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
640*b1cdbd2cSJim Jagielski 		0,0,0,
641*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
642*b1cdbd2cSJim Jagielski }
643*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setSchemasMap()644*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setSchemasMap()
645*b1cdbd2cSJim Jagielski {
646*b1cdbd2cSJim Jagielski 	m_mColumns[1] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TABLE_SCHEM"),
647*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
648*b1cdbd2cSJim Jagielski 		0,0,0,
649*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
650*b1cdbd2cSJim Jagielski }
651*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
setVersionColumnsMap()652*b1cdbd2cSJim Jagielski void ODatabaseMetaDataResultSetMetaData::setVersionColumnsMap()
653*b1cdbd2cSJim Jagielski {
654*b1cdbd2cSJim Jagielski    m_mColumns[1] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("SCOPE"),
655*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
656*b1cdbd2cSJim Jagielski 		0,0,0,
657*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
658*b1cdbd2cSJim Jagielski 	m_mColumns[2] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("COLUMN_NAME"),
659*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
660*b1cdbd2cSJim Jagielski 		0,0,0,
661*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
662*b1cdbd2cSJim Jagielski 	m_mColumns[3] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("DATA_TYPE"),
663*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
664*b1cdbd2cSJim Jagielski 		0,0,0,
665*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
666*b1cdbd2cSJim Jagielski 	m_mColumns[4] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("TYPE_NAME"),
667*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
668*b1cdbd2cSJim Jagielski 		0,0,0,
669*b1cdbd2cSJim Jagielski                 DataType::VARCHAR);
670*b1cdbd2cSJim Jagielski 	m_mColumns[5] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("COLUMN_SIZE"),
671*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
672*b1cdbd2cSJim Jagielski 		0,0,0,
673*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
674*b1cdbd2cSJim Jagielski 	m_mColumns[6] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("BUFFER_LENGTH"),
675*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
676*b1cdbd2cSJim Jagielski 		0,0,0,
677*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
678*b1cdbd2cSJim Jagielski 	m_mColumns[7] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("DECIMAL_DIGITS"),
679*b1cdbd2cSJim Jagielski                 ColumnValue::NULLABLE,
680*b1cdbd2cSJim Jagielski 		0,0,0,
681*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
682*b1cdbd2cSJim Jagielski 	m_mColumns[8] = OColumn(::rtl::OUString(),::rtl::OUString::createFromAscii("PSEUDO_COLUMN"),
683*b1cdbd2cSJim Jagielski                 ColumnValue::NO_NULLS,
684*b1cdbd2cSJim Jagielski 		0,0,0,
685*b1cdbd2cSJim Jagielski                 DataType::INTEGER);
686*b1cdbd2cSJim Jagielski }
687*b1cdbd2cSJim Jagielski 
688*b1cdbd2cSJim Jagielski 
689