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 = , // “写”链接池链接数  

                MaxReadPoolSize = , // “读”链接池链接数  

                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(, , )); 

                } 

            } 

            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) > ; 

            } 

        } 

        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 - ); 

            } 

        } 

        public static List<T> List_GetList<T>(string key) 

        { 

            using (IRedisClient redis = prcm.GetClient()) 

            { 

                var c = redis.GetTypedClient<T>(); 

                return c.Lists[key].GetRange(, c.Lists[key].Count); 

            } 

        } 

        public static List<T> List_GetList<T>(string key, int pageIndex, int pageSize) 

        { 

            int start = pageSize * (pageIndex - ); 

            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 > ) 

                { 

                    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, ); 

            } 

        } 

        /// <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 - ) * pageSize, pageIndex * pageSize - );  

                if (list != null && list.Count > ) 

                { 

                    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, , ); 

                if (list != null && list.Count > ) 

                { 

                    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 

    } 

}
 
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
       
    }
}

redisHelper的更多相关文章

  1. Basic Tutorials of Redis(9) -First Edition RedisHelper

    After learning the basic opreation of Redis,we should take some time to summarize the usage. And I w ...

  2. C# Azure 存储-分布式缓存Redis工具类 RedisHelper

    using System; using System.Collections.Generic; using Newtonsoft.Json; using StackExchange.Redis; na ...

  3. Asp.Net Core 2.0 项目实战(6)Redis配置、封装帮助类RedisHelper及使用实例

    本文目录 1. 摘要 2. Redis配置 3. RedisHelper 4.使用实例 5. 总结 1.  摘要 由于內存存取速度远高于磁盘读取的特性,为了程序效率提高性能,通常会把常用的不常变动的数 ...

  4. [C#] 使用 StackExchange.Redis 封装属于自己的 RedisHelper

    使用 StackExchange.Redis 封装属于自己的 RedisHelper 目录 核心类 ConnectionMultiplexer 字符串(String) 哈希(Hash) 列表(List ...

  5. RedisHelper帮助类

    using Newtonsoft.Json; using RedLockNet.SERedis; using RedLockNet.SERedis.Configuration; using Stack ...

  6. RedisHelper in C#

    自己写了一个RedisHelper,现贴出来,希望各位大神能够指正和优化. using System; using StackExchange.Redis; using System.Configur ...

  7. 使用 StackExchange.Redis 封装属于自己的 RedisHelper

    目录 核心类 ConnectionMultiplexer 字符串(String) 哈希(Hash) 列表(List) 有序集合(sorted set) Key 操作 发布订阅 其他 简介 目前 .NE ...

  8. RedisHelper (C#)

    <add key="RedisServers" value="172.20.2.90:9379,password=Aa+123456789" /> ...

  9. RedisHelper Redis帮助类

    using StackExchange.Redis; using System; using System.Collections.Generic; using System.IO; using Sy ...

  10. Redis:RedisHelper(5)

    /// <summary> /// Redis 助手 /// </summary> public class RedisHelper { /// <summary> ...

随机推荐

  1. 简单的BSON OID生成实现

    简单的OID生成测试实现,只是简单的用用,切勿用于生产环境. /* 应该使用大端序的,这里没有做转换 * ObjectId是12-byte BSON类型,其结构为: * * 4-byte 值为Unix ...

  2. Quartz.NET开源作业调度框架系列(一):快速入门step by step-转

    Quartz.NET是一个被广泛使用的开源作业调度框架 , 由于是用C#语言创建,可方便的用于winform和asp.net应用程序中.Quartz.NET提供了巨大的灵活性但又兼具简单性.开发人员可 ...

  3. servlet保存数据的几种方式

    In Servlets you have 4 scopes where you can store data. Application Session Request Page

  4. ios中推送

    http://www.cnblogs.com/cdts_change/p/3240893.html 推荐:http://blog.csdn.net/zhuqilin0/article/details/ ...

  5. 优化 App 的启动时间

    这是一篇 WWDC 2016 Session 406 的学习笔记,从原理到实践讲述了如何优化 App 的启动时间. App 运行理论 main() 执行前发生的事 Mach-O 格式 虚拟内存基础 M ...

  6. memcached全面剖析--5. memcached的应用和兼容程序

    我是Mixi的长野.memcached的连载终于要结束了.到上次为止,我们介绍了与memcached直接相关的话题,本次介绍一些mixi的案例和实际应用上的话题,并介绍一些与memcached兼容的程 ...

  7. Map的有序和无序实现类,与Map的排序

    1.HashMap.Hashtable不是有序的: 2.TreeMap和LinkedHashMap是有序的(TreeMap默认 Key 升序,LinkedHashMap则记录了插入顺序). 今天做统计 ...

  8. 【Oracle】Oracle中复合数据类型

    1,常见的操作数据库的技术有那些 jdbc     使用java 访问数据库的技术    PLSQL  (procedure  过程化sql) 在数据库内部操作数据的技术    proc/c++    ...

  9. SpringMVC整合Mongodb开发,高级操作

    开发环境: 操作系统:windows xpMongodb:2.0.6依 赖 包:Spring3.2.2 + spring-data-mongodb-1.3.0 + Spring-data-1.5 +  ...

  10. 如何从40亿整数中找到不存在的一个 webservice Asp.Net Core 轻松学-10分钟使用EFCore连接MSSQL数据库 WPF实战案例-打印 RabbitMQ与.net core(五) topic类型 与 headers类型 的Exchange

    如何从40亿整数中找到不存在的一个 前言 给定一个最多包含40亿个随机排列的32位的顺序整数的顺序文件,找出一个不在文件中的32位整数.(在文件中至少确实一个这样的数-为什么?).在具有足够内存的情况 ...