KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > caucho > db > sql > ExistsQuery


1 /*
2  * Copyright (c) 1998-2006 Caucho Technology -- all rights reserved
3  *
4  * This file is part of Resin(R) Open Source
5  *
6  * Each copy or derived work must preserve the copyright notice and this
7  * notice unmodified.
8  *
9  * Resin Open Source is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 2 of the License, or
12  * (at your option) any later version.
13  *
14  * Resin Open Source is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty
17  * of NON-INFRINGEMENT. See the GNU General Public License for more
18  * details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with Resin Open Source; if not, write to the
22  * Free SoftwareFoundation, Inc.
23  * 59 Temple Place, Suite 330
24  * Boston, MA 02111-1307 USA
25  *
26  * @author Scott Ferguson
27  */

28
29 package com.caucho.db.sql;
30
31 import com.caucho.db.Database;
32 import com.caucho.db.store.Transaction;
33 import com.caucho.db.table.TableIterator;
34 import com.caucho.log.Log;
35 import com.caucho.sql.SQLExceptionWrapper;
36
37 import java.io.IOException JavaDoc;
38 import java.sql.SQLException JavaDoc;
39 import java.util.logging.Logger JavaDoc;
40
41 public class ExistsQuery extends SelectQuery {
42   private static final Logger JavaDoc log = Log.open(ExistsQuery.class);
43
44   private static Expr []_nullExprs = new Expr[0];
45
46   protected ExistsQuery(Database db, String JavaDoc sql)
47     throws SQLException JavaDoc
48   {
49     super(db, sql);
50   }
51
52   /**
53    * Executes the query.
54    */

55   public boolean exists(QueryContext context, Transaction xa)
56     throws SQLException JavaDoc
57   {
58     SelectResult result = SelectResult.create(_nullExprs, null);
59
60     try {
61       TableIterator []rows = result.initRows(getFromItems());
62       context.init(xa, rows, isReadOnly());
63
64       return execute(result, rows, context, xa);
65     } catch (IOException JavaDoc e) {
66       throw new SQLExceptionWrapper(e);
67     } finally {
68       context.unlock();
69
70       result.close();
71     }
72   }
73   
74   /**
75    * Executes the query.
76    */

77   private boolean execute(SelectResult result,
78                TableIterator []rows,
79                QueryContext context,
80                Transaction transaction)
81     throws SQLException JavaDoc, IOException JavaDoc
82   {
83     FromItem []fromItems = getFromItems();
84     int rowLength = fromItems.length;
85     
86     return start(rows, rowLength, context, transaction);
87   }
88
89   /**
90    * Executes the query.
91    */

92   public void execute(QueryContext queryCtx, Transaction xa)
93     throws SQLException JavaDoc
94   {
95     throw new UnsupportedOperationException JavaDoc();
96   }
97 }
98
Popular Tags