/* * DBeaver - Universal Database Manager * Copyright (C) 2010-2017 Serge Rider (serge@jkiss.org) * Copyright (C) 2011-2012 Eugene Fradkin (eugene.fradkin@gmail.com) * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.jkiss.dbeaver.ext.postgresql.tools.maintenance; import org.eclipse.swt.layout.GridData; import org.eclipse.swt.widgets.Button; import org.eclipse.swt.widgets.Composite; import org.eclipse.swt.widgets.Group; import org.eclipse.ui.IWorkbenchPart; import org.eclipse.ui.IWorkbenchPartSite; import org.eclipse.ui.IWorkbenchWindow; import org.jkiss.dbeaver.DBException; import org.jkiss.dbeaver.ext.postgresql.model.PostgreObject; import org.jkiss.dbeaver.ext.postgresql.model.PostgreTableBase; import org.jkiss.dbeaver.model.DBPEvaluationContext; import org.jkiss.dbeaver.model.struct.DBSObject; import org.jkiss.dbeaver.tools.IExternalTool; import org.jkiss.dbeaver.ui.UIUtils; import org.jkiss.utils.CommonUtils; import java.util.Collection; import java.util.List; /** * Table truncate */ public class PostgreToolTruncate implements IExternalTool { @Override public void execute(IWorkbenchWindow window, IWorkbenchPart activePart, Collection<DBSObject> objects) throws DBException { List<PostgreTableBase> tables = CommonUtils.filterCollection(objects, PostgreTableBase.class); if (!tables.isEmpty()) { SQLDialog dialog = new SQLDialog(activePart.getSite(), tables); dialog.open(); } } static class SQLDialog extends TableToolDialog { private Button onlyCheck; private Button restartIdentityCheck; private Button cascadeCheck; public SQLDialog(IWorkbenchPartSite partSite, Collection<PostgreTableBase> selectedTables) { super(partSite, "Truncate table(s)", selectedTables); } @Override protected void generateObjectCommand(List<String> lines, PostgreObject object) { if (object instanceof PostgreTableBase) { String sql = "TRUNCATE TABLE"; if (onlyCheck.getSelection()) sql += " ONLY"; sql += " " + ((PostgreTableBase) object).getFullyQualifiedName(DBPEvaluationContext.DDL); if (restartIdentityCheck.getSelection()) sql += " RESTART IDENTITY"; else sql += " CONTINUE IDENTITY"; if (cascadeCheck.getSelection()) sql += " CASCADE"; else sql += " RESTRICT"; lines.add(sql); } } @Override protected void createControls(Composite parent) { Group optionsGroup = UIUtils.createControlGroup(parent, "Options", 1, 0, 0); optionsGroup.setLayoutData(new GridData(GridData.FILL_HORIZONTAL)); onlyCheck = UIUtils.createCheckbox(optionsGroup, "Only", "If ONLY is not specified, the table and all its descendant tables (if any) are truncated.", false, 0); onlyCheck.addSelectionListener(SQL_CHANGE_LISTENER); restartIdentityCheck = UIUtils.createCheckbox(optionsGroup, "Restart identity", "Automatically restart sequences owned by columns of the truncated table(s).", false, 0); restartIdentityCheck.addSelectionListener(SQL_CHANGE_LISTENER); cascadeCheck = UIUtils.createCheckbox(optionsGroup, "Cascade", "Automatically truncate all tables that have foreign-key references to any of the named tables, or to any tables added to the group due to CASCADE.", false, 0); cascadeCheck.addSelectionListener(SQL_CHANGE_LISTENER); createObjectsSelector(parent); } @Override protected boolean needsRefreshOnFinish() { return true; } } }