- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何执行 getNearest 查询其他命令的结果,例如过滤器命令?
var point = r.point(-122.422876,37.777128);
r.db('test').table('users').
filter({tags : 'tag'}).
getNearest(point, {index: 'geodata', maxResults: 30, unit :'km'})
我有一个“用户”表:
[
{id: 1, tags : ['music', 'cups'], geodata: r.point()}
{id: 2, tags: ['music', 'play'], geodata: r.point()}
]
首先,我想按“标签”字段进行过滤,然后返回最近的。
我指定的查询不正确,返回以下错误:“RqlRuntimeError: Expected type TABLE but found SELECTION”
最佳答案
你的查询抛出错误的原因是因为 .getNearest
仅适用于表格。文档就是这么说的。
选项#1
你可以通过颠倒命令的顺序来解决你的问题:
var point = r.point(-122.422876,37.777128);
r.db('test')
.table('users')
.getNearest(point, {index: 'geodata', maxResults: 30, unit :'km'})
.filter({tags : 'tag'})
这是有效的,因为 .getNearest
返回一个数组,而 .filter
可以处理一个数组。
var point = r.point(-122.422876,37.777128);
r.db('test')
.table('users')
.getNearest(point, {index: 'geodata', unit :'km'})
.filter({tags : 'tag'})
.limit(30)
这种方法的问题是,为了保证所有可能的结果都存在,你不能将 maxResults
选项传递给 getNearest,这意味着每一行都将被查询然后过滤.
这种情况最适用于大多数项目将通过过滤器的情况。
根据您的数据,也可以编写一个递增增加 maxResults
的函数,直到它获得所需的所有结果,但这可能很复杂而且不是很优雅。
选项 2
如果过滤器要过滤掉大部分结果,那么您可以使用 getAll
过滤结果(创建一个 tags
索引)并让 getAll
先过滤结果,然后根据距离对结果进行排序:
var point = r.point(-122.422876,37.777128);
r.table('users')
.getAll('tag', {index: 'tags'})
.orderBy(r.row('geodata')
.distance(point))
.limit(30)
数据类型
通过使用 .typeOf
,您始终可以随时获取任何内容的类型方法。
示例:
r.db('test')
.table('users').typeOf() // "TABLE"
r.db('test')
.table('users')
.filter({tags : 'tag'}).typeOf() // "STREAM"
如果您想了解更多有关 ReQL 数据类型的信息,可以查看此 blog post我写了解释 ReQL 数据类型及其不同之处的文章。
关于nearest-neighbor - 带有过滤器和 getNearest 命令的 rethinkdb,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29730916/
我正在 Unity 中制作泡泡射击游戏。我来到了可以击中另一个气泡的地步,它摧毁了它的所有邻居。 现在我试图摧毁它的所有邻居的邻居,这会导致堆栈溢出。我正在使用递归。 我在没有递归的情况下完成了它,并
我有一组 3D 点,每个点都与一个方向相关联(例如单位向量)。给定另一个点 + 方向,我想找出集合中最近的点(使用标准 2 范数),该点也满足方向向量的特定条件(例如,两个方向向量之间的角度在特定角度
局部敏感散列对于 KNN 来说似乎是一种很好的技术,没有任何缺点。但是,如果有人在工业中将其用于实际应用,那么局部敏感散列的缺点是什么? LSH在什么情况下会失败或者做的有些糟糕?还是编码/调整需要很
我想找到一种方法来确定我的 knn 算法中实际使用了哪些邻居,这样我就可以更深入地研究与我的特征相似的数据行。 这是一个数据集示例,我将其分为预测模型的训练集和测试集: Player
基于 calculating average distance of nearest neighbours in pandas dataframe 中的代码,如何调整它以便将第二个和第三个最近邻居返回
我目前正在编写一个 C 程序,用于查找多维数组中大于所有相邻元素的元素。所以如果我的输入是 3 2 9 13 7 6 1 5 8 它应该打印 9 13 8 但是,它似乎不起作用 :( 我已经运行了几次
在 1 维的爬山中,我尝试了两个邻居 - 我当前点左侧的一个小三角洲和一个右侧的小三角洲,然后保留给出更高目标函数值的那个。如何将其扩展到 n 维空间?如何定义 n 维空间的邻居?我是否必须尝试 2^
假设我们有一个包含 n 个元素的序列 S .一对元素xi,xj如果 |xi-xj|= k) continue; if (++neighborCount[i] > neighb
我正在编写一个方法,它将一个点数组作为输入,并为数组中的每个点找到除它本身之外离它最近的点。我目前正在以蛮力方式执行此操作(检查每个点与其他点)。我当前的实现没有对数组进行排序,但我可以使用 Comp
我在尝试想出一种逻辑方法来检查基于“网格”的类编程项目中的邻居时遇到了很多麻烦。 我遇到的主要问题是想办法有效地检查它是否在侧面,这样我就不会得到索引越界错误。 编辑:我忘了说我使用的是二维数组。 最
假设我使用 2D/3D numpy 数组来建模由单元格组成的盒子。单元格由从 0 开始递增的数字标记。在此之前,这可以通过 来完成 box = np.arange(np.prod(n_cells))
在论文“When Is 'Nearest Neighbor' Meaningful?”中我们读到,“我们表明,在某些广泛的条件下(在数据和查询分布或工作负载方面),随着维度的增加,到最近的距离neig
我正在查看维基百科上的 A 星伪代码 ( wikipedia:A*_search_algorithm ),我对这段代码有疑问: for each neighbor in neighbor_nodes(
我使用 Android Dev Phone 2,使用 GsmCellLocation.getCid() 方法获取网络上的 Cell ID。当我运行命令并获取所有 CellID 时Neighboring
我正在使用基于点云库 (PCL) 的 kd-tree 最近邻 (NN) 搜索的 C++ 实现。该数据集包含约 220 万个点。我正在为每个其他点搜索 NN 点。搜索半径设置为 2.0。要完全计算它,大
如何执行 getNearest 查询其他命令的结果,例如过滤器命令? var point = r.point(-122.422876,37.777128); r.db('test').table('
当使用特征描述符时 [如 SIFT、SURF] - 近似最近邻法是在图像之间进行匹配的最快方法吗? 最佳答案 你应该看看 pyramid match kernel ,这是迄今为止最成功的图像与局部特征
获取networkx中节点的邻居的时间复杂度是多少? >>> G = nx.Graph() >>> G.add_edges_from([('a', 'b'), ('a', 'c')]) >>> G.n
有没有办法从 sklearn.neighbors.KDTree 实例中通过 id 获取节点或所有节点? from sklearn.neighbors import KDTree import
这是代码。 from sklearn.neighbors import NearestNeighbors import numpy as np X = np.array([[-1, -1], [-2,
我是一名优秀的程序员,十分优秀!