hive
Hive User Defined Functions (UDF's)
Zoeken…
Bijenkorf UDF creatie
Om een UDF te maken, moeten we de klasse UDF ( org.apache.hadoop.hive.ql.exec.UDF
) uitbreiden en de evaluatiemethode implementeren.
Zodra UDF is nageleefd en JAR is gebouwd, moeten we jar toevoegen aan component component om een tijdelijke / permanente functie te creëren.
import org.apache.hadoop.hive.ql.exec.UDF;
class UDFExample extends UDF {
public String evaluate(String input) {
return new String("Hello " + input);
}
}
hive> ADD JAR <JAR NAME>.jar;
hive> CREATE TEMPORARY FUNCTION helloworld as 'package.name.UDFExample';
hive> select helloworld(name) from test;
Hive UDF om de gegeven string bij te knippen.
package MyHiveUDFs;
import org.apache.commons.lang.StringUtils;
import org.apache.hadoop.hive.ql.exec.UDF;
import org.apache.hadoop.io.Text;
public class Strip extends UDF {
private Text result = new Text();
public Text evaluate(Text str) {
if(str == null) {
return null;
}
result.set(StringUtils.strip(str.toString()));
return result;
}
}
exporteer het bovenstaande naar jar-bestand
Ga naar de Hive CLI en voeg de UDF JAR toe
hive> ADD jar /home/cloudera/Hive/hive_udf_trim.jar;
Controleer of JAR zich in Hive CLI Classpath bevindt
hive> list jars;
/home/cloudera/Hive/hive_udf_trim.jar
Maak tijdelijke functie
hive> CREATE TEMPORARY FUNCTION STRIP AS 'MyHiveUDFs.Strip';
UDF-uitgang
hive> select strip(' hiveUDF ') from dummy;
OK
hiveUDF
Modified text is an extract of the original Stack Overflow Documentation
Licentie onder CC BY-SA 3.0
Niet aangesloten bij Stack Overflow