org.apache.hadoop.hive.metastore.events.InsertEvent Maven / Gradle / Ivy
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.hadoop.hive.metastore.events;
import org.apache.hadoop.hive.metastore.HiveMetaStore.HMSHandler;
import org.apache.hadoop.hive.metastore.api.FieldSchema;
import org.apache.hadoop.hive.metastore.api.MetaException;
import org.apache.hadoop.hive.metastore.api.NoSuchObjectException;
import org.apache.hadoop.hive.metastore.api.Table;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
public class InsertEvent extends ListenerEvent {
// Note that this event is fired from the client, so rather than having full metastore objects
// we have just the string names, but that's fine for what we need.
private final String db;
private final String table;
private final Map keyValues;
private final List files;
/**
*
* @param db name of the database the table is in
* @param table name of the table being inserted into
* @param partVals list of partition values, can be null
* @param status status of insert, true = success, false = failure
* @param handler handler that is firing the event
*/
public InsertEvent(String db, String table, List partVals, List files,
boolean status, HMSHandler handler) throws MetaException, NoSuchObjectException {
super(status, handler);
this.db = db;
this.table = table;
this.files = files;
Table t = handler.get_table(db,table);
keyValues = new LinkedHashMap();
if (partVals != null) {
for (int i = 0; i < partVals.size(); i++) {
keyValues.put(t.getPartitionKeys().get(i).getName(), partVals.get(i));
}
}
}
public String getDb() {
return db;
}
/**
* @return The table.
*/
public String getTable() {
return table;
}
/**
* @return List of values for the partition keys.
*/
public Map getPartitionKeyValues() {
return keyValues;
}
/**
* Get list of files created as a result of this DML operation
* @return list of new files
*/
public List getFiles() {
return files;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy