redis支援五種資料型別:string(字串),hash(雜湊),list(列表),set(集合)及zset(sorted set:有序集合)
string(字串)
string 是 redis 最基本的型別,你可以理解成與 memcached 一模一樣的型別,乙個 key 對應乙個 value。
string 型別是二進位制安全的。意思是 redis 的 string 可以包含任何資料。比如jpg或者序列化的物件。
string 型別是 redis 最基本的資料型別,string 型別的值最大能儲存 512mb。
## 首先建立一些 key,並賦上對應值:
redis 127.0.0.1:6379> set hjk1 redis
okredis 127.0.0.1:6379> set hjk2 mysql
okredis 127.0.0.1:6379> set hjk3 mongodb
ok查詢以hj開頭的key值
redis 127.0.0.1:6379> keys hj*
「hjk1」
「hjk2」
「hjk3」
**獲取redis裡所有key可以用:keys ***
redis 127.0.0.1:6379> keys *
「hjk1」
「hjk2」
「hjk3」
hash(雜湊)
redis hash 是乙個鍵值(key=>value)對集合。
redis hash 是乙個 string 型別的 field 和 value 的對映表,hash 特別適合用於儲存物件。
del runoob 用於刪除前面測試用過的 key,不然會報錯!!!不要問我怎麼知道的!!
用hmset myhash file1 「啦啦啦啦啦這裡是你要存的值」 file2 「啦啦啦啦啦啦啦」
執行了之後你就可以用 hget myhash 這裡寫key值 來查詢
每個 hash 可以儲存 232 -1 鍵值對(40多億)!!!!
127.0.0.1:6379> hmset myhash file1 「assad」 file2 「fghjhj」
ok127.0.0.1:6379> hget myhash file1
「assad」
127.0.0.1:6379> hget myhash file2
「fghjhj」
127.0.0.1:6379>
list(列表)
redis 列表是簡單的字串列表,按照插入順序排序。你可以新增乙個元素到列表的頭部(左邊)或者尾部(右邊)。
用 lpush 這裡寫list名(沒有會自動建立) 這裡寫你要新增的值
具體看下面:
127.0.0.1:6379> lpush run redis
(integer) 1
127.0.0.1:6379> lpush run fff
(integer) 2
127.0.0.1:6379> lpush run cccccc
(integer) 3
127.0.0.1:6379> lpush run ccccc2
(integer) 4
127.0.0.1:6379> lpush run 0 10
(integer) 6
127.0.0.1:6379> lrange run 0 10
「10」
「0」「ccccc2」
「cccccc」
「fff」
「redis」
127.0.0.1:6379>
set(集合)
redis的set是string型別的無序集合。
集合是通過雜湊表實現的,所以新增,刪除,查詢的複雜度都是o(1)。sadd 命令
新增乙個 string 元素到 key 對應的 set 集合中,成功返回1,如果元素已經在集合中返回 0,如果 key 對應的 set 不存在則返回錯誤。
127.0.0.1:6379> del runoob
(integer) 0
127.0.0.1:6379> sadd hj res
(integer) 1
127.0.0.1:6379> sadd hj asad
(integer) 1
127.0.0.1:6379> sadd hj asad2
(integer) 1
127.0.0.1:6379> sadd hj asad2
(integer) 0
127.0.0.1:6379> smembers hj
「asad」
「asad2」
「res」
zset(sorted set:有序集合)
redis zset 和 set 一樣也是string型別元素的集合,且不允許重複的成員。
不同的是每個元素都會關聯乙個double型別的分數。redis正是通過分數來為集合中的成員進行從小到大的排序。
zset的成員是唯一的,但分數(score)卻可以重複。zadd 命令
新增元素到集合,元素在集合中存在則更新對應score
127.0.0.1:6379> del runoob
(integer) 0
127.0.0.1:6379> zadd rung 0 ghka
(integer) 1
127.0.0.1:6379> zadd rung 0 ghka1
(integer) 1
127.0.0.1:6379> zadd rung 0 ghka12
(integer) 1
127.0.0.1:6379> zadd rung 0 ghka123
(integer) 1
127.0.0.1:6379> zadd rung 0 ghka1234
(integer) 1
127.0.0.1:6379> zadd rung 0 ghka1234
(integer) 0
127.0.0.1:6379> zrangebyscore rung 0 1000
「ghka」
「ghka1」
「ghka12」
「ghka123」
「ghka1234」
下面是資料型別的應用場景!!!:
redis資料型別
redis對比與memcached 最大的優勢就是支援更多靈活的資料結構,豐富的資料操作 redis現支援的資料型別有 字串,列表,集合,雜湊,有序集合 1.字串 普通資料型別 2.列表 簡單的字串列表,按照插入順序排序。你可以新增乙個元素到列表的頭部 左邊 或者尾部 右邊 適用於 對資料頭尾操作頻...
Redis 資料型別
redis支援五種資料型別 string 字串 hash 雜湊 list 列表 set 集合 及zset sorted set 有序集合 string是redis最基本的型別,你可以理解成與memcached一模一樣的型別,乙個key對應乙個value。string型別是二進位制安全的。意思是red...
Redis 資料型別
redis支援五種資料型別 string 字串 hash 雜湊 list 列表 set 集合 及zset sorted set 有序集合 string是redis最基本的型別,你可以理解成與memcached一模一樣的型別,乙個key對應乙個value。string型別是二進位制安全的。意思是red...