अपाचे प्रेस्टो - कस्टम फंक्शन एप्लीकेशन
प्रेस्टो कस्टम फ़ंक्शन को विकसित करने के लिए एक मैवेन प्रोजेक्ट बनाएं।
SimpleFunctionsFactory.java
फ़ंक्शन को लागू करने के लिए SimpleFunctionsFactory क्लास बनाएँ।
package com.tutorialspoint.simple.functions;
import com.facebook.presto.metadata.FunctionFactory;
import com.facebook.presto.metadata.FunctionListBuilder;
import com.facebook.presto.metadata.SqlFunction;
import com.facebook.presto.spi.type.TypeManager;
import java.util.List;
public class SimpleFunctionFactory implements FunctionFactory {
private final TypeManager typeManager;
public SimpleFunctionFactory(TypeManager typeManager) {
this.typeManager = typeManager;
}
@Override
public List<SqlFunction> listFunctions() {
return new FunctionListBuilder(typeManager)
.scalar(SimpleFunctions.class)
.getFunctions();
}
}
SimpleFunctionsPlugin.java
प्लगइन इंटरफेस को लागू करने के लिए एक SimpleFunctionsPlugin वर्ग बनाएँ।
package com.tutorialspoint.simple.functions;
import com.facebook.presto.metadata.FunctionFactory;
import com.facebook.presto.spi.Plugin;
import com.facebook.presto.spi.type.TypeManager;
import com.google.common.collect.ImmutableList;
import javax.inject.Inject;
import java.util.List;
import static java.util.Objects.requireNonNull;
public class SimpleFunctionsPlugin implements Plugin {
private TypeManager typeManager;
@Inject
public void setTypeManager(TypeManager typeManager) {
this.typeManager = requireNonNull(typeManager, "typeManager is null”);
//Inject TypeManager class here
}
@Override
public <T> List<T> getServices(Class<T> type){
if (type == FunctionFactory.class) {
return ImmutableList.of(type.cast(new SimpleFunctionFactory(typeManager)));
}
return ImmutableList.of();
}
}
संसाधन फ़ाइल जोड़ें
एक संसाधन फ़ाइल बनाएँ जो कार्यान्वयन पैकेज में निर्दिष्ट है।
(com.tutorialspoint.simple.functions.SimpleFunctionsPlugin)
अब संसाधन फ़ाइल स्थान @ / पथ / से / संसाधन / पर जाएँ
फिर परिवर्तन जोड़ें,
com.facebook.presto.spi.Plugin
pom.xml
Pom.xml फ़ाइल के लिए निम्न निर्भरताएँ जोड़ें।
<?xml version = "1.0"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.tutorialspoint.simple.functions</groupId>
<artifactId>presto-simple-functions</artifactId>
<packaging>jar</packaging>
<version>1.0</version>
<name>presto-simple-functions</name>
<description>Simple test functions for Presto</description>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>com.facebook.presto</groupId>
<artifactId>presto-spi</artifactId>
<version>0.149</version>
</dependency>
<dependency>
<groupId>com.facebook.presto</groupId>
<artifactId>presto-main</artifactId>
<version>0.149</version>
</dependency>
<dependency>
<groupId>javax.inject</groupId>
<artifactId>javax.inject</artifactId>
<version>1</version>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>19.0</version>
</dependency>
</dependencies>
<build>
<finalName>presto-simple-functions</finalName>
<plugins>
<!-- Make this jar executable -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.3.2</version>
</plugin>
</plugins>
</build>
</project>
SimpleFunctions.java
Presto विशेषताओं का उपयोग करके SimpleFunctions वर्ग बनाएँ।
package com.tutorialspoint.simple.functions;
import com.facebook.presto.operator.Description;
import com.facebook.presto.operator.scalar.ScalarFunction;
import com.facebook.presto.operator.scalar.StringFunctions;
import com.facebook.presto.spi.type.StandardTypes;
import com.facebook.presto.type.LiteralParameters;
import com.facebook.presto.type.SqlType;
public final class SimpleFunctions {
private SimpleFunctions() {
}
@Description("Returns summation of two numbers")
@ScalarFunction(“mysum")
//function name
@SqlType(StandardTypes.BIGINT)
public static long sum(@SqlType(StandardTypes.BIGINT) long num1,
@SqlType(StandardTypes.BIGINT) long num2) {
return num1 + num2;
}
}
एप्लिकेशन तैयार होने के बाद एप्लिकेशन को कंपाइल करें और निष्पादित करें। यह JAR फ़ाइल का उत्पादन करेगा। फ़ाइल को कॉपी करें और JAR फ़ाइल को लक्ष्य प्रेस्टो सर्वर प्लगइन निर्देशिका में स्थानांतरित करें।
संकलन
mvn compile
क्रियान्वयन
mvn package
अब प्रेस्टो सर्वर को रीस्टार्ट करें और प्रेस्टो क्लाइंट को कनेक्ट करें। फिर नीचे बताए अनुसार कस्टम फंक्शन एप्लिकेशन को निष्पादित करें,
$ ./presto --catalog mysql --schema default
सवाल
presto:default> select mysum(10,10);
परिणाम
_col0
-------
20