/************************************************************************* * * The Contents of this file are made available subject to the terms of * the BSD license. * * Copyright 2000, 2010 Oracle and/or its affiliates. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. Neither the name of Sun Microsystems, Inc. nor the names of its * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * *************************************************************************/ import java.io.*; import com.sun.star.comp.helper.RegistryServiceFactory; import com.sun.star.comp.servicemanager.ServiceManager; import com.sun.star.lang.XMultiComponentFactory; 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.UnoRuntime; import com.sun.star.uno.XComponentContext; 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.*; import com.sun.star.frame.*; public class CodeSamples { public static XComponentContext xContext; public static XMultiComponentFactory xMCF; public static void main(String argv[]) throws java.lang.Exception { try { // get the remote office component context xContext = com.sun.star.comp.helper.Bootstrap.bootstrap(); System.out.println("Connected to a running office ..."); xMCF = xContext.getServiceManager(); } catch(Exception e) { System.err.println("ERROR: can't get a component context from a running office ..."); e.printStackTrace(); System.exit(1); } try{ createQuerydefinition( ); printQueryColumnNames( ); XConnection con = openConnectionWithDriverManager(); 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(); } catch(Exception e) { System.err.println(e); e.printStackTrace(); } System.exit(0); } // 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() throws com.sun.star.uno.Exception { XConnection con = null; // create the DriverManager Object driverManager = xMCF.createInstanceWithContext("com.sun.star.sdbc.DriverManager", xContext); // 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 mysql con = xDriverManager.getConnectionWithInfo(url,props); } return con; } // uses the driver directly to create a new connection and dispose it. public static XConnection openConnectionWithDriver() throws com.sun.star.uno.Exception { XConnection con = null; // create the Driver with the implementation name Object aDriver = xMCF.createInstanceWithContext("org.openoffice.comp.drivers.MySQL.Driver", xContext); // 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 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 mysql con = xDriver.connect(url,props); } return con; } // print all available datasources public static void printDataSources() throws com.sun.star.uno.Exception { // create a DatabaseContext and print all DataSource names XNameAccess xNameAccess = (XNameAccess)UnoRuntime.queryInterface( XNameAccess.class, xMCF.createInstanceWithContext("com.sun.star.sdb.DatabaseContext", xContext)); String aNames [] = xNameAccess.getElementNames(); for(int i=0;i