/** * Copyright (C) 2000 - 2009 Silverpeas * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * As a special exception to the terms and conditions of version 3.0 of * the GPL, you may redistribute this Program in connection with Free/Libre * Open Source Software ("FLOSS") applications as described in Silverpeas's * FLOSS exception. You should have received a copy of the text describing * the FLOSS exception, and it is also available here: * "http://repository.silverpeas.com/legal/licensing" * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package org.silverpeas.dbbuilder.sql; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.SQLException; /** * @author ehugonnet */ public class RemoveSQLInstruction implements SQLInstruction { public static final String DELETE_DEPENDENCIES = "delete from SR_DEPENDENCIES where SR_PACKAGE = ?"; public static final String DELETE_SCRIPTS = "delete from SR_SCRIPTS where SR_ITEM_ID IN " + "(SELECT SRU.SR_ITEM_ID from SR_UNINSTITEMS SRU where SRU.SR_PACKAGE = ?)"; public static final String DELETE_UNINSTITEMS = "delete from SR_UNINSTITEMS where SR_PACKAGE = ?"; public static final String DELETE_PACKAGE = "delete from SR_PACKAGES where SR_PACKAGE= ?"; private String packageName; public RemoveSQLInstruction(String packageName) { this.packageName = packageName; } @Override public void execute(Connection connection) throws SQLException { PreparedStatement pstmt = connection.prepareStatement(DELETE_DEPENDENCIES); pstmt.setString(1, packageName); pstmt.executeUpdate(); pstmt.close(); pstmt = connection.prepareStatement(DELETE_SCRIPTS); pstmt.setString(1, packageName); pstmt.executeUpdate(); pstmt.close(); pstmt = connection.prepareStatement(DELETE_UNINSTITEMS); pstmt.setString(1, packageName); pstmt.executeUpdate(); pstmt.close(); pstmt = connection.prepareStatement(DELETE_PACKAGE); pstmt.setString(1, packageName); pstmt.executeUpdate(); pstmt.close(); } }