Redis储存DataTable

 很早之前的代码,回顾一下。在用redis的时候,希望将datatable储存起来。

大致如下:


        #region datatable操作

        /// <summary>
        /// 插入Datatable缓存
        /// </summary>
        /// <param name="key"></param>
        /// <param name="dt"></param>
        /// <param name="seconds"></param>
        public void SetMemByDataTable(string key, DataTable dt, int seconds)
        {

            DateTime expiryTime = DateTime.Now.AddSeconds(seconds);
            System.Runtime.Serialization.IFormatter formatter = new System.Runtime.Serialization.Formatters.Binary.BinaryFormatter();//定义BinaryFormatter以序列化DataSet对象   
            System.IO.MemoryStream ms = new System.IO.MemoryStream();//创建内存流对象   
            formatter.Serialize(ms, dt);//把Datatable对象序列化到内存流   
            byte[] buffer = ms.ToArray();//把内存流对象写入字节数组   
            ms.Close();//关闭内存流对象   
            ms.Dispose();//释放资源   
            Redis.Set(key, buffer, expiryTime);
        }

        /// <summary>
        /// 得到datatable
        /// </summary>
        /// <param name="key"></param>
        /// <returns></returns>
        public DataTable GetMemByDataSet(string key)
        {
            var item = Get(key);
            return (DataTable)item;
        }

        /// <summary>
        /// 根据key得到二进制数据流
        /// </summary>
        /// <param name="key"></param>
        /// <returns></returns>
        public object Get(string key)
        {
            byte[] buffer = Redis.Get(key);

            return GetObjFromBytes(buffer);
        }

        private object GetObjFromBytes(byte[] buffer)
        {
            if (buffer == null)
            {
                return null;
            }
            using (System.IO.MemoryStream stream = new System.IO.MemoryStream(buffer))
            {
                stream.Position = 0;
                System.Runtime.Serialization.IFormatter bf = new System.Runtime.Serialization.Formatters.Binary.BinaryFormatter();
                Object reobj = bf.Deserialize(stream);
                return reobj;
            }
        }

        #endregion

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值