import java.io.*; import com.sun.star.comp.helper.RegistryServiceFactory; import com.sun.star.comp.servicemanager.ServiceManager; import com.sun.star.lang.XMultiServiceFactory; import com.sun.star.lang.XSingleServiceFactory; import com.sun.star.lang.XServiceInfo; import com.sun.star.lang.XComponent; import com.sun.star.bridge.XUnoUrlResolver; import com.sun.star.uno.*; import com.sun.star.beans.XPropertySet; import com.sun.star.container.XNameAccess; import com.sun.star.container.XNameContainer; import com.sun.star.sdbc.*; import com.sun.star.sdb.*; import com.sun.star.sdbcx.*; public class CodeSamples { public static XMultiServiceFactory rSmgr; public static void main(String argv[]) throws java.lang.Exception { try{ rSmgr = connect("socket,host=localhost,port=8100"); // checkConnection( openConnectionWithDriverManager(rSmgr) ); // checkConnection( openConnectionWithDriver(rSmgr) ); createQuerydefinition( rSmgr ); printQueryColumnNames( rSmgr ); XConnection con = openConnectionWithDriverManager( rSmgr ); if ( con != null ) { { SalesMan sm = new SalesMan( con ); try { sm.dropSalesManTable( ); // doesn't matter here } catch(com.sun.star.uno.Exception e) { } sm.createSalesManTable( ); sm.insertDataIntoSalesMan( ); sm.updateSalesMan( ); sm.retrieveSalesManData( ); } { Sales sm = new Sales( con ); try { sm.dropSalesTable( ); // doesn't matter here } catch(com.sun.star.uno.Exception e) { } sm.createSalesTable( ); sm.insertDataIntoSales( ); sm.updateSales( ); sm.retrieveSalesData( ); sm.displayColumnNames( ); } displayTableStructure( con ); } // printDataSources(rSmgr); } catch(com.sun.star.uno.Exception e) { System.out.println(e); e.printStackTrace(); } System.exit(0); } public static XMultiServiceFactory connect( String connectStr ) throws com.sun.star.uno.Exception, com.sun.star.uno.RuntimeException, java.lang.Exception { // initial serviceManager XMultiServiceFactory xLocalServiceManager = com.sun.star.comp.helper.Bootstrap.createSimpleServiceManager(); // create a connector, so that it can contact the office Object xUrlResolver = xLocalServiceManager.createInstance( "com.sun.star.bridge.UnoUrlResolver" ); XUnoUrlResolver urlResolver = (XUnoUrlResolver)UnoRuntime.queryInterface( XUnoUrlResolver.class, xUrlResolver ); Object rInitialObject = urlResolver.resolve( "uno:" + connectStr + ";urp;StarOffice.NamingService" ); XNamingService rName = (XNamingService)UnoRuntime.queryInterface( XNamingService.class, rInitialObject ); XMultiServiceFactory xMSF = null; if( rName != null ) { System.err.println( "got the remote naming service !" ); Object rXsmgr = rName.getRegisteredObject("StarOffice.ServiceManager" ); xMSF = (XMultiServiceFactory) UnoRuntime.queryInterface( XMultiServiceFactory.class, rXsmgr ); } return ( xMSF ); } // check if the connection is not null aand dispose it later on. public static void checkConnection(XConnection con) throws com.sun.star.uno.Exception { if(con != null) { System.out.println("Connection was created!"); // now we dispose the connection to close it XComponent xComponent = (XComponent)UnoRuntime.queryInterface(XComponent.class,con); if(xComponent != null) { // connections must be disposed xComponent.dispose(); System.out.println("Connection disposed!"); } } else System.out.println("Connection could not be created!"); } // uses the driver manager to create a new connection and dispose it. public static XConnection openConnectionWithDriverManager(XMultiServiceFactory _rMSF) throws com.sun.star.uno.Exception { XConnection con = null; // create the DriverManager Object driverManager = _rMSF.createInstance("com.sun.star.sdbc.DriverManager"); // query for the interface com.sun.star.sdbc.XDriverManager xDriverManager; xDriverManager = (XDriverManager)UnoRuntime.queryInterface(XDriverManager.class,driverManager); if(xDriverManager != null) { // first create the needed url String adabasURL = "sdbc:adabas::MYDB0"; // second create the necessary properties com.sun.star.beans.PropertyValue [] adabasProps = new com.sun.star.beans.PropertyValue[] { new com.sun.star.beans.PropertyValue("user",0,"test1",com.sun.star.beans.PropertyState.DIRECT_VALUE), new com.sun.star.beans.PropertyValue("password",0,"test1",com.sun.star.beans.PropertyState.DIRECT_VALUE) }; // now create a connection to adabas con = xDriverManager.getConnectionWithInfo(adabasURL,adabasProps); } return con; } // uses the driver manager to create a new connection and dispose it. public static XConnection openToJDBC(XMultiServiceFactory _rMSF) throws com.sun.star.uno.Exception { XConnection con = null; // create the DriverManager Object driverManager = _rMSF.createInstance("com.sun.star.sdbc.DriverManager"); // query for the interface com.sun.star.sdbc.XDriverManager xDriverManager; xDriverManager = (XDriverManager)UnoRuntime.queryInterface(XDriverManager.class,driverManager); if(xDriverManager != null) { // first create the needed url String url = "jdbc:mysql://localhost:3306/TestTables"; // second create the necessary properties com.sun.star.beans.PropertyValue [] props = new com.sun.star.beans.PropertyValue[] { new com.sun.star.beans.PropertyValue("user",0,"test1",com.sun.star.beans.PropertyState.DIRECT_VALUE), new com.sun.star.beans.PropertyValue("password",0,"test1",com.sun.star.beans.PropertyState.DIRECT_VALUE), new com.sun.star.beans.PropertyValue("JavaDriverClass",0,"org.gjt.mm.mysql.Driver",com.sun.star.beans.PropertyState.DIRECT_VALUE) }; // now create a connection to adabas con = xDriverManager.getConnectionWithInfo(url,props); } return con; } // uses the driver directly to create a new connection and dispose it. public static XConnection openConnectionWithDriver(XMultiServiceFactory _rMSF) throws com.sun.star.uno.Exception { XConnection con = null; // create the Driver with the implementation name Object aDriver = _rMSF.createInstance("com.sun.star.comp.sdbcx.adabas.ODriver"); // query for the interface com.sun.star.sdbc.XDriver xDriver; xDriver = (XDriver)UnoRuntime.queryInterface(XDriver.class,aDriver); if(xDriver != null) { // first create the needed url String adabasURL = "sdbc:adabas::MYDB0"; // second create the necessary properties com.sun.star.beans.PropertyValue [] adabasProps = new com.sun.star.beans.PropertyValue[] { new com.sun.star.beans.PropertyValue("user",0,"test1",com.sun.star.beans.PropertyState.DIRECT_VALUE), new com.sun.star.beans.PropertyValue("password",0,"test1",com.sun.star.beans.PropertyState.DIRECT_VALUE) }; // now create a connection to adabas con = xDriver.connect(adabasURL,adabasProps); } return con; } // print all available datasources public static void printDataSources(XMultiServiceFactory _rMSF) throws com.sun.star.uno.Exception { // create a DatabaseContext and print all DataSource names XNameAccess xNameAccess = (XNameAccess)UnoRuntime.queryInterface(XNameAccess.class, _rMSF.createInstance("com.sun.star.sdb.DatabaseContext")); String aNames [] = xNameAccess.getElementNames(); for(int i=0;i