主頁 > 資料庫 > Redis實戰解讀-初識Redis&Redis基本資料型別

Redis實戰解讀-初識Redis&Redis基本資料型別

2023-05-16 15:30:43 資料庫

Redis實戰解讀

一.初識Redis

1.什么是Redis

? Redis是一個速度非常快的非關系型資料庫(non-relational database),它可以存盤鍵(key)與五種不同型別的值的映射(mapping),可以將存盤在記憶體的鍵值對資料持久化到磁盤,可以使用復制特性來擴展讀性能,也可以采用客戶端分片來擴展寫性能,--《Redis實戰》

2.Redis與其他資料庫的對比

? 與memcached對比:Redis能夠存盤包括字串型別的共計五種資料型別的鍵值,而memcached只能存盤普通的字串型別的鍵值,

二.Redis中的資料結構

Redis支持String(字串),List(串列),Set(集合),Hash(散列),Zset(有序集合)共計五種資料型別以存盤鍵值,接下來,我們將分別去討論這五種資料型別

(我們將在Linux系統進行演示,如何在Linux系統上安裝并運行Redis,請參照https://redis.io/docs/getting-started/installation/install-redis-on-linux/)

1.String(字串)

字串的內容可以是字串,整數或者是浮點數,因此,字串可以進行字串相關的操作,以及數值型的自加自減操作,

相當于其他資料型別而言,字串型別的內容較為簡單,這里以代碼過之,

image-20230512162318677

相關方法說明:

向資料庫中添加一個key-value: set key value

獲取資料庫中指定key的value: get key

洗掉資料庫中指定的key: del key

2.List(串列)

Redis中的鏈表結構能夠順序存盤多個字串,其中,鏈表中的每一個節點均代表著一個字串

代碼演示:

image-20230512163534988image-20230512163836833

相關方法說明:

rpush key value:從左側向key對應的鏈表插入一個value元素,并回傳添加的元素的value值

lpush key value:從右側向key對應的鏈表插入一個value元素,并回傳添加的元素的value值

rpop key:從左側洗掉key對應的鏈表的一個元素,并回傳洗掉的元素的value值

lpop key:從右側洗掉key對應的鏈表的一個元素,并回傳洗掉的元素的value值

lindex key index :獲取串列上指定(從右側數)index處的元素的value值

lrange key startIndex endIndex:獲取從startIndex索引到endIndex索引之間(即[startIndex,endIndex]區間上的元素)的元素的元素值

注意:當startIndex = 0,endIndex = -1,則表示獲取整個鏈表內的所有元素,

? index是從0開始計數,

3.Set(集合)

與List資料型別不同的是,Set不能存盤多個相同的字串值,也就是說,其存盤的元素值具有唯一性,此外,其存盤順序也是不定的,即元素存盤的順序與插入順序沒有關系,

image-20230512165802415 image-20230512165853630image-20230512170220291

相關方法說明:

sadd key value : 向指定key的集合中添加一個值為value的元素,成功回傳1,失敗回傳0

srem key value : 向指定key的集合中洗掉一個值為value的元素,成功回傳1,失敗回傳0

smembers key : 獲取指定key的集合中的全部元素

sismember key value :確定指定元素value是否存在于key的集合中,存在則回傳1,不存在則回傳0

4.Hash(散列)

Redis中的散列用于存盤多個鍵值對之間的映射,類似于Java中的Map資料型別,

image-20230513161158538image-20230513161213401image-20230513161551708

相關方法說明:

hset key sub_key sub_value : 向指定key的集合中添加 sub_key 與sub_value的鍵值映射,插入成功回傳1,失敗回傳0

hget key sub_key : 獲取指定key的集合中的sub_key對應的值,存在sub_key的關系映射,則回傳相對應的值,不存在回傳nil

hdel key sub_key : 洗掉指定key的集合中的sub_key的鍵值映射

hgetall key : 獲取指定key集合中的全部鍵值映射,注意:結果是以key1,value1,key2,value2,.......交替展示

5.Zset(有序集合)

與Set一樣,該種資料型別也是用于存盤唯一性的鍵值的,與前者不同的是,后者在鍵值的基礎上還添加了一個與之系結的分數值(score),因此你可以依據score值去獲取相應的value值,并且也可以查詢指定score范圍內的相對應的key值,

image-20230513162755613image-20230513162810089

相關方法說明:

zadd key score item : 向指定key的有序集合中添加一個分數為score 的item元素,插入成功回傳1,失敗回傳0

zrem key item : 洗掉指定key的有序集合中的指定item元素,洗掉成功回傳1,失敗回傳0

zrange key startIndex endIndex [withscores] : 獲取指定key的有序集合中的索引介于起始索引startIndex與結束索引endIndex之間的元素,添加withscores則回傳的結果中為item與score的交替展示

zrangebyscore key minScore maxScore [withscores]: 獲取指定key的有序集合中的分數值介于minScore與maxScore之間的元素值,添加withscores則回傳的結果中為item與score的交替展示

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/552591.html

標籤:其他

上一篇:06~12-Esp8266物聯網芯片的使用(一)-part02/03-ESP8266開發環境、編程舉例

下一篇:返回列表

標籤雲
其他(159126) Python(38137) JavaScript(25431) Java(18044) C(15226) 區塊鏈(8267) C#(7972) AI(7469) 爪哇(7425) MySQL(7191) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5871) 数组(5741) R(5409) Linux(5340) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4572) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2433) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1973) 功能(1967) Web開發(1951) HtmlCss(1937) python-3.x(1918) C++(1917) 弹簧靴(1913) xml(1889) PostgreSQL(1877) .NETCore(1860) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • Redis實戰解讀-初識Redis&Redis基本資料型別

    一.初識Redis
    1.什么是Redis
    ? Redis是一個速度非常快的非關系型資料庫(non-relational database),它可以存盤鍵(key)與五種不同型別的值的映射(mapping),可以將存盤在記憶體的鍵值對資料持久化到磁盤,可以使用復制特性來擴展讀性能,也可以采用客戶端分片來... ......

    uj5u.com 2023-05-16 15:30:43 more
  • 06~12-Esp8266物聯網芯片的使用(一)-part02/03-ESP8266開發環境、

    上一章主要作了芯片介紹,這一章主要作對開發環境的介紹。 認識Arduino Arduino是一款便捷靈活、方便上手的開源電子原型平臺。包含硬體(各種型號的Arduino板)和軟體(ArduinoIDE)。它構建于開放原始碼simple I/O介面版,并且具有使用類似Java、C語言的Processi ......

    uj5u.com 2023-05-16 15:30:35 more
  • Redis資料結構二之SDS和雙向鏈表

    本文首發于公眾號:Hunter后端 原文鏈接:Redis資料結構二之SDS和雙向鏈表 這一篇筆記介紹一下 SDS(simple dynamic string)和雙向鏈表。 以下是本篇筆記目錄: SDS 常數復雜度獲取字串長度 杜絕緩沖區溢位 減少修改字串帶來的記憶體重分配次數 二進制安全 兼容C字 ......

    uj5u.com 2023-05-16 15:30:27 more
  • Apache Arrow DataFusion原理與架構

    本篇主要介紹了一種使用Rust語言撰寫的查詢引擎——DataFusion,其使用了基于Arrow格式的記憶體模型,結合Rust語言本身的優勢,達成了非常優秀的性能指標 DataFusion是一個查詢引擎而非資料庫,因此其本身不具備存盤資料的能力。但正因為不依賴底層存盤的格式,使其成為了一個靈活可擴展的 ......

    uj5u.com 2023-05-16 15:30:16 more
  • MySQL的varchar存盤原理:InnoDB記錄存盤結構

    摘要:varchar(M) 能存多少個字符,為什么提示最大16383?innodb怎么知道varchar真正有多長?記錄為NULL,innodb如何處理?某個列資料占用的位元組數非常多怎么辦?影響每行實際可用空間的因素有哪些?本篇圍繞innodb默認行格式dynamic來說說原理。 本文分享自華為云社 ......

    uj5u.com 2023-05-16 15:29:49 more
  • 架構師日記-從資料庫發展歷程到資料結構設計探析

    本文針對資料存盤相關名詞概念進行了解釋,重點介紹了資料庫技術的發展史。為了豐富文章的可讀性以及實用性,又從資料結構設計層面進行了部分技術實戰能力的外延擴展,闡述了拉鏈表,位運算,環形佇列等相關資料結構在軟體開發領域的應用,希望本文給你帶來識訓。 ......

    uj5u.com 2023-05-16 15:29:42 more
  • MySQL 存盤程序&觸發器&事務

    存盤程序 概念 存盤程序(Stored Procedure),是為了完成特定功能的SQL陳述句集。 優點 存盤程序可以理解為shell腳本這型別的命令集輸出工具,但是在底層,存盤程序擁有更多的優點: ==語言的靈活性跟功能性更強==,在原有基礎之上可以插入控制陳述句、回圈陳述句等讓SQL陳述句的功能更強,能 ......

    uj5u.com 2023-05-16 15:29:30 more
  • pg_enterprise_views偶然發現的PG神仙插件!

    一直從事資料庫相關的作業,對于PG而言最大的問題其實是在運維管理方面,其缺乏有效且直觀成體系的系統表,苦覓良久,今日在PG官網中發現了一款新收錄的免費插件,其提供了數十張系統表,內容涵蓋了從作業系統到資料庫的負載指標、等待事件、會話、客戶端、SQL、SQL執行計劃、超時鎖、長事務、資料庫物件、寫行程 ......

    uj5u.com 2023-05-16 15:28:49 more
  • Redis實戰解讀-初識Redis&Redis基本資料型別

    一.初識Redis
    1.什么是Redis
    ? Redis是一個速度非常快的非關系型資料庫(non-relational database),它可以存盤鍵(key)與五種不同型別的值的映射(mapping),可以將存盤在記憶體的鍵值對資料持久化到磁盤,可以使用復制特性來擴展讀性能,也可以采用客戶端分片來... ......

    uj5u.com 2023-05-16 15:28:18 more
  • Redis資料結構二之SDS和雙向鏈表

    本文首發于公眾號:Hunter后端 原文鏈接:Redis資料結構二之SDS和雙向鏈表 這一篇筆記介紹一下 SDS(simple dynamic string)和雙向鏈表。 以下是本篇筆記目錄: SDS 常數復雜度獲取字串長度 杜絕緩沖區溢位 減少修改字串帶來的記憶體重分配次數 二進制安全 兼容C字 ......

    uj5u.com 2023-05-16 15:28:08 more