• DoingOrder.aspx.cs缓存的使用方法


    using System;
    using System.Web.UI;
    using System.Data;
    using System.Text;
    using BLL = SmartWaterSys.BLL;
     
    namespace Web
    {
    public partial class DoingOrder : System.Web.UI.Page
    {
    protected void Page_Load(object sender, EventArgs e)
    {
    if (!Page.IsPostBack)
    {
    this.txtStartTime.Text = DateTime.Now.AddMonths(-1).ToString("yyyy-MM-dd");
    this.txtEndTime.Text = DateTime.Now.ToString("yyyy-MM-dd");
    if (Cache["StrWhere_DoingOrder"] != null)
    Cache.Remove("StrWhere_DoingOrder");//清除缓存
    LoadDDLOrderType();
    QueryData(SetInitQueryString());
    }
    }
     
    private void LoadDDLOrderType()
    {
    BLL.EN_OrderType ordertype = new BLL.EN_OrderType();
    DataSet ds = ordertype.GetAllList();
    this.OrderTypeLst.DataSource = ds;
    this.OrderTypeLst.DataTextField = "EN_OrderType_Name";
    this.OrderTypeLst.DataValueField = "EN_OrderType_ID";
    this.OrderTypeLst.DataBind();
    this.OrderTypeLst.Items.Insert(0, "全部");
    }
    private string SetInitQueryString()
    {
    StringBuilder sbSql = new StringBuilder();
    if (OrderTypeLst.SelectedItem != null && OrderTypeLst.SelectedItem.Text != "全部")
    {
    sbSql.Append(string.Format(" and EN_OrderType_Name = '{0}' ", OrderTypeLst.SelectedItem.Text));
    }
    if (StatusDDL != null && StatusDDL.SelectedItem.Text != "全部")
    {
    sbSql.Append(string.Format(" and [Status] = '{0}' ", StatusDDL.SelectedItem.Text));
    }
    if (txtOrderNum.Text.Length != 0)
    {
    sbSql.Append(string.Format(" and EN_OrderInfo_Num like '%{0}%'", txtOrderNum.Text));
    }
    if (txtStartTime.Text.Length != 0)
    {
    sbSql.Append(string.Format(" and DL_OrderProcess_ReceiveDate >= '{0}'", txtStartTime.Text));
    }
    if (txtEndTime.Text.Length != 0)
    {
    sbSql.Append(string.Format(" and DL_OrderProcess_AdvanceDate <= '{0}'", txtEndTime.Text));
    }
    Cache["StrWhere_DoingOrder"] = sbSql.ToString();//首次加载完页面(分页)或者重置按钮后保存至缓存
    return sbSql.ToString();
    }
     
    protected void lnkRefresh_Click(object sender, EventArgs e)
    {
    lnkQuery_Click(null,null);
    }
     
    protected void lnkQuery_Click(object sender, EventArgs e)
    {
    this.AspNetPager1.CurrentPageIndex = 0;
    BLL.View_Operate view = new BLL.View_Operate();
    StringBuilder sbSql = new StringBuilder();
    if (OrderTypeLst.SelectedItem != null && OrderTypeLst.SelectedItem.Text !="全部")
    {
    sbSql.Append(string.Format(" and EN_OrderType_Name = '{0}' ", OrderTypeLst.SelectedItem.Text));
    }
    if (StatusDDL !=null && StatusDDL.SelectedItem.Text!="全部")
    {
    sbSql.Append(string.Format(" and [Status] = '{0}' ",StatusDDL.SelectedItem.Text));
    }
    //sbSql.Append(string.Format(" and EN_OrderType_Name = '{0}' and [Status] = '{1}' ", OrderTypeLst.SelectedItem.Text, StatusDDL.SelectedItem.Text));
    if (txtOrderNum.Text.Length != 0)
    sbSql.Append(string.Format(" and EN_OrderInfo_Num like '%{0}%'", txtOrderNum.Text));
    if (txtStartTime.Text.Length != 0)
    sbSql.Append(string.Format(" and DL_OrderProcess_ReceiveDate >= '{0}'", txtStartTime.Text));
    if (txtEndTime.Text.Length != 0)
    sbSql.Append(string.Format(" and DL_OrderProcess_AdvanceDate <= '{0}'", txtEndTime.Text));
    Cache["StrWhere_DoingOrder"] = sbSql.ToString();//根据查询条件查询数据后保存至缓存
    QueryData(sbSql.ToString());
    }
     
    protected void lnkReset_Click(object sender, EventArgs e)
    {
    this.txtStartTime.Text = DateTime.Now.AddMonths(-1).ToString("yyyy-MM-dd");
    this.txtEndTime.Text = DateTime.Now.ToString("yyyy-MM-dd");
    this.txtOrderNum.Text = "";
    if (Cache["StrWhere_DoingOrder"] != null)//重置时清除缓存
    Cache.Remove("StrWhere_DoingOrder");
    LoadDDLOrderType();
    QueryData(SetInitQueryString());
    }
     
     
    private void QueryData(string strWhere)
    {
    StringBuilder sb = new StringBuilder();
    if (!string.IsNullOrEmpty(strWhere))
    {
    sb.Append(strWhere);
    }
    BLL.View_Operate bll = new BLL.View_Operate();
    int page = this.AspNetPager1.CurrentPageIndex, pageSize = this.AspNetPager1.PageSize, pageCount = 0, counts = 0;
     
    DataSet ds = bll.GetListByPage("View_CheckOrderDoing", sb.ToString(), "[EN_OrderInfo_ID]", ref pageCount, ref counts, pageSize, page, "EN_OrderInfo_ID", "*", 1);
    this.dgrdOrder.DataSource = ds;
    this.dgrdOrder.DataBind();
    this.AspNetPager1.RecordCount = counts;
    }
     
     
    protected void AspNetPager1_PageChanged(object sender, EventArgs e)
    {
    if (Cache["StrWhere_DoingOrder"] == null)
    QueryData("");
    else
    QueryData(Cache["StrWhere_DoingOrder"].ToString());//当缓存不为空时使用
    }
    }
    }
    Cache 即高速缓存.那么cache是怎么样提高系统性能与运行速度呢?是不是在任何情况下用cache都能提高性能?是不是cache用的越多就越好呢?我在近 期开发的项目中有所体会,写下来当作总结也希望能跟大家一起探讨探讨,有错误的地方希望大家批评指正。
      1.Cache 是怎么样工作的?
      Cache 是分配在服务器上的一个公共的内存片。
      所谓公共指的cache只要一创建是任何一个客户端浏览器都可以通过后台代码访问到它,它面向的是所有用户,相对而言session也是服务器上的一 段内存,但他面向的是单个用户。它是服务器的一段内存块,也就是说每个cache一经创建就占用了服务器资源的。所以从这点来说我们就可以说:并不是 cache越多越好。  
      cache 是有时间限制的,超过了服务器设定的过期时间,它就会被服务器回收。
      cache 可以存放任何对象
      
      2.Cache 怎么样创建以及怎么样销毁  
      创建cache  
      在DotNet环境下通过Cache.Insert(string key,object o)方法创建。
          其中key 代表cache的ID,o代表存到cache里的对象。
      
      销毁cache 
      通过方法Cache.Remove(string key)
          其中key 代表cache的 ID.
      
      调用cache  
      Cache支持装箱/拆箱操作。如你可以把一个DataSet对象ds通过Cache.Insert(“dsCache”,ds)的方式存到Cache中,可以通过拆箱操作 DataSet ds = (DataSet)Cache[“dsCache”]来访问它。
      
      3.什么时候用cache  
      Cache 一般用于数据较固定,用的较频繁的地方。例如可以把进销存系统中可以把产品信息存入cache,在用户调用产品信息时通过调用cache即可,这样从很大 程度上减少了用户与数据库的交互,提高了系统的性能。反之,cache不适合用在数据变动快,使用范围很窄的地方。例如把一个具体采购单存入 cache中。
      
      4.cache 调用注意事项  
      Cache是有时间限制的。超过了服务器设置的过期时间,就会被服务器回收。当cache被回收后对应的内存块就会被清空,再次通过cache[“cachekey”]访问对象时返回的就是null值。所以以下这种调用就会出现异常
      
      DataSet ds = (DataSet)Cache[“cacheds”];  
      DataRow dr = ds.Table[0].Row[0]; //出错,ds为null值,不存在表0。
      
      正确的写法应该是:  
      DataSet ds;  
      if(Cache[“cacheds”] != null)  
      {  
          ds = (DataSet)Cache[“cacheds”];  
      }  
      else  
      {  
          ds= GetDsFromDataBase();  
      }  
      DataRow dr = ds.Table[0].Row[0]; 
  • 相关阅读:
    ElementUI 组件不支持@keyup 的解决办法
    ElementUI 实现头部组件和左侧组件效果
    ElementUI 整体页面布局
    vue路由登录拦截
    vue中使用localStorage存储信息
    ElementUI Checkbox 多选框
    vue拦截器qs
    (未完)经典Web漏洞实战演练靶场笔记
    文件包含漏洞实战靶场笔记
    文件解析漏洞总结
  • 原文地址:https://www.cnblogs.com/sherlockholmes/p/5286984.html
Copyright © 2020-2023  润新知