《Redis使用手册之HyperLog与地理坐标应用》

《Redis使用手册之HyperLog与地理坐标》

目录

      • **《Redis使用手册之HyperLog与地理坐标》**
      • **PFADD:对集合元素进行计数**
      • **PFCOUNT:返回集合的近似基数**
      • **PFMERGE:计算多个HyperLogLog的并集**
      • **GEOADD:存储坐标**
      • **GEOPOS:获取指定位置的坐标**
      • GEODIST:计算两个位置之间的直线距离**
      • **GEORADIUS:查找指定坐标半径范围内的其他位置**
      • **GEORADIUSBYMEMBER:查找指定位置半径范围内的其他位置**
      • **GEOHASH:获取指定位置的Geohash值**
      • **事务**
      • **带有乐观锁的事务**

PFADD:对集合元素进行计数

127.0.0.1:6379> pfadd hyperlog a b c
(integer) 1
127.0.0.1:6379> pfadd hyperlog a
(integer) 0
127.0.0.1:6379> pfadd hyperlog d
(integer) 1

PFADD:对集合元素进行计数 PFADD hyperlog element [element …] - 如果给定的所有元素都已经进行过计数,那么PFADD命令将返回0,表示HYperLog-log计算出的近似基础没有发生变化。 - 如果给定的元素中出现了至少一个之前没有进行过计数的元素,导致Hyperloglog计算的近似基础发生了变化,那么PFADD命令将返回1。

PFADD:对集合元素进行计数

PFCOUNT:返回集合的近似基数

127.0.0.1:6379> pfcount hyperlog
(integer) 4
127.0.0.1:6379> pfadd hyperlog1 d e f
(integer) 1
127.0.0.1:6379> pfcount hyperlog hyperlog1
(integer) 6

PFCOUNT:返回集合的近似基础 PFCOUNT hyperloglog [hyperloglog …] 返回并集的近似基数

PFCOUNT:返回集合的近似基数

PFMERGE:计算多个HyperLogLog的并集

127.0.0.1:6379> pfadd numbers1 128 256 512
(integer) 1
127.0.0.1:6379> pfadd number2 128 256 512
(integer) 1
127.0.0.1:6379> pfadd number3 128 512 1024
(integer) 1
127.0.0.1:6379> pfmerge union-numbers numbers1 numbers2 numbers3
OK
127.0.0.1:6379> pfcount union-numbers
(integer) 3

127.0.0.1:6379> pfcount numbers1 numbers2 numbers3
(integer) 3

PFMETGE:计算多个HYperLogLog的并集 PFMERGE destination hyperloglog [hyperloglog …]

PFMERGE:计算多个HyperLogLog的并集

GEOADD:存储坐标

127.0.0.1:6379> geoadd Guangdong-citics 113.2099647 23.593675 qingyuan
(integer) 1
127.0.0.1:6379> geoadd Guangdong-citics 113 23 qingyuan
(integer) 0

GEOPOS:获取指定位置的坐标

127.0.0.1:6379> geopos Guangdong-citics qingyuan

  1. “112.99999862909317017”

    “23.00000023389439718”

GEOPOS:获取指定位置的坐标

GEOPOS:获取指定位置的坐标

GEODIST:计算两个位置之间的直线距离**

  • 127.0.0.1:6379> geodist Guangdong-citics qingyuan guangzhou
    “1949897.2806”
    127.0.0.1:6379> geodist Guangdong-citics qingyuan guangzhou km
    “1949.8973”

    GEODIST:计算两个位置之间的直线距离

    GEODIST location_set name1 name2

    指定距离的单位

    GEODIST location_set name1 name2 [unit]

    unit参数的值可以是以下单位中的任意一个:

    m——以米为单位,为默认单位

    km——千米为单位

    mi——英里为单位

    ft——英尺为单位

    GEODIST:计算两个位置之间的直线距离

GEORADIUS:查找指定坐标半径范围内的其他位置

  • 127.0.0.1:6379> GEOADD Guangdong-cities 113.2099647 23.593675 Qingyuan 113.2278442 23.1255978 Guangzhou 113.106308 23.0088312 Foshan 113.7943267 22.9761989 Dongguan 114.0538788 22.5551603 Shenzhen 113.4060288 22.5111574 Zhongshan
    (integer) 6
    127.0.0.1:6379> GEORADIUS Guangdong-cities 112.3351942 23.0586893 50 km
    (empty list or set)
    127.0.0.1:6379> GEORADIUS Guangdong-cities 112.3351942 23.0586893 100 km

    “Foshan”

    “Guangzhou”
    127.0.0.1:6379> GEORADIUS Guangdong-cities 112.3351942 23.0586893 150 km

    “Foshan”

    “Guangzhou”

    “Dongguan”

    “Qingyuan”

    “Zhongshan”
    127.0.0.1:6379> GEORADIUS Guangdong-cities 112.3351942 23.0586893 250 km

    “Zhongshan”

    “Shenzhen”

    “Foshan”

    “Guangzhou”

    “Dongguan”

    “Qingyuan”

    GEORADIUS:查找指定坐标半径范围内的其他位置

    GEORADIUS location_set longitude latitude radius unit

    location_set参数用于指定执行查找操作的位置集合。

    longitude参数和latitude参数分别用于指定中心点的经度和纬度。

    radius参数用于指定查找半径。

    unit参数用于指定查找半径的单位,与GEODIST命令中的unit参数一样,这个参数的值可以是m(米)、km(千米)、mi(英里)或者ft(英尺)中的任意一个。 返回被匹配位置与中心点之间的距离

    georadius location_set longitude latitude radius unit [WITHDIST]

    返回被匹配位置的坐标 WITHCOORD

    排序查找结果 [ASC|DESC]

    限制命令获取的位置数量 [COUNT n]

    同时使用多个可选项

    127.0.0.1:6379> GEORADIUS Guangdong-cities 112.3351942 23.0586893 250 km withdist withcoord asc count 3

    1. “Foshan”

    2. “79.1250”

      1. “113.10631066560745239”
      2. “23.00883120241353907”
    3. “Guangzhou”

    4. “91.6332”

      1. “113.22784155607223511”
      2. “23.1255982020608073”
    5. “Qingyuan”

    6. “107.3463”

      1. “113.20996731519699097”
      2. “23.59367501967128788”

    GEORADIUS:查找指定坐标半径范围内的其他位置

GEORADIUSBYMEMBER:查找指定位置半径范围内的其他位置

GEORADIUSBYMEMBER:查找指定位置半径范围内的其他位置 GEORADIUSBYMEMBER location_set name radius unit [WITHDIST] [WITHCOORD] [ASC|DESC] [COUNT n]

GEORADIUSBYMEMBER:查找指定位置半径范围内的其他位置

GEOHASH:获取指定位置的Geohash值

  • 127.0.0.1:6379> geohash Guangdong-citics qingyuan

    “ws06g7h0dy0”
    127.0.0.1:6379> geohash Guangdong-citics qingyuan Guangzhou Shenzhen

    “ws06g7h0dy0”

    (nil)

    “ws107659240”

    GEOHASH:获取指定位置的Geohash值 Geohash是一种编码格式,这种格式可以将用户给定的经度和纬度转换成单个Geohash值,也可以根据给定的Geohash值还原出被转换的经度和纬度。

    GEOHASH:获取指定位置的Geohash值用户可以通过向GEOHASH命令传入一个或多个位置来获得这些位置对应的经纬度坐标的Geohash表示:

事务

MULTI:开启事务 EXEC:执行事务 DISCARD:放弃事务

MULTI:开启事务

带有乐观锁的事务

​ MULTI:添加事务

​ EXEC:提交

  • 127.0.0.1:6379> multi
    OK
    127.0.0.1:6379> set title “Hand in Hand”
    QUEUED
    127.0.0.1:6379> sadd fruits apple banana cherry
    QUEUED
    127.0.0.1:6379> rpush numbers 123456 789
    QUEUED

    127.0.0.1:6379> exec

    OK

    (integer) 3

    (integer) 2

    discard:取消事务

    127.0.0.1:6379> multi
    OK
    127.0.0.1:6379> set page_count 10086
    QUEUED
    127.0.0.1:6379> set download_count 12345
    QUEUED
    127.0.0.1:6379> discard
    OK
    127.0.0.1:6379> get page_count
    (nil)

    带有乐观锁的事物

    WATCH:对键进行监视

    watch key [key …]

    127.0.0.1:6379> watch user_id_counter
    OK
    127.0.0.1:6379> multi
    OK
    127.0.0.1:6379> incr user_id_counter
    QUEUED
    127.0.0.1:6379> exec

    (integer) 152
    127.0.0.1:6379> unwatch
    OK

    通过同时使用watch命令和Redis事物,我们可以构建出一种针对被监视键的乐观锁机制,确保事物只会在被监视键没有发生任何变化的情况下执行,从而保证事物对被监视键的所有修改都是安全、正确和有效的。

    UNWATCH:取消对键的监视。

    unwatch 除了显式地执行unwatch命令之外,使用EXEC命令执行事物和使用DISCARD命令取消事物,同样会导致客户端撤销对所有键的监视,这是因为这两个命令在执行之后都会隐式地调用unwatch命令。

    带有乐观锁的事务

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/588480.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

如何反向查看某个命令所属的rpm包的2个方法?(rpm -qf `which xxx`和yum provides和 rpm -ql xxx.rpm)

文章目录 快速回忆方法1: rpm -qf方法2:yum provides 其他rpm如何查看某个rpm包里面包含哪些命令: rpm -ql主推方法1: rpm -ql方法2:yum info 其他查看rdma-core中包含哪些cmd:一些其他命令所在包探索 快速回忆 rpm -…

C++_set和map的学习

1. 关联式容器 STL中的容器有序列式容器和关联式容器。 其中 vector 、 list 、 deque 、 forward_list(C11)就是序列式容器, 因为其底层为线性序列的数据结构,里面 存储的是元素本身 关联式容器 也是用来存储数据的,与序列式容器不同的是&am…

Word域代码学习(简单使用)-【SEQ】

Word域代码学习(简单使用)-【SEQ】 快捷键 序号快捷键操作1 Ctrl F9 插入域代码花括号2 F9 显示域代码结果3 Shift F9 切换为域代码4 Windows Alt F9 切换全部域代码 域代码说明 域代码不区分大小写在word中,依次选择插入➡文档部件➡域即可选择插入…

2.4Java全栈开发前端+后端(全栈工程师进阶之路)-前端框架VUE3-基础-Vue组件

初识Vue组件 Vue中的组件是页面中的一部分,通过层层拼装,最终形成了一个完整的组件。这也是目前前端最流行的开发方 式。下面是Vue3官方给出的一张图,通过图片能清楚的了解到什么是Vue中的组件。 图的左边是一个网页,网页分为了…

初识Vue-组件化开发(应用实例)

目录 一、任务管理应用 1.介绍 2.代码 1. 任务列表组件 (TaskList.vue) 2. 添加任务组件 (AddTask.vue) 3. 应用入口组件 (App.vue) 4. 主入口文件 (main.js) 3.效果 4.总结 二、购物车 1.介绍 2.代码 1. 商品列表组件 (ProductList.vue) 2. 购物车组件 (Cart.vue…

医疗大模型华佗GPT-2:医学问答超越GPT-4,通过2023年国家执业药师考试

前言 随着人工智能技术的快速发展,特别是在自然语言处理(NLP)领域,大型预训练模型如GPT系列已经显示出在多个领域的强大应用潜力。最近,华佗GPT-2医疗大模型的发布,不仅标志着人工智能在医学领域的一大进步,更是在202…

国产服务器操作系统部署NTP服务 _ 统信UOS _ 麒麟 _ 中科方德

原文链接:国产服务器操作系统部署NTP服务 | 统信UOS | 麒麟 | 中科方德 Hello,大家好啊!在保持服务器时间的精确同步方面,时间同步服务器(NTP服务器)扮演着至关重要的角色,它能确保系统操作的时…

小程序商城|基于Spring Boot的智能小程序商城的设计与实现(源码+数据库+文档)

小程序商城目录 目录 基于Spring Boot的智能小程序商城 一、前言 二、系统设计 三、系统功能设计 1用户信息管理 2 商品信息管理 3公告信息管理 4论坛信息管理 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取: …

LeetCode 面试题 17.14 —— 最小 k 个数

阅读目录 1. 题目2. 解题思路一3. 代码实现一4. 解题思路二5. 代码实现二 1. 题目 2. 解题思路一 第一种方法就是利用快速排序,第一次排序后,数组被划分为了左右两个区间 [ 0 , i ] , [ i 1 , a r r . s i z e ( ) − 1 ] [0, i], [i1, arr.size()-1]…

Windows下载MingGW

因为要配置vscode的c/c环境,需要下载一个编译器,gcc官方推荐开源的MingGW-W64,看了几个下载方法,决定用最简单的离线安装。 niXman/mingw-builds-binaries/releases 32位的操作系统:i686,64位的操作系统&a…

画渐变色的圆弧练习

import sysfrom PySide6.QtCore import QPointF from PySide6.QtWidgets import * from PySide6.QtGui import *class MyWidget(QWidget):def paintEvent(self, event):painter QPainter(self) # 设定画板painter.setRenderHint(QPainter.Antialiasing) # 抗锯齿size min(s…

Rust Turbofish 的由来

0x01 什么是 Turbofish 我们运行如下 Rust Snippet&#xff1a; fn main() {let numbers: Vec<i32> vec![1, 2, 3, 4, 5, 6, 7, 8, 9, 10];let even_numbers numbers.into_iter().filter(|n| n % 2 0).collect();println!("{:?}", even_numbers); }不出意…

在线听歌播放器 梨花带雨网页音乐播放器 网页音乐在线听 源码

最新梨花带雨网页音乐播放器二开优化修复美化版全开源版本源码下载 下 载 地 址 &#xff1a; runruncode.com/php/19749.html 梨花带雨播放器基于thinkphp6开发的XPlayerHTML5网页播放器前台控制面板,支持多音乐平台音乐解析。二开内容&#xff1a;修复播放器接口问题&am…

Java零基础入门到精通_Day 11

1.继承 定义&#xff1a; 继承是面向对象三大特征之一。可以使得子类具有父类的属性和方法&#xff0c;还可以在子类中重新定义&#xff0c;追加属性和方法 格式&#xff1a; public class 子类 extends 父类{} 子类&#xff1a;也叫派生类 父类&#xff1a;基类/超类 继…

【c++】反向迭代器的探究实现

&#x1f525;个人主页&#xff1a;Quitecoder &#x1f525;专栏&#xff1a;c笔记仓 在list中我们实现了正向的迭代器&#xff0c;学习完优先级队列后&#xff0c;我们也对适配器模式有了一个深刻的理解&#xff0c;这篇文章基于这种模式下&#xff0c;实现各类容器的反向迭…

【论文阅读笔记】TS2Vec: Towards Universal Representation of Time Series

【论文阅读笔记】TS2Vec: Towards Universal Representation of Time Series 摘要 这段文字介绍了一个名为TS2Vec的通用框架&#xff0c;用于学习时间序列数据的表示&#xff0c;可以在任意语义层次上进行。与现有方法不同&#xff0c;TS2Vec通过对增强的上下文视图进行层次化…

【论文阅读:Towards Efficient Data Valuation Based on the Shapley Value】

基于Shapley值的高校数据价值评估 主要贡献 提出了一系列用于近似计算Shapley值的高效算法。设计了一个算法&#xff0c;通过实现不同模型评估之间的适当信息共享来实现这一目标,该算法具有可证明的误差保证来近似N个数据点的SV&#xff0c;其模型评估数量为 O ( N l o g ( N…

Typora配置PicGo图床,将图片文件上传到gitee厂库,获取图片链接显示在md文件中

Typora配置PicGo图床&#xff0c;将图片文件上传到gitee厂库&#xff0c;获取图片链接显示在md文件中 创建Gitee创库和配置私人令牌 名字、路径、描述自己随便添&#xff0c;但是必须开源&#xff0c;链接才能可以访问&#xff1a; 进入偏好设置 > 图像 > 选择PicGo-Cor…

CAS 与 volatile

目录 CAS volatile 为什么无锁效率高 CAS 的特点 CAS AtomicInteger 内部并没有用锁来保护共享变量的线程安全。那么它是如何实现的呢&#xff1f; public void withdraw(Integer amount) {while(true) {// 需要不断尝试&#xff0c;直到成功为止while (true) {// 比如拿到…

基于Springboot+Vue的Java项目-入校申报审批系统开发实战(附演示视频+源码+LW)

大家好&#xff01;我是程序员一帆&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;Java毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计 &am…
最新文章