xref: /trunk/main/connectivity/qa/connectivity/tools/RowSet.java (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir package connectivity.tools;
29*cdf0e10cSrcweir 
30*cdf0e10cSrcweir import com.sun.star.beans.XPropertySet;
31*cdf0e10cSrcweir import com.sun.star.container.XIndexAccess;
32*cdf0e10cSrcweir import com.sun.star.container.XNameAccess;
33*cdf0e10cSrcweir import com.sun.star.io.XInputStream;
34*cdf0e10cSrcweir import com.sun.star.lang.XComponent;
35*cdf0e10cSrcweir import com.sun.star.lang.XMultiServiceFactory;
36*cdf0e10cSrcweir import com.sun.star.sdbc.SQLException;
37*cdf0e10cSrcweir import com.sun.star.sdbc.XArray;
38*cdf0e10cSrcweir import com.sun.star.sdbc.XBlob;
39*cdf0e10cSrcweir import com.sun.star.sdbc.XClob;
40*cdf0e10cSrcweir import com.sun.star.sdbc.XRef;
41*cdf0e10cSrcweir import com.sun.star.sdbc.XRow;
42*cdf0e10cSrcweir import com.sun.star.sdbc.XRowSet;
43*cdf0e10cSrcweir import com.sun.star.sdbc.XRowSetListener;
44*cdf0e10cSrcweir import com.sun.star.sdbcx.XColumnsSupplier;
45*cdf0e10cSrcweir import com.sun.star.uno.UnoRuntime;
46*cdf0e10cSrcweir import com.sun.star.util.Date;
47*cdf0e10cSrcweir import com.sun.star.util.DateTime;
48*cdf0e10cSrcweir import com.sun.star.util.Time;
49*cdf0e10cSrcweir 
50*cdf0e10cSrcweir public class RowSet implements XRowSet, XRow
51*cdf0e10cSrcweir {
52*cdf0e10cSrcweir     private XRowSet                 m_rowSet;
53*cdf0e10cSrcweir     private XRow                    m_row;
54*cdf0e10cSrcweir     private XPropertySet            m_rowSetProps;
55*cdf0e10cSrcweir 
56*cdf0e10cSrcweir     public RowSet( XMultiServiceFactory _orb, String _dataSource, int _commandType, String _command )
57*cdf0e10cSrcweir     {
58*cdf0e10cSrcweir         try
59*cdf0e10cSrcweir         {
60*cdf0e10cSrcweir             m_rowSetProps = UnoRuntime.queryInterface( XPropertySet.class, _orb.createInstance( "com.sun.star.sdb.RowSet" ) );
61*cdf0e10cSrcweir             m_rowSetProps.setPropertyValue( "DataSourceName", _dataSource );
62*cdf0e10cSrcweir             m_rowSetProps.setPropertyValue( "CommandType", new Integer( _commandType ) );
63*cdf0e10cSrcweir             m_rowSetProps.setPropertyValue( "Command", _command );
64*cdf0e10cSrcweir 
65*cdf0e10cSrcweir             m_rowSet = UnoRuntime.queryInterface( XRowSet.class, m_rowSetProps );
66*cdf0e10cSrcweir             m_row = UnoRuntime.queryInterface( XRow.class, m_rowSetProps );
67*cdf0e10cSrcweir         }
68*cdf0e10cSrcweir         catch ( Exception e )
69*cdf0e10cSrcweir         {
70*cdf0e10cSrcweir             e.printStackTrace(System.err);
71*cdf0e10cSrcweir             throw new java.lang.InstantiationError();
72*cdf0e10cSrcweir         }
73*cdf0e10cSrcweir     }
74*cdf0e10cSrcweir 
75*cdf0e10cSrcweir     // misc
76*cdf0e10cSrcweir     public int getColumnCount()
77*cdf0e10cSrcweir     {
78*cdf0e10cSrcweir         XColumnsSupplier suppCols = (XColumnsSupplier)UnoRuntime.queryInterface(
79*cdf0e10cSrcweir             XColumnsSupplier.class, m_rowSet );
80*cdf0e10cSrcweir         XIndexAccess columns = (XIndexAccess)UnoRuntime.queryInterface(
81*cdf0e10cSrcweir             XIndexAccess.class, suppCols.getColumns() );
82*cdf0e10cSrcweir         return columns.getCount();
83*cdf0e10cSrcweir     }
84*cdf0e10cSrcweir 
85*cdf0e10cSrcweir     // XRowSet
86*cdf0e10cSrcweir     public void execute() throws SQLException
87*cdf0e10cSrcweir     {
88*cdf0e10cSrcweir         m_rowSet.execute();
89*cdf0e10cSrcweir     }
90*cdf0e10cSrcweir 
91*cdf0e10cSrcweir     public void addRowSetListener( XRowSetListener _listener )
92*cdf0e10cSrcweir     {
93*cdf0e10cSrcweir         m_rowSet.addRowSetListener( _listener );
94*cdf0e10cSrcweir     }
95*cdf0e10cSrcweir 
96*cdf0e10cSrcweir     public void removeRowSetListener( XRowSetListener _listener )
97*cdf0e10cSrcweir     {
98*cdf0e10cSrcweir         m_rowSet.removeRowSetListener( _listener );
99*cdf0e10cSrcweir     }
100*cdf0e10cSrcweir 
101*cdf0e10cSrcweir     public boolean next() throws SQLException
102*cdf0e10cSrcweir     {
103*cdf0e10cSrcweir         return m_rowSet.next();
104*cdf0e10cSrcweir     }
105*cdf0e10cSrcweir 
106*cdf0e10cSrcweir     public boolean isBeforeFirst() throws SQLException
107*cdf0e10cSrcweir     {
108*cdf0e10cSrcweir         return m_rowSet.isBeforeFirst();
109*cdf0e10cSrcweir     }
110*cdf0e10cSrcweir 
111*cdf0e10cSrcweir     public boolean isAfterLast() throws SQLException
112*cdf0e10cSrcweir     {
113*cdf0e10cSrcweir         return m_rowSet.isAfterLast();
114*cdf0e10cSrcweir     }
115*cdf0e10cSrcweir 
116*cdf0e10cSrcweir     public boolean isFirst() throws SQLException
117*cdf0e10cSrcweir     {
118*cdf0e10cSrcweir         return m_rowSet.isFirst();
119*cdf0e10cSrcweir     }
120*cdf0e10cSrcweir 
121*cdf0e10cSrcweir     public boolean isLast() throws SQLException
122*cdf0e10cSrcweir     {
123*cdf0e10cSrcweir         return m_rowSet.isLast();
124*cdf0e10cSrcweir     }
125*cdf0e10cSrcweir 
126*cdf0e10cSrcweir     public void beforeFirst() throws SQLException
127*cdf0e10cSrcweir     {
128*cdf0e10cSrcweir         m_rowSet.beforeFirst();
129*cdf0e10cSrcweir     }
130*cdf0e10cSrcweir 
131*cdf0e10cSrcweir     public void afterLast() throws SQLException
132*cdf0e10cSrcweir     {
133*cdf0e10cSrcweir         m_rowSet.afterLast();
134*cdf0e10cSrcweir     }
135*cdf0e10cSrcweir 
136*cdf0e10cSrcweir     public boolean first() throws SQLException
137*cdf0e10cSrcweir     {
138*cdf0e10cSrcweir         return m_rowSet.first();
139*cdf0e10cSrcweir     }
140*cdf0e10cSrcweir 
141*cdf0e10cSrcweir     public boolean last() throws SQLException
142*cdf0e10cSrcweir     {
143*cdf0e10cSrcweir         return m_rowSet.last();
144*cdf0e10cSrcweir     }
145*cdf0e10cSrcweir 
146*cdf0e10cSrcweir     public int getRow() throws SQLException
147*cdf0e10cSrcweir     {
148*cdf0e10cSrcweir         return m_rowSet.getRow();
149*cdf0e10cSrcweir     }
150*cdf0e10cSrcweir 
151*cdf0e10cSrcweir     public boolean absolute(int i) throws SQLException
152*cdf0e10cSrcweir     {
153*cdf0e10cSrcweir         return m_rowSet.absolute(i);
154*cdf0e10cSrcweir     }
155*cdf0e10cSrcweir 
156*cdf0e10cSrcweir     public boolean relative(int i) throws SQLException
157*cdf0e10cSrcweir     {
158*cdf0e10cSrcweir         return m_rowSet.relative(i);
159*cdf0e10cSrcweir     }
160*cdf0e10cSrcweir 
161*cdf0e10cSrcweir     public boolean previous() throws SQLException
162*cdf0e10cSrcweir     {
163*cdf0e10cSrcweir         return m_rowSet.previous();
164*cdf0e10cSrcweir     }
165*cdf0e10cSrcweir 
166*cdf0e10cSrcweir     public void refreshRow() throws SQLException
167*cdf0e10cSrcweir     {
168*cdf0e10cSrcweir         m_rowSet.refreshRow();
169*cdf0e10cSrcweir     }
170*cdf0e10cSrcweir 
171*cdf0e10cSrcweir     public boolean rowUpdated() throws SQLException
172*cdf0e10cSrcweir     {
173*cdf0e10cSrcweir         return m_rowSet.rowUpdated();
174*cdf0e10cSrcweir     }
175*cdf0e10cSrcweir 
176*cdf0e10cSrcweir     public boolean rowInserted() throws SQLException
177*cdf0e10cSrcweir     {
178*cdf0e10cSrcweir         return m_rowSet.rowInserted();
179*cdf0e10cSrcweir     }
180*cdf0e10cSrcweir 
181*cdf0e10cSrcweir     public boolean rowDeleted() throws SQLException
182*cdf0e10cSrcweir     {
183*cdf0e10cSrcweir         return m_rowSet.rowDeleted();
184*cdf0e10cSrcweir     }
185*cdf0e10cSrcweir 
186*cdf0e10cSrcweir     // XRow
187*cdf0e10cSrcweir     public Object getStatement() throws SQLException
188*cdf0e10cSrcweir     {
189*cdf0e10cSrcweir         return m_rowSet.getStatement();
190*cdf0e10cSrcweir     }
191*cdf0e10cSrcweir 
192*cdf0e10cSrcweir     public boolean wasNull() throws SQLException
193*cdf0e10cSrcweir     {
194*cdf0e10cSrcweir         return m_row.wasNull();
195*cdf0e10cSrcweir     }
196*cdf0e10cSrcweir 
197*cdf0e10cSrcweir     public String getString(int i) throws SQLException
198*cdf0e10cSrcweir     {
199*cdf0e10cSrcweir         return m_row.getString(i);
200*cdf0e10cSrcweir     }
201*cdf0e10cSrcweir 
202*cdf0e10cSrcweir     public boolean getBoolean(int i) throws SQLException
203*cdf0e10cSrcweir     {
204*cdf0e10cSrcweir         return m_row.getBoolean(i);
205*cdf0e10cSrcweir     }
206*cdf0e10cSrcweir 
207*cdf0e10cSrcweir     public byte getByte(int i) throws SQLException
208*cdf0e10cSrcweir     {
209*cdf0e10cSrcweir         return m_row.getByte(i);
210*cdf0e10cSrcweir     }
211*cdf0e10cSrcweir 
212*cdf0e10cSrcweir     public short getShort(int i) throws SQLException
213*cdf0e10cSrcweir     {
214*cdf0e10cSrcweir         return m_row.getShort(i);
215*cdf0e10cSrcweir     }
216*cdf0e10cSrcweir 
217*cdf0e10cSrcweir     public int getInt(int i) throws SQLException
218*cdf0e10cSrcweir     {
219*cdf0e10cSrcweir         return m_row.getInt(i);
220*cdf0e10cSrcweir     }
221*cdf0e10cSrcweir 
222*cdf0e10cSrcweir     public long getLong(int i) throws SQLException
223*cdf0e10cSrcweir     {
224*cdf0e10cSrcweir         return m_row.getLong(i);
225*cdf0e10cSrcweir     }
226*cdf0e10cSrcweir 
227*cdf0e10cSrcweir     public float getFloat(int i) throws SQLException
228*cdf0e10cSrcweir     {
229*cdf0e10cSrcweir         return m_row.getFloat(i);
230*cdf0e10cSrcweir     }
231*cdf0e10cSrcweir 
232*cdf0e10cSrcweir     public double getDouble(int i) throws SQLException
233*cdf0e10cSrcweir     {
234*cdf0e10cSrcweir         return m_row.getDouble(i);
235*cdf0e10cSrcweir     }
236*cdf0e10cSrcweir 
237*cdf0e10cSrcweir     public byte[] getBytes(int i) throws SQLException
238*cdf0e10cSrcweir     {
239*cdf0e10cSrcweir         return m_row.getBytes(i);
240*cdf0e10cSrcweir     }
241*cdf0e10cSrcweir 
242*cdf0e10cSrcweir     public Date getDate(int i) throws SQLException
243*cdf0e10cSrcweir     {
244*cdf0e10cSrcweir         return m_row.getDate(i);
245*cdf0e10cSrcweir     }
246*cdf0e10cSrcweir 
247*cdf0e10cSrcweir     public Time getTime(int i) throws SQLException
248*cdf0e10cSrcweir     {
249*cdf0e10cSrcweir         return m_row.getTime(i);
250*cdf0e10cSrcweir     }
251*cdf0e10cSrcweir 
252*cdf0e10cSrcweir     public DateTime getTimestamp(int i) throws SQLException
253*cdf0e10cSrcweir     {
254*cdf0e10cSrcweir         return m_row.getTimestamp(i);
255*cdf0e10cSrcweir     }
256*cdf0e10cSrcweir 
257*cdf0e10cSrcweir     public XInputStream getBinaryStream(int i) throws SQLException
258*cdf0e10cSrcweir     {
259*cdf0e10cSrcweir         return m_row.getBinaryStream(i);
260*cdf0e10cSrcweir     }
261*cdf0e10cSrcweir 
262*cdf0e10cSrcweir     public XInputStream getCharacterStream(int i) throws SQLException
263*cdf0e10cSrcweir     {
264*cdf0e10cSrcweir         return m_row.getCharacterStream(i);
265*cdf0e10cSrcweir     }
266*cdf0e10cSrcweir 
267*cdf0e10cSrcweir     public Object getObject(int i, XNameAccess xNameAccess) throws SQLException
268*cdf0e10cSrcweir     {
269*cdf0e10cSrcweir         return m_row.getObject(i, xNameAccess);
270*cdf0e10cSrcweir     }
271*cdf0e10cSrcweir 
272*cdf0e10cSrcweir     public XRef getRef(int i) throws SQLException
273*cdf0e10cSrcweir     {
274*cdf0e10cSrcweir         return m_row.getRef(i);
275*cdf0e10cSrcweir     }
276*cdf0e10cSrcweir 
277*cdf0e10cSrcweir     public XBlob getBlob(int i) throws SQLException
278*cdf0e10cSrcweir     {
279*cdf0e10cSrcweir         return m_row.getBlob(i);
280*cdf0e10cSrcweir     }
281*cdf0e10cSrcweir 
282*cdf0e10cSrcweir     public XClob getClob(int i) throws SQLException
283*cdf0e10cSrcweir     {
284*cdf0e10cSrcweir         return m_row.getClob(i);
285*cdf0e10cSrcweir     }
286*cdf0e10cSrcweir 
287*cdf0e10cSrcweir     public XArray getArray(int i) throws SQLException
288*cdf0e10cSrcweir     {
289*cdf0e10cSrcweir         return m_row.getArray(i);
290*cdf0e10cSrcweir     }
291*cdf0e10cSrcweir 
292*cdf0e10cSrcweir     public void dispose()
293*cdf0e10cSrcweir     {
294*cdf0e10cSrcweir         if ( m_rowSet == null )
295*cdf0e10cSrcweir             return;
296*cdf0e10cSrcweir         XComponent rowSetComp = UnoRuntime.queryInterface( XComponent.class, m_rowSet );
297*cdf0e10cSrcweir         rowSetComp.dispose();
298*cdf0e10cSrcweir     }
299*cdf0e10cSrcweir };
300