Aerospike - 使用多个过滤器查询

时间:2015-07-24 09:16:40

标签: java aerospike

我正在尝试使用多个过滤器查询aerospike,参考下面提到的链接...

https://www.aerospike.com/community/labs/query_multiple_filters.html

在上面的线程中提出的示例中,使用的aerospike-client版本是3.0.22,我在我的项目中使用的是3.0.0版本。 我可以在aerospike网站上查询数据库并检索所需的数据,但是当我在项目中运行相同的代码时,不会返回任何数据。

版本3.0.0中是否支持用于数据检索的lua脚本和聚合函数?如果是,是否还有其他方法可以使用3.0.0版查询相同内容?

Lua Script

local function map_order(record)
return map {key=record.key, mid=record.mid, orderId=record.orderId, amount=record.amount}
end

function filter_order(stream, mid)
  local function filter_mid(record)
    return record.mid == mid
  end

  return stream : filter(filter_mid) : map(map_order)

end

数据检索代码

ResultSet resultSet = client.queryAggregate(null, stmt, "profile", "filter_order", Value.get("mid334"));

编辑:获取此例外

com.aerospike.client.AerospikeException: Failed to read file: /home/lalit/spring-suite/sts-bundle/sts-3.6.3.RELEASE/udf/profile.lua

文件位于/home/lalit/udf/profile.udf

用于注册lua文件的代码

 LuaConfig.SourceDirectory = "udf";
 udfFile = new File("/home/lalit/udf/profile.lua");
 task = client.getAerospikeClient().register(null, udfFile.getPath(), udfFile.getName(), Language.LUA); 
 task.waitTillComplete();

1 个答案:

答案 0 :(得分:2)

管理解决它。

QueryAggregateExecutor的

运行方法从文件系统加载 lua 函数,其中它使用LuaConfig.SourceDirectory变量来定位脚本文件的路径。

我正在通过 udf

LuaConfig.SourceDirectory = "udf"

应该是 / home / lalit / udf

LuaConfig.SourceDirectory = "/home/lalit/udf"