首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有多个过滤器的航空公司查询

带有多个过滤器的航空公司查询
EN

Stack Overflow用户
提问于 2015-07-24 09:16:40
回答 1查看 544关注 0票数 0

我试着用多个过滤器查询机场,参考下面提到的链接.

filters.html

在上述线程中提出的示例中,使用的aerospike客户端版本为3.0.22,而我在项目中使用的是3.0.0版本。我能够查询数据库并检索所需的数据,更改aerospike网站上提到的示例,但是当我在项目中运行相同的代码时,不会返回任何数据。

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

Lua脚本

代码语言:javascript
复制
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

数据检索代码

代码语言:javascript
复制
ResultSet resultSet = client.queryAggregate(null, stmt, "profile", "filter_order", Value.get("mid334"));

编辑:获取此异常

代码语言:javascript
复制
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文件的代码

代码语言:javascript
复制
 LuaConfig.SourceDirectory = "udf";
 udfFile = new File("/home/lalit/udf/profile.lua");
 task = client.getAerospikeClient().register(null, udfFile.getPath(), udfFile.getName(), Language.LUA); 
 task.waitTillComplete();
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-07-24 14:22:57

设法解决了。

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

我路过udf

代码语言:javascript
复制
LuaConfig.SourceDirectory = "udf"

哪个应该是/home/lalit/udf

代码语言:javascript
复制
LuaConfig.SourceDirectory = "/home/lalit/udf"
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31606652

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档