Quadcap Embeddable Database

com/quadcap/sql/AddTable.java

Go to the documentation of this file.
00001 package com.quadcap.sql; 00002 00003 /* Copyright 1999 - 2003 Quadcap Software. All rights reserved. 00004 * 00005 * This software is distributed under the Quadcap Free Software License. 00006 * This software may be used or modified for any purpose, personal or 00007 * commercial. Open Source redistributions are permitted. Commercial 00008 * redistribution of larger works derived from, or works which bundle 00009 * this software requires a "Commercial Redistribution License"; see 00010 * http://www.quadcap.com/purchase. 00011 * 00012 * Redistributions qualify as "Open Source" under one of the following terms: 00013 * 00014 * Redistributions are made at no charge beyond the reasonable cost of 00015 * materials and delivery. 00016 * 00017 * Redistributions are accompanied by a copy of the Source Code or by an 00018 * irrevocable offer to provide a copy of the Source Code for up to three 00019 * years at the cost of materials and delivery. Such redistributions 00020 * must allow further use, modification, and redistribution of the Source 00021 * Code under substantially the same terms as this license. 00022 * 00023 * Redistributions of source code must retain the copyright notices as they 00024 * appear in each source code file, these license terms, and the 00025 * disclaimer/limitation of liability set forth as paragraph 6 below. 00026 * 00027 * Redistributions in binary form must reproduce this Copyright Notice, 00028 * these license terms, and the disclaimer/limitation of liability set 00029 * forth as paragraph 6 below, in the documentation and/or other materials 00030 * provided with the distribution. 00031 * 00032 * The Software is provided on an "AS IS" basis. No warranty is 00033 * provided that the Software is free of defects, or fit for a 00034 * particular purpose. 00035 * 00036 * Limitation of Liability. Quadcap Software shall not be liable 00037 * for any damages suffered by the Licensee or any third party resulting 00038 * from use of the Software. 00039 */ 00040 00041 import java.io.Externalizable; 00042 import java.io.IOException; 00043 import java.io.ObjectInput; 00044 import java.io.ObjectOutput; 00045 import java.io.OutputStream; 00046 00047 import java.sql.SQLException; 00048 00049 import com.quadcap.util.Debug; 00050 import com.quadcap.sql.io.Extern; 00051 00052 /** 00053 * Log step to add a table to a database. 00054 * 00055 * @author Stan Bailes 00056 */ 00057 public class AddTable extends LogStep implements Externalizable { 00058 Relation table; 00059 00060 /** 00061 * Default constructor 00062 */ 00063 public AddTable() {} 00064 00065 /** 00066 * Explicit constructor from table 00067 */ 00068 public AddTable(Session session, Relation table) { 00069 super(session); 00070 this.table = table; 00071 } 00072 00073 /** 00074 * LogStep.redo(): Add the table to the database 00075 */ 00076 public void redo(Session session) throws IOException, SQLException { 00077 Database db = session.getDatabase(); 00078 db.addRelation(table); 00079 } 00080 00081 /** 00082 * LogStep.undo(): Remove the table from the database 00083 */ 00084 public void undo(Session session) throws IOException, SQLException { 00085 Database db = session.getDatabase(); 00086 db.removeRelation(table.getName()); 00087 } 00088 00089 /** 00090 * LogStep.prepare(): We check for already-existing table and throw 00091 * exception early, rather than let the user proceed under false 00092 * illusions. 00093 */ 00094 public void prepare(Session session) throws IOException, SQLException { 00095 Database db = session.getDatabase(); 00096 if (db.getRelation(table.getName()) != null) { 00097 throw new SQLException("Table/view already exists: " + 00098 table.getName(), 00099 "42000"); 00100 } 00101 } 00102 00103 /** 00104 * Read me from a stream 00105 */ 00106 public void readExternal(ObjectInput in) 00107 throws IOException, ClassNotFoundException 00108 { 00109 super.readExternal(in); 00110 table = (Relation)in.readObject(); 00111 } 00112 00113 /** 00114 * Write me to a stream 00115 */ 00116 public void writeExternal(ObjectOutput out) throws IOException { 00117 super.writeExternal(out); 00118 out.writeObject(table); 00119 } 00120 00121 //#ifdef DEBUG 00122 /** 00123 * Return a displayable representation for debugging 00124 */ 00125 public String toString() { 00126 StringBuffer sb = new StringBuffer(super.toString()); 00127 sb.append(" AddTable("); 00128 sb.append(table.toString()); 00129 sb.append(')'); 00130 return sb.toString(); 00131 } 00132 //#endif 00133 00134 static Extern extern; 00135 public void setExtern(Extern extern) { AddTable.extern = extern; } 00136 public Extern getExtern() { return extern; } 00137 }