अपाचे प्रेस्टो - कस्टम फंक्शन एप्लीकेशन

प्रेस्टो कस्टम फ़ंक्शन को विकसित करने के लिए एक मैवेन प्रोजेक्ट बनाएं।

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