MongoDB聚合运算符:$toHashedIndexKey

MongoDB聚合运算符:$toHashedIndexKey

文章目录

$toHashedIndexKey计算并返回输入表达式的哈希值,其使用的哈希函数与MongoDB创建哈希索引相同。哈希函数将键值或字符串映射到固定大小的数值。

语法

js 复制代码
{ $toHashedIndexKey: <key or string to hash> }

举例

角度的双曲正切

使用下面的脚本创建trigonometry集合,包含一个文档,存储了以度为单位的角度:

在聚合管道中,可以使用$toHashedIndexKey计算字符串的散列值。本例计算字符串"string to hash"的散列值:

js 复制代码
db.aggregate(
   [
      { $documents: [ { val: "string to hash" } ] },
      { $addFields: { hashedVal: { $toHashedIndexKey: "$val" } } }
   ]
 )

执行的结果为:

js 复制代码
[ { val: 'string to hash', hashedVal: Long("763543691661428748") } ]

**注意:**与散列索引不同,$toHashedIndexKey聚合操作符不考虑排序规则,这意味着该操作符产生的哈希值可能与基于相同数据的哈希索引的哈希值不一致。

相关推荐
添砖java‘’17 分钟前
MYSQL数据类型
数据库·mysql
qq_3721542321 分钟前
如何配置表中某列的排序权重_全文索引配置与权重分配
jvm·数据库·python
小张成长计划..22 分钟前
【C++】25:哈希表的实现
数据结构·哈希算法·散列表
M--Y24 分钟前
Redis集群和典型应用场景
redis·算法·哈希算法·集群
2501_9142459332 分钟前
CSS如何使用-nth-of-type精确选择列表项_通过元素类型限制提升样式健壮性
jvm·数据库·python
吕源林39 分钟前
Golang如何做本地缓存加速_Golang本地缓存教程【核心】
jvm·数据库·python
Magic@1 小时前
Redis学习[1] ——基本概念和数据类型
linux·开发语言·数据库·c++·redis·学习
Irene19911 小时前
SQL查询优化:NOT EXISTS与LEFT JOIN性能对比
oracle·哈希算法
你觉得脆皮鸡好吃吗1 小时前
SQL注入 基础防御
数据库·sql
池佳齐1 小时前
软考高级系统架构设计师备考(十九):数据库系统—数据库设计
数据库·系统架构