怎樣在Redis通過(guò)StackExchange.Redis存儲(chǔ)集合類型List

本篇文章為大家展示了怎樣在redis通過(guò)StackExchange.Redis 存儲(chǔ)集合類型List,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

成都創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括華容網(wǎng)站建設(shè)、華容網(wǎng)站制作、華容網(wǎng)頁(yè)制作以及華容網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,華容網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到華容省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

StackExchange 是由StackOverFlow出品, 是對(duì)Redis的.NET封裝,被越來(lái)越多的.NET開(kāi)發(fā)者使用在項(xiàng)目中。
絕大部分原先使用ServiceStack的開(kāi)發(fā)者逐漸都轉(zhuǎn)了過(guò)來(lái),由于SS在其新版中不再開(kāi)源,并對(duì)免費(fèi)版本有所限制。

實(shí)際問(wèn)題

那么用.NET的開(kāi)發(fā)者會(huì)發(fā)現(xiàn),其根本沒(méi)有對(duì)List類型的存儲(chǔ)封裝,那么要實(shí)現(xiàn)一個(gè)類似如下需求:
假如我有一個(gè)Customer的模型。

   public class Customer

    {

        public string FirstName { get; set; }

        public string LastName { get; set; }

        public string Address1 { get; set; }

        public string City { get; set; }

        public string State { get; set; }

    }

var customers = new List<Customer>();

怎樣將List<customer> customers 存入Redis中呢?

來(lái)龍去脈

是由于StackExchange.Redis是一個(gè)純客戶端的代理,他僅僅實(shí)現(xiàn)了Redis自由的功能,并不額外封裝其它功能。 也不具備像ORM那樣的自動(dòng)類型匹配。

他僅僅存儲(chǔ)鍵值對(duì) 像string 或者 byte[]。所以你明白了吧,必須序列化存儲(chǔ),用類似Json格式一樣。像用第三方NewtonSoft或者是Google公司流行的Protocol Buffers 序列化格式的Protobuf-Net 也是不錯(cuò)的選擇。 

Redis支持存儲(chǔ)的類型有五種String ,Hash ,List ,Set ,和 Sorted Set, 正如上面說(shuō)的,這些存儲(chǔ)類型全部由字符串構(gòu)成。

其中Set類型是沒(méi)有順序的,并且值必須唯一, List類型有順序且允許重復(fù)。

解決方案

如果你僅僅為了緩存存一批量的 List<Customer> 數(shù)據(jù), 那么自己封裝一個(gè)ListGet() 和 ListSet()方法吧。

我對(duì)比過(guò)使用 List 和 String 兩種類型存儲(chǔ)。

Redis 的List類型和 .NET領(lǐng)域還有所不同,實(shí)際上,它是一個(gè)雙向隊(duì)列,可以左右插入值。

所以如果是批量數(shù)據(jù)插入 那么必須一個(gè)個(gè)插入, 代碼比較簡(jiǎn)單如下:

//封裝的ListSet

public void ListSet<T>(string key, List<T> value)

{

        .....

       //下面的database 是redis的數(shù)據(jù)庫(kù)對(duì)象.

        foreach (var single in value)

        {

                var s = ConvertJson(single); //序列化

                database.ListRightPush(key, s); //要一個(gè)個(gè)的插入

        }

}

//封裝的ListGet

public void ListGet<T>(string key)

{

       ...

       //ListRange返回的是一組字符串對(duì)象

       //需要逐個(gè)反序列化成實(shí)體

       var vList = database.ListRange(key) ;  

       List<T> result = new List<T>();

       foreach (var item in vList)

       {

           var model = ConvertObj<T>(item); //反序列化

           result.Add(model);

       }

       return result;

}

當(dāng)然測(cè)試了一下性能,取20W條數(shù)據(jù)平均時(shí)間 

測(cè)試效果如下:

怎樣在Redis通過(guò)StackExchange.Redis 存儲(chǔ)集合類型List

獲取10000條數(shù)據(jù),平均時(shí)間大概793.78毫秒.

/// <summary>

   /// 存儲(chǔ)List

   /// </summary>

   /// <typeparam name="T"></typeparam>

   /// <param name="key"></param>

   /// <param name="value"></param>

   public void ListSet<T>(string key, List<T> value)

   { 

       db.StringSet(key, ConvertJson(value));

   }

   /// <summary>

   /// 獲取指定key的List

   /// </summary>

   /// <param name="key"></param>

   /// <returns></returns>

   public List<T> ListGet<T>(string key)

   { 

       return ConvetList<T>(db.StringGet(key));

   }

上述內(nèi)容就是怎樣在Redis通過(guò)StackExchange.Redis 存儲(chǔ)集合類型List,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

新聞名稱:怎樣在Redis通過(guò)StackExchange.Redis存儲(chǔ)集合類型List
網(wǎng)頁(yè)URL:http://muchs.cn/article32/ipidsc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、網(wǎng)站改版虛擬主機(jī)、定制開(kāi)發(fā)電子商務(wù)、微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司