/**
* 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();
}
}