/* This file is part of VoltDB.
* Copyright (C) 2008-2010 VoltDB L.L.C.
*
* VoltDB is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* VoltDB 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with VoltDB. If not, see <http://www.gnu.org/licenses/>.
*/
package org.voltdb.plannodes;
import org.json.JSONException;
import org.json.JSONObject;
import org.json.JSONStringer;
import org.voltdb.catalog.Database;
import org.voltdb.planner.PlannerContext;
import org.voltdb.types.PlanNodeType;
/**
*
*/
public class InsertPlanNode extends AbstractOperationPlanNode {
public enum Members {
MULTI_PARTITION;
}
private boolean m_multiPartition = false;
/**
* @param id
*/
public InsertPlanNode(PlannerContext context, Integer id) {
super(context, id);
}
public boolean getMultiPartition() {
return m_multiPartition;
}
public void setMultiPartition(boolean multiPartition) {
m_multiPartition = multiPartition;
}
@Override
public PlanNodeType getPlanNodeType() {
return PlanNodeType.INSERT;
}
@Override
public void toJSONString(JSONStringer stringer) throws JSONException {
super.toJSONString(stringer);
stringer.key(Members.MULTI_PARTITION.name()).value(m_multiPartition);
}
@Override
protected void loadFromJSONObject(JSONObject obj, Database db) throws JSONException {
super.loadFromJSONObject(obj, db);
m_multiPartition = obj.getBoolean(Members.MULTI_PARTITION.name());
}
}