Apply a UDF
Jump to the Code block for a combined complete example.
UDFs that execute on a single record are Record UDFs. The record may or may not exist in the database, and the UDF may create, read, and/or update a record.
Setup
The following examples will use the setup below to illustrate applying a record UDF.
import com.aerospike.client.AerospikeClient;import com.aerospike.client.Key;import com.aerospike.client.Record;import com.aerospike.client.Value;import com.aerospike.client.BatchRecord;import com.aerospike.client.BatchResults;import com.aerospike.client.exp.Exp;import com.aerospike.client.policy.WritePolicy;import com.aerospike.client.task.ExecuteTask;
// Establishes a connection to the serverAerospikeClient client = new AerospikeClient("127.0.0.1", 3000);
The record structure:
Occurred: IntegerReported: IntegerPosted: IntegerReport: Map{ shape: List, summary: String, city: String, state: String, duration: String}Location: GeoJSON
Single record commands
Single argument
This example uses the setRecent
function in the module example.lua
.
See Manage UDFs for example.lua
code and information on registering the UDF.
This compares the posted
bin to a supplied value and writes true
/false
to a recent
bin based on the result.
// Creates a key with the namespace "sandbox", set "ufodata", and user key 5000Key key = new Key("sandbox", "ufodata", 5000);
// Execute the UDFObject result = client.execute( null, key, "example", "setRecent", Value.get(20210101));
// View the updated recordRecord record = client.get(null, key);System.out.format("Record: %s", record.bins);
// Close the connection to the serverclient.close();
Multiple argument
This example uses the getDaysBetween
function in the module example.lua
.
See Manage UDFs for example.lua
code and information on registering the UDF.
This compares two dates, provived by passing the bin names with the date values, and returns the days between. The following example will return the days between the sighting occurence and posting to the site.
// Creates a key with the namespace "sandbox", set "ufodata", and user key 5000Key key = new Key("sandbox", "ufodata", 5000);
// Execute the UDFObject result = client.execute( null, key, "example", "getDaysBetween", Value.get("occurred"), Value.get("posted"));
// Do somethingSystem.out.format("%s days between occurrence and post", result);
// Close the connection to the serverclient.close();
Batch operation with a UDF
This example will use the multi-argument example from above, and apply it to a batch of records.
// Create batch of keysKey[] keys = new Key[10];for (int i = 0; i < 10; i++) { keys[i] = new Key("sandbox", "ufodata", (i + 100));}
// Execute the UDFBatchResults batchResult = client.execute( null, null, keys, "example", "getDaysBetween", Value.get("occurred"), Value.get("posted"));
// Access the resultsfor (BatchRecord batchRecord : batchResult.records){ Record record = batchRecord.record; if(record != null){ // Do something System.out.format("%s days between occurrence and post\n", record.bins.get("SUCCESS")); }}// Close the connection to the serverclient.close();
Background query with a UDF
This example will use the single argument example from above, and apply it to all records that match a Filter Expression through a background query.
// Create the policyWritePolicy writePolicy = new WritePolicy();// Build the expressionwritePolicy.filterExp = Exp.build( Exp.binExists("posted"));
// Create statementStatement stmt = new Statement();
// Set namespace and set namestmt.setNamespace("sandbox");stmt.setSetName("ufodata");
ExecuteTask task = client.execute( writePolicy, stmt, "example", "setRecent", Value.get(20210101));
// Return the query statusint status = task.queryStatus();
String queryStatus;switch (status){ case 0: queryStatus = "not found"; break; case 1: queryStatus = "in progress"; break; case 2: queryStatus = "complete"; break;}System.out.format("Query %s.", queryStatus);
// Close the connection to the serverclient.close();
Code block
Expand this section for a single code block to apply a record UDF
import com.aerospike.client.AerospikeClient;import com.aerospike.client.Key;import com.aerospike.client.Record;import com.aerospike.client.Value;import com.aerospike.client.BatchRecord;import com.aerospike.client.BatchResults;import com.aerospike.client.exp.Exp;import com.aerospike.client.policy.WritePolicy;import com.aerospike.client.task.ExecuteTask;
// Establishes a connection to the serverAerospikeClient client = new AerospikeClient("127.0.0.1", 3000);
// Creates a key with the namespace "sandbox", set "ufodata", and user key 5000Key key = new Key("sandbox", "ufodata", 5000);
// Execute the UDFObject result = client.execute( null, key, "example", "getDaysBetween", Value.get("occurred"), Value.get("posted"));
// Do somethingSystem.out.format("%s days between occurrence and post", result);
// Close the connection to the serverclient.close();