redis的五種數據類型


1、string(字符串)

它師最基本的類型,可以理解為Memcached一模一樣的類型,一個key對應一個value。

注意:一個鍵最大能存儲 512MB。

特性:可以包含任何數據,比如jpg圖片或者序列化的對象,一個鍵最大能存儲512M

2、Hash(哈希)

Redis hash 是一個鍵值(key=>value)對集合。

Redis hash 是一個 string 類型的 field 和 value 的映射表,hash 特別適合用於存儲對象。

注意:每個 hash 可以存儲 232 -1 鍵值對(40多億)。

特性:適合存儲對象,並且可以像數據庫中update一個屬性一樣只修改某一項屬性值(Memcached中需要取出整個字符串反序列化成對象修改完再序列化存回去)

3、list(列表)

Redis 列表是簡單的字符串列表,按照插入順序排序。你可以添加一個元素到列表的頭部(左邊)或者尾部(右邊)。

注意:列表最多可存儲 232 - 1 元素 (4294967295, 每個列表可存儲40多億)。

特性:增刪快,提供了操作某一段元素的API

4、set(集合)

Redis 的 Set 是 string 類型的無序集合。

集合是通過哈希表實現的,所以添加,刪除,查找的復雜度都是 O(1)。

注意:以上實例中 rabbitmq 添加了兩次,但根據集合內元素的唯一性,第二次插入的元素將被忽略。

集合中最大的成員數為 232 - 1(4294967295, 每個集合可存儲40多億個成員)。

特性:

1、添加、刪除,查找的復雜度都是O(1)

2、為集合提供了求交集、並集、差集等操作

5、sorted set:有序集合

Redis zset 和 set 一樣也是string類型元素的集合,且不允許重復的成員。

不同的是每個元素都會關聯一個double類型的分數。redis正是通過分數來為集合中的成員進行從小到大的排序。

zset的成員是唯一的,但分數(score)卻可以重復。

特性:數據插入集合時,已經進行天然排序

----------------------------------------------------------

注意:Redis支持多個數據庫,並且每個數據庫的數據是隔離的不能共享,並且基於單機才有,如果是集群就沒有數據庫的概念。

Redis是一個字典結構的存儲服務器,而實際上一個Redis實例提供了多個用來存儲數據的字典,客戶端可以指定將數據存儲在哪個字典中。這與我們熟知的在一個關系數據庫實例中可以創建多個數據庫類似,所以可以將其中的每個字典都理解成一個獨立的數據庫。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM