一种历史浏览功能的实现(C#)

//   将最近浏览的ID按浏览时间压入_cookiesName

//存储时按队列算法,读取时按堆柣算法

            if (Page.Request.Cookies[_cookiesName] != null)
            {
                HttpCookie _tempCurBuyerList = Page.Request.Cookies[_cookiesName];
                string _tempstr = _tempCurBuyerList.Value; if (_tempstr.IndexOf(",") > 0)
                {
                    string[] sArray = _tempstr.Split(',');
                    bool hasthis = false;
                    foreach (string i in sArray)
                    {
                        if (i == objectID.ToString())
                        {
                            hasthis = true;
                            break;
                        }
                        else
                        {
                            hasthis = false;
                        }
                    }
                    if (!hasthis)
                    {
                        if (sArray.Length > 11)
                        {
                            //超过限定,去掉最先入队的元素 
                            _tempstr = _tempstr.Substring(0, _tempstr.LastIndexOf(","));
                        }
                        //队列 
                        _tempstr = objectID.ToString() + "," + _tempstr;
                    }
                }
                else
                {
                    //
                    _tempstr += "," + objectID.ToString();
                    if (_tempstr != objectID.ToString())
                    {
                        _tempstr = objectID.ToString() + "," + _tempstr;
                    }
                }
                _tempCurBuyerList.Value = _tempstr;
                _tempCurBuyerList.Expires = DateTime.Now.AddDays(7);
                Page.Response.Cookies.Add(_tempCurBuyerList);
            }
            else
            {
                HttpCookie _addToCookies = new HttpCookie(_cookiesName);
                _addToCookies.Value = objectID.ToString();
                _addToCookies.Expires = DateTime.Now.AddDays(7);
                Page.Response.Cookies.Add(_addToCookies);
            }

//提取时,按队列从左至右排序

string _tempBuyStr = "select TradeLeadsID from TradeLeads where TradeLeadsID IN (" + _tempBuyCookies + ")";
_tempBuyStr += "order by charindex(','+ltrim(TradeLeadsID)+',', '," + _tempBuyCookies + ",')";//重要
    

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值