1、redis是什麼
> redis是一種支援Key-Value等多種資料結構的儲存系統。可用於快取,事件釋出或訂閱,高速佇列等場景。該資料庫使用ANSI C語言編寫,支援網路,提供字串,雜湊,列表,佇列,集合結構直接存取,基於記憶體,可持久化。
2、redis資料型別
> Redis一共支援五種資料類:string(字串),hash(雜湊),list(列表),set(集合)和zset(sorted set有序集合)。
3、redis的應用場景有哪些
> a會話快取(最常用)
> b.訊息佇列,(比如支付3,活動排行榜或計數)
> c.釋出,訂閱訊息(訊息通知)
> d.列表詳情內容快取等
4、Redis 常用用法詳情
/*** String 資料型別 **/
# string是redis最基本的型別,而且string型別是二進位制安全的.
# 意思是redis的string可以包含任何資料,比如jpg圖片或者序列化的物件.
$redis->set('key','LY');
$redis->set('number','1');
$redis->setex('key',5,'LY'); // 設定有效期為5秒的鍵值
$redis->psetex('key',5000,'LY'); // 設定有效期為5000毫秒(同5秒)的鍵值
$redis->setnx('key','LW'); // 若鍵值存在返回false 不存在返回true
$redis->delete('key'); // 刪除鍵值 可以傳入陣列 array('key1','key2')刪除多個鍵
$redis->getSet('key','LW'); // 將鍵key的值設定為LW, 並返回這個鍵值原來的值LY
// 批次事務處理,不保證處理資料的原子性
$ret = $redis->multi()
->set('key1', 'val1')
->get('key1')
->setnx('key', 'val2')
->get('key2')->exec();
// 監控鍵key是否被其他客戶端修改,如果KEY在呼叫watch()和exec()之間被修改,exec失敗
$redis->watch('key');
// 頻道訂閱
function f($redis, $chan, $msg) {
switch($chan) {
case 'chan-1':
echo $msg;
break;
case 'chan-2':
echo $msg;
break;
case 'chan-2':
echo $msg;
break;
}
}
$redis->subscribe(array('chan-1', 'chan-2', 'chan-3'), 'f'); // subscribe to 3 chans
$redis->publish('chan-1', 'hello, world!'); // send message.
$redis->exists('key'); // 驗證鍵是否存在,存在返回true
$redis->incr('number'); // 鍵值加1
$redis->incrby('number',-10); // 鍵值加減10
$redis->incrByFloat('number', +/- 1.5); //鍵值加減小數
$redis->decr('number'); // 鍵值減1
$redis->decrBy('number',10); // 鍵值減10
$mget = $redis->mget(array('number','key')); // 批次獲取鍵值,返回一個陣列
$redis->mset(array('key0' => 'value0', 'key1' => 'value1')); // 批次設定鍵值
// 批次設定鍵值,類似將setnx()方法批次操作
$redis->msetnx(array('key0' => 'value0', 'key1' => 'value1'));
$redis->append('key', '-Smudge'); // 原鍵值LY,將值追加到鍵值後面,鍵值為LY-Smudge
$redis->getRange('key', 0, 5); // 鍵值擷取從0位置開始到5位置結束
$redis->getRange('key', -6, -1); // 字串擷取從-6(倒數第6位置)開始到-1(倒數第1位置)結束
// 鍵值中替換字串,0表示從0位置開始,有多少個字元替換多少位置,其中漢字佔2個位置
$redis->setRange('key', 0, 'Smudge');
$redis->strlen('key'); // 鍵值長度
$redis->getBit('key');
$redis->setBit('key');
/** Hash 資料型別 */
# redis hash是一個string型別的field和value的對映表.
# 它的新增,刪除操作都是O(1)(平均).hash特別適合用於儲存物件。
$redis->hSet('h', 'name', 'LY'); // 在h表中 新增name欄位 value為LY
// 在h表中 新增name欄位 value為LY 如果欄位name的value存在返回false 否則返回 true
$redis->hSetNx('h', 'name', 'LY');
$redis->hGet('h', 'name'); // 獲取h表中name欄位value
$redis->hLen('h'); // 獲取h表長度即欄位的個數
$redis->hDel('h','email'); // 刪除h表中email 欄位
$redis->hKeys('h'); // 獲取h表中所有欄位
$redis->hVals('h'); // 獲取h表中所有欄位value
$redis->hGetAll('h'); // 獲取h表中所有欄位和value 返回一個關聯陣列(欄位為鍵值)
$redis->hExists('h', 'email'); // 判斷email 欄位是否存在與表h 不存在返回false
$redis->hSet('h', 'age', 28);
// 設定h表中age欄位value加(-2) 如果value是個非數值 則返回false 否則,返回操作後的value
$redis->hIncrBy('h', 'age', -2);
// 設定h表中age欄位value加(-2.6)如果value是個非數值 則返回false 否則返回操作後的value(小數點保留15位)
$redis->hIncrByFloat('h', 'age', -0.33);
// 表h 批次設定欄位和value
$redis->hMset('h', array('score' => '80', 'salary' => 2000));
$redis->hMGet('h', array('score','salary')); // 表h 批次獲取欄位的value
/***************List 資料型別 ******************************/
$redis->delete('list-key'); // 刪除連結串列
$redis->lPush('list-key', 'A'); // 插入連結串列頭部/左側,返回連結串列長度
$redis->rPush('list-key', 'B'); // 插入連結串列尾部/右側,返回連結串列長度
$redis->lPushx('list-key', 'C');// 插入連結串列頭部/左側,連結串列不存在返回0,存在即插入成功,返回當前連結串列長度
$redis->rPushx('list-key', 'C');// 插入連結串列尾部/右側,連結串列不存在返回0,存在即插入成功,返回當前連結串列長度
$redis->lPop('list-key'); // 返回LIST頂部(左側)的VALUE ,後入先出(棧)
$redis->rPop('list-key'); // 返回LIST尾部(右側)的VALUE ,先入先出(佇列)
$redis->blPop();
$redis->brPop();
// 如果是連結串列則返回連結串列長度,空連結串列返回0若不是連結串列或者不為空,則返回false ,判斷非連結串列 " === false "
$redis->lSize('list-key');
$redis->lGet('list-key',-1); // 透過索引獲取連結串列元素 0獲取左側一個 -1獲取最後一個
$redis->lSet('list-key', 0, 'X'); // 0位置元素替換為 X
$redis->lRange('list-key', 0, 3); // 連結串列擷取 從0開始 3位置結束 ,結束位置為-1 獲取開始位置之後的全部
$redis->lTrim('list-key', 0, 1); // 擷取連結串列(不可逆) 從0索引開始 1索引結束
$redis->lRem('list-key', 'C', 2); // 連結串列從左開始刪除元素2個C
// 在C元素前面插入X , Redis::AfTER(表示後面插入)連結串列不存在則插入失敗 返回0 若元素不存在返回-1
$redis->lInsert('list-key', Redis::BEFORE, 'C', 'X');
// 從源LIST的最後彈出一個元素並且把這個元素從目標LIST的頂部(左側)壓入目標LIST。
$redis->rpoplpush('list-key', 'list-key2');
// rpoplpush的阻塞版本,這個版本有第三個引數用於設定阻塞時間即如果源LIST為空,
// 那麼可以阻塞監聽timeout的時間,如果有元素了則執行操作。
$redis->brpoplpush();
/************* Set 集合 資料型別 *******************/
# set無序集合 不允許出現重複的元素 服務端可以實現多個 集合操作
$redis->sMembers('key'); // 獲取容器key中所有元素
// (從左側插入,最後插入的元素在0位置),集合中已經存在LY 則返回false,不存在新增成功 返回true
$redis->sAdd('key' , 'LY');
$redis->sRem('key' , 'LY'); // 移除容器中的LY
$redis->sMove('key','key1','LY'); // 將容易key中的元素LY 移動到容器key1 操作成功返回TRUE
$redis->sIsMember('key','LY'); // 檢查VALUE是否是SET容器中的成員
$redis->sCard('key'); // 返回SET容器的成員數
$redis->sPop('key'); // 隨機返回容器中一個元素,並移除該元素
$redis->sRandMember('key'); // 隨機返回容器中一個元素,不移除該元素
// 返回兩個集合的交集 沒有交集返回一個空陣列,若引數只有一個集合,則返回集合對應的完整的陣列
$redis->sInter('key','key1');
$redis->sInterStore('store','key','key1'); // 將集合key和集合key1的交集 存入容器store 成功返回1
$redis->sUnion('key','key1'); // 集合key和集合key1的並集 注意即使多個集合有相同元素 只保留一個
// 集合key和集合key1的並集儲存在集合store中, 注意即使多個集合有相同元素 只保留一個
$redis->sUnionStore('store','key','key1');
$redis->sDiff('key','key1','key2'); // 返回陣列,該陣列元素是存在於key集合而不存在於集合key1 key2
/************* Zset 有序集合 資料型別*********************/
# (stored set) 和 set 一樣是字串的集合,不同的是每個元素都會關聯一個 double 型別的 score
# redis的list型別其實就是一個每個子元素都是string型別的雙向連結串列。
// 插入集合tkey中,A元素關聯一個分數,插入成功返回1,同時集合元素不可以重複, 如果元素已經存在返回 0
$redis->zAdd('tkey', 1, 'A');
$redis->zRange('tkey',0,-1); // 獲取集合元素,從0位置 到 -1 位置
$redis->zRange('tkey',0,-1, true); // 獲取集合元素,從0位置 到 -1 位置, 返回一個關聯陣列 帶分數
array([A] => 0.01,[B] => 0.02,[D] => 0.03); // 其中小數來自zAdd方法第二個引數
$redis->zDelete('tkey', 'B'); // 移除集合tkey中元素B 成功返回1 失敗返回 0
$redis->zRevRange('tkey', 0, -1); // 獲取集合元素,從0位置 到 -1 位置,陣列按照score降序處理
// 獲取集合元素,從0位置 到 -1 位置,陣列按照score降序處理 返回score關聯陣列
$redis->zRevRange('tkey', 0, -1,true);
// 獲取幾個tkey中score在區間[0,0.2]元素 ,score由低到高排序,
// 元素具有相同的score,那麼會按照字典順序排列 , withscores 控制返回關聯陣列
$redis->zRangeByScore('tkey', 0, 0.2,array('withscores' => true));
// 其中limit中 0和1 表示取符合條件集合中 從0位置開始,向後掃描1個 返回關聯陣列
$redis->zRangeByScore('tkey', 0.1, 0.36, array('withscores' => TRUE, 'limit' => array(0, 1)));
$redis->zCount('tkey', 2, 10); // 獲取tkey中score在區間[2, 10]元素的個數
$redis->zRemRangeByScore('tkey', 1, 3); // 移除tkey中score在區間[1, 3](含邊界)的元素
// 預設元素score是遞增的,移除tkey中元素 從0開始到-1位置結束
$redis->zRemRangeByRank('tkey', 0, 1);
$redis->zSize('tkey'); // 返回儲存在key對應的有序集合中的元素的個數
$redis->zScore('tkey', 'A'); // 返回集合tkey中元素A的score值
// 返回集合tkey中元素A的索引值,z集合中元素按照score從低到高進行排列 ,即最低的score index索引為0
$redis->zRank('tkey', 'A');
$redis->zIncrBy('tkey', 2.5, 'A'); // 將集合tkey中元素A的score值 加 2.5
// 將集合tkey和集合tkey1元素合併於集合union , 並且新集合中元素不能重複,返回新集合的元素個數,
// 如果元素A在tkey和tkey1都存在,則合併後的元素A的score相加
$redis->zUnion('union', array('tkey', 'tkey1'));
// 集合k1和集合k2並集於k02 ,array(5,1)中元素的個數與子集合對應,然後 5 對應k1
// k1每個元素score都要乘以5 ,同理1對應k2,k2每個元素score乘以1,
// 然後元素按照遞增排序,預設相同的元素score(SUM)相加
$redis->zUnion('ko2', array('k1', 'k2'), array(5, 2));
// 各個子集乘以因子之後,元素按照遞增排序,相同的元素的score取最大值(MAX),也可以設定MIN 取最小值
$redis->zUnion('ko2', array('k1', 'k2'), array(10, 2),'MAX');
// 集合k1和集合k2取交集於k01 ,且按照score值遞增排序,如果集合元素相同,則新集合中的元素的score值相加
$redis->zInter('ko1', array('k1', 'k2'));
// 集合k1和集合k2取交集於k01 ,array(5,1)中元素的個數與子集合對應,然後 5 對應k1
// k1每個元素score都要乘以5 ,同理1對應k2,k2每個元素score乘以1,
// 然後元素score按照遞增排序,預設相同的元素score(SUM)相加
$redis->zInter('ko1', array('k1', 'k2'), array(5, 1));
// 各個子集乘以因子之後,元素score按照遞增排序,相同的元素score取最大值(MAX)也可以設定MIN 取最小值
$redis->zInter('ko1', array('k1', 'k2'), array(5, 1),'MAX');
本作品採用《CC 協議》,轉載必須註明作者和本文連結