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 package connectivity.tools; 25*b1cdbd2cSJim Jagielski 26*b1cdbd2cSJim Jagielski import com.sun.star.beans.XPropertySet; 27*b1cdbd2cSJim Jagielski import com.sun.star.container.XNameAccess; 28*b1cdbd2cSJim Jagielski import com.sun.star.sdbc.ColumnValue; 29*b1cdbd2cSJim Jagielski import com.sun.star.sdbcx.XColumnsSupplier; 30*b1cdbd2cSJim Jagielski import com.sun.star.sdbcx.XDataDescriptorFactory; 31*b1cdbd2cSJim Jagielski import com.sun.star.sdbcx.XTablesSupplier; 32*b1cdbd2cSJim Jagielski import com.sun.star.uno.UnoRuntime; 33*b1cdbd2cSJim Jagielski import connectivity.tools.sdb.Connection; 34*b1cdbd2cSJim Jagielski 35*b1cdbd2cSJim Jagielski /** is a very simply descriptor of a HSQL table, to be used with a HsqlDatabase.createTable method 36*b1cdbd2cSJim Jagielski */ 37*b1cdbd2cSJim Jagielski public class HsqlTableDescriptor 38*b1cdbd2cSJim Jagielski { 39*b1cdbd2cSJim Jagielski private String m_name; 40*b1cdbd2cSJim Jagielski private HsqlColumnDescriptor[] m_columns; 41*b1cdbd2cSJim Jagielski 42*b1cdbd2cSJim Jagielski /** Creates a new instance of HsqlTableDescriptor */ HsqlTableDescriptor( String _name, HsqlColumnDescriptor[] _columns )43*b1cdbd2cSJim Jagielski public HsqlTableDescriptor( String _name, HsqlColumnDescriptor[] _columns ) 44*b1cdbd2cSJim Jagielski { 45*b1cdbd2cSJim Jagielski m_name = _name; 46*b1cdbd2cSJim Jagielski m_columns = _columns; 47*b1cdbd2cSJim Jagielski } 48*b1cdbd2cSJim Jagielski 49*b1cdbd2cSJim Jagielski /** returns the name of the table 50*b1cdbd2cSJim Jagielski */ getName()51*b1cdbd2cSJim Jagielski public String getName() 52*b1cdbd2cSJim Jagielski { 53*b1cdbd2cSJim Jagielski return m_name; 54*b1cdbd2cSJim Jagielski } 55*b1cdbd2cSJim Jagielski 56*b1cdbd2cSJim Jagielski /** returns the set of column descriptors for the table 57*b1cdbd2cSJim Jagielski */ getColumns()58*b1cdbd2cSJim Jagielski public HsqlColumnDescriptor[] getColumns() 59*b1cdbd2cSJim Jagielski { 60*b1cdbd2cSJim Jagielski return m_columns; 61*b1cdbd2cSJim Jagielski } 62*b1cdbd2cSJim Jagielski createSdbcxDescriptor( Connection _forConnection )63*b1cdbd2cSJim Jagielski public XPropertySet createSdbcxDescriptor( Connection _forConnection ) 64*b1cdbd2cSJim Jagielski { 65*b1cdbd2cSJim Jagielski XTablesSupplier suppTables = UnoRuntime.queryInterface( XTablesSupplier.class, _forConnection.getXConnection() ); 66*b1cdbd2cSJim Jagielski XDataDescriptorFactory tableDescFac = UnoRuntime.queryInterface( XDataDescriptorFactory.class, suppTables.getTables() ); 67*b1cdbd2cSJim Jagielski XPropertySet tableDesc = tableDescFac.createDataDescriptor(); 68*b1cdbd2cSJim Jagielski 69*b1cdbd2cSJim Jagielski try 70*b1cdbd2cSJim Jagielski { 71*b1cdbd2cSJim Jagielski tableDesc.setPropertyValue( "Name", getName() ); 72*b1cdbd2cSJim Jagielski } 73*b1cdbd2cSJim Jagielski catch ( Exception e ) { e.printStackTrace( System.err ); } 74*b1cdbd2cSJim Jagielski 75*b1cdbd2cSJim Jagielski XColumnsSupplier suppDescCols = UnoRuntime.queryInterface( XColumnsSupplier.class, tableDesc ); 76*b1cdbd2cSJim Jagielski 77*b1cdbd2cSJim Jagielski XNameAccess descColumns = suppDescCols.getColumns(); 78*b1cdbd2cSJim Jagielski XDataDescriptorFactory columnDescFac = UnoRuntime.queryInterface( XDataDescriptorFactory.class, descColumns ); 79*b1cdbd2cSJim Jagielski 80*b1cdbd2cSJim Jagielski HsqlColumnDescriptor[] myColumns = getColumns(); 81*b1cdbd2cSJim Jagielski for ( int i = 0; i < myColumns.length; ++i ) 82*b1cdbd2cSJim Jagielski { 83*b1cdbd2cSJim Jagielski XPropertySet columnDesc = columnDescFac.createDataDescriptor(); 84*b1cdbd2cSJim Jagielski try 85*b1cdbd2cSJim Jagielski { 86*b1cdbd2cSJim Jagielski columnDesc.setPropertyValue( "Name", myColumns[i].getName() ); 87*b1cdbd2cSJim Jagielski columnDesc.setPropertyValue( "IsNullable", new Integer( myColumns[i].isRequired() ? ColumnValue.NO_NULLS : ColumnValue.NULLABLE) ); 88*b1cdbd2cSJim Jagielski columnDesc.setPropertyValue( "TypeName", myColumns[i].getTypeName() ); 89*b1cdbd2cSJim Jagielski if ( myColumns[i].isPrimaryKey() || myColumns[i].isForeignKey() ) 90*b1cdbd2cSJim Jagielski // not yet implemented 91*b1cdbd2cSJim Jagielski throw new java.lang.UnsupportedOperationException("creating a primary or foreign key via SDBCX not yet implemented" ); 92*b1cdbd2cSJim Jagielski } 93*b1cdbd2cSJim Jagielski catch( com.sun.star.uno.Exception e ) { e.printStackTrace( System.err ); } 94*b1cdbd2cSJim Jagielski } 95*b1cdbd2cSJim Jagielski 96*b1cdbd2cSJim Jagielski return tableDesc; 97*b1cdbd2cSJim Jagielski } 98*b1cdbd2cSJim Jagielski } 99