Redis操作的封裝類

來源:互聯網
上載者:User

標籤:

 
using System;using System.Collections.Generic;using System.Linq;using System.Text;using ServiceStack.Redis;       namespace Com.QFGame.QNX.Community.Redis{    public class RedisBase    {               private static string RedisPath = System.Configuration.ConfigurationSettings.AppSettings["RedisPath"];               #region -- 串連資訊 --        //10.0.18.8:6379        public static PooledRedisClientManager prcm = CreateManager(new string[] { RedisPath }, new string[] { RedisPath });        private static PooledRedisClientManager CreateManager(string[] readWriteHosts, string[] readOnlyHosts)        {             // 支援讀寫分離,均衡負載             return new PooledRedisClientManager(readWriteHosts, readOnlyHosts, new RedisClientManagerConfig            {                MaxWritePoolSize = 5, // “寫”連結池連結數                 MaxReadPoolSize = 5, // “讀”連結池連結數                 AutoStart = true,            });        }        #endregion                                                                              #region -- Item --        /// <summary>        /// 設定單體        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <param name="t"></param>        /// <param name="timeSpan"></param>        /// <returns></returns>        public static bool Item_Set<T>(string key, T t)        {            try            {                using (IRedisClient redis = prcm.GetClient())                {                    return redis.Set<T>(key, t, new TimeSpan(1, 0, 0));                }            }            catch (Exception ex)            {                // LogInfo            }            return false;        }               /// <summary>        /// 擷取單體        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <returns></returns>        public static T Item_Get<T>(string key) where T : class        {            using (IRedisClient redis = prcm.GetClient())            {                return redis.Get<T>(key);            }        }               /// <summary>        /// 移除單體        /// </summary>        /// <param name="key"></param>        public static bool Item_Remove(string key)        {            using (IRedisClient redis = prcm.GetClient())            {                return redis.Remove(key);            }        }               #endregion               #region -- List --               public static void List_Add<T>(string key, T t)        {            using (IRedisClient redis = prcm.GetClient())            {                var redisTypedClient = redis.GetTypedClient<T>();                redisTypedClient.AddItemToList(redisTypedClient.Lists[key], t);            }        }                                     public static bool List_Remove<T>(string key, T t)        {            using (IRedisClient redis = prcm.GetClient())            {                var redisTypedClient = redis.GetTypedClient<T>();                return redisTypedClient.RemoveItemFromList(redisTypedClient.Lists[key], t) > 0;            }        }        public static void List_RemoveAll<T>(string key)        {            using (IRedisClient redis = prcm.GetClient())            {                var redisTypedClient = redis.GetTypedClient<T>();                redisTypedClient.Lists[key].RemoveAll();            }        }               public static int List_Count(string key)        {            using (IRedisClient redis = prcm.GetClient())            {                return redis.GetListCount(key);            }         }               public static List<T> List_GetRange<T>(string key, int start, int count)        {            using (IRedisClient redis = prcm.GetClient())            {                var c = redis.GetTypedClient<T>();                return c.Lists[key].GetRange(start, start + count - 1);            }        }                      public static List<T> List_GetList<T>(string key)        {            using (IRedisClient redis = prcm.GetClient())            {                var c = redis.GetTypedClient<T>();                return c.Lists[key].GetRange(0, c.Lists[key].Count);            }        }               public static List<T> List_GetList<T>(string key, int pageIndex, int pageSize)        {            int start = pageSize * (pageIndex - 1);            return List_GetRange<T>(key, start, pageSize);        }               /// <summary>        /// 設定緩衝到期        /// </summary>        /// <param name="key"></param>        /// <param name="datetime"></param>        public static void List_SetExpire(string key, DateTime datetime)        {                using (IRedisClient redis = prcm.GetClient())                {                        redis.ExpireEntryAt(key, datetime);                }        }        #endregion               #region -- Set --        public static void Set_Add<T>(string key, T t)        {            using (IRedisClient redis = prcm.GetClient())            {                var redisTypedClient = redis.GetTypedClient<T>();                redisTypedClient.Sets[key].Add(t);            }        }        public static bool Set_Contains<T>(string key, T t)        {            using (IRedisClient redis = prcm.GetClient())            {                var redisTypedClient = redis.GetTypedClient<T>();                return redisTypedClient.Sets[key].Contains(t);            }        }        public static bool Set_Remove<T>(string key, T t)        {            using (IRedisClient redis = prcm.GetClient())            {                var redisTypedClient = redis.GetTypedClient<T>();                return redisTypedClient.Sets[key].Remove(t);            }        }        #endregion                      #region -- Hash --        /// <summary>        /// 判斷某個資料是否已經被緩衝        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <param name="dataKey"></param>        /// <returns></returns>        public static bool Hash_Exist<T>(string key, string dataKey)        {            using (IRedisClient redis = prcm.GetClient())            {                return redis.HashContainsEntry(key, dataKey);            }        }               /// <summary>        /// 儲存資料到hash表        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <param name="dataKey"></param>        /// <returns></returns>        public static bool Hash_Set<T>(string key, string dataKey, T t)        {            using (IRedisClient redis = prcm.GetClient())            {                string value = ServiceStack.Text.JsonSerializer.SerializeToString<T>(t);                return redis.SetEntryInHash(key, dataKey, value);            }        }        /// <summary>        /// 移除hash中的某值        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <param name="dataKey"></param>        /// <returns></returns>        public static bool Hash_Remove(string key, string dataKey)        {            using (IRedisClient redis = prcm.GetClient())            {                return redis.RemoveEntryFromHash(key, dataKey);            }        }        /// <summary>        /// 移除整個hash        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <param name="dataKey"></param>        /// <returns></returns>        public static bool Hash_Remove(string key)        {            using (IRedisClient redis = prcm.GetClient())            {                return redis.Remove(key);            }        }        /// <summary>        /// 從hash表擷取資料        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <param name="dataKey"></param>        /// <returns></returns>        public static T Hash_Get<T>(string key, string dataKey)        {            using (IRedisClient redis = prcm.GetClient())            {                string value = redis.GetValueFromHash(key, dataKey);                return ServiceStack.Text.JsonSerializer.DeserializeFromString<T>(value);            }        }        /// <summary>        /// 擷取整個hash的資料        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <returns></returns>        public static List<T> Hash_GetAll<T>(string key)        {            using (IRedisClient redis = prcm.GetClient())            {                var list = redis.GetHashValues(key);                if (list != null && list.Count > 0)                {                    List<T> result = new List<T>();                    foreach (var item in list)                    {                        var value = ServiceStack.Text.JsonSerializer.DeserializeFromString<T>(item);                        result.Add(value);                    }                    return result;                }                return null;            }        }        /// <summary>        /// 設定緩衝到期        /// </summary>        /// <param name="key"></param>        /// <param name="datetime"></param>        public static void Hash_SetExpire(string key, DateTime datetime)        {            using (IRedisClient redis = prcm.GetClient())            {                redis.ExpireEntryAt(key, datetime);            }        }        #endregion                             #region -- SortedSet --        /// <summary>        ///  添加資料到 SortedSet        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <param name="t"></param>        /// <param name="score"></param>        public static bool SortedSet_Add<T>(string key, T t, double score)        {            using (IRedisClient redis = prcm.GetClient())            {                string value = ServiceStack.Text.JsonSerializer.SerializeToString<T>(t);                return redis.AddItemToSortedSet(key, value, score);            }        }        /// <summary>        /// 移除資料從SortedSet        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <param name="t"></param>        /// <returns></returns>        public static bool SortedSet_Remove<T>(string key, T t)        {            using (IRedisClient redis = prcm.GetClient())            {                string value = ServiceStack.Text.JsonSerializer.SerializeToString<T>(t);                return redis.RemoveItemFromSortedSet(key, value);            }        }        /// <summary>        /// 修剪SortedSet        /// </summary>        /// <param name="key"></param>        /// <param name="size">保留的條數</param>        /// <returns></returns>        public static int SortedSet_Trim(string key, int size)        {            using (IRedisClient redis = prcm.GetClient())            {                return redis.RemoveRangeFromSortedSet(key, size, 9999999);            }        }        /// <summary>        /// 擷取SortedSet的長度        /// </summary>        /// <param name="key"></param>        /// <returns></returns>        public static int SortedSet_Count(string key)        {            using (IRedisClient redis = prcm.GetClient())            {                return redis.GetSortedSetCount(key);            }        }               /// <summary>        /// 擷取SortedSet的分頁資料        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <param name="pageIndex"></param>        /// <param name="pageSize"></param>        /// <returns></returns>        public static List<T> SortedSet_GetList<T>(string key, int pageIndex, int pageSize)        {            using (IRedisClient redis = prcm.GetClient())            {                var list = redis.GetRangeFromSortedSet(key, (pageIndex - 1) * pageSize, pageIndex * pageSize - 1);                 if (list != null && list.Count > 0)                {                    List<T> result = new List<T>();                    foreach (var item in list)                    {                        var data = ServiceStack.Text.JsonSerializer.DeserializeFromString<T>(item);                        result.Add(data);                    }                    return result;                }            }            return null;        }                      /// <summary>        /// 擷取SortedSet的全部資料        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="key"></param>        /// <param name="pageIndex"></param>        /// <param name="pageSize"></param>        /// <returns></returns>        public static List<T> SortedSet_GetListALL<T>(string key)        {            using (IRedisClient redis = prcm.GetClient())            {                var list = redis.GetRangeFromSortedSet(key, 0, 9999999);                if (list != null && list.Count > 0)                {                    List<T> result = new List<T>();                    foreach (var item in list)                    {                        var data = ServiceStack.Text.JsonSerializer.DeserializeFromString<T>(item);                        result.Add(data);                    }                    return result;                }            }            return null;        }               /// <summary>        /// 設定緩衝到期        /// </summary>        /// <param name="key"></param>        /// <param name="datetime"></param>        public static void SortedSet_SetExpire(string key, DateTime datetime)        {            using (IRedisClient redis = prcm.GetClient())            {                redis.ExpireEntryAt(key, datetime);            }        }               //public static double SortedSet_GetItemScore<T>(string key,T t)        //{        //    using (IRedisClient redis = prcm.GetClient())        //    {        //        var data = ServiceStack.Text.JsonSerializer.SerializeToString<T>(t);        //        return redis.GetItemScoreInSortedSet(key, data);        //    }        //    return 0;        //}               #endregion           }}
 

  可以使用redis desktop manager管理工具查看伺服器緩衝中的資料

 

 

Redis操作的封裝類

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.