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(-).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(, "全部");
}
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 != )
{
sbSql.Append(string.Format(" and EN_OrderInfo_Num like '%{0}%'", txtOrderNum.Text));
}
if (txtStartTime.Text.Length != )
{
sbSql.Append(string.Format(" and DL_OrderProcess_ReceiveDate >= '{0}'", txtStartTime.Text));
}
if (txtEndTime.Text.Length != )
{
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 = ;
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 != )
sbSql.Append(string.Format(" and EN_OrderInfo_Num like '%{0}%'", txtOrderNum.Text));
if (txtStartTime.Text.Length != )
sbSql.Append(string.Format(" and DL_OrderProcess_ReceiveDate >= '{0}'", txtStartTime.Text));
if (txtEndTime.Text.Length != )
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(-).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 = , counts = ; DataSet ds = bll.GetListByPage("View_CheckOrderDoing", sb.ToString(), "[EN_OrderInfo_ID]", ref pageCount, ref counts, pageSize, page, "EN_OrderInfo_ID", "*", );
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());//当缓存不为空时使用
}
}
}
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];
DoingOrder.aspx.cs缓存的使用方法的更多相关文章
- WebForm.aspx 页面通过 AJAX 访问WebForm.aspx.cs类中的方法,获取数据
WebForm.aspx 页面通过 AJAX 访问WebForm.aspx.cs类中的方法,获取数据 WebForm1.aspx 页面 (原生AJAX请求,写法一) <%@ Page Langu ...
- WebForm.aspx 页面通过 AJAX 访问WebForm.aspx.cs类中的方法,获取数据(转)
WebForm.aspx 页面通过 AJAX 访问WebForm.aspx.cs类中的方法,获取数据 WebForm1.aspx 页面 (原生AJAX请求,写法一) <%@ Page Langu ...
- 通过ajax访问aspx的CodeBehind中的方法
引言 在项目中突然看到,aspx中的ajax可以访问aspx.cs中的方法,觉得很新奇,也许是lz少见多怪,不过,真的有发现新大陆似的那种兴奋,你也许知道这代表什么,学会了这种方式,代表你以后,可以建 ...
- aspx页面前端使用js 调用aspx.cs后台的方法,不回传
本次使用 Ajax.dll,AjaxPro.dll 两个类库 1.首先添加引用:Ajax.dll,AjaxPro.dll 文件在 Libiary 目录下 2.配置 WebConfig 属性 将 下面2 ...
- jQuery Ajax 方法调用 Asp.Net WebService 以及调用aspx.cs中方法的详细例子
一.jQuery Ajax 方法调用 Asp.Net WebService (引自Terry Feng) Html文件 <!DOCTYPE html PUBLIC "-//W3C//D ...
- ASHX呼叫ASPX.cs的方法
ASHX呼叫ASPX.cs的方法 问题来自论坛,有网友这样的要求,在ASHX内呼叫ASPX.cs的一个方法或函数. 在一个网站中,也许不止只有一个aspx网页.把aspx.cs内的方法宣告为publi ...
- 用juery的ajax方法调用aspx.cs页面中的webmethod方法示例
juery的ajax调用aspx.cs页面中的webmethod方法:首先在 aspx.cs文件里建一个公开的静态方法,然后加上WebMethod属性,具体实现如下,感兴趣的朋友可以参考下哈,希望对大 ...
- 用juery的ajax方法调用aspx.cs页面中的webmethod方法
首先在 aspx.cs文件里建一个公开的静态方法,然后加上WebMethod属性. 如: [WebMethod] public static string GetUserName() { //.... ...
- ASCX呼叫ASPX.CS的方法
为了安全设计,一般情况之下,改用为接口(interface). 在网页中实现这个接口: 用户控件: 当然,把用户控件ascx拉至网页之后,在用户控件的linkbutton的click事件,就可以呼叫至 ...
随机推荐
- Android 判断当前网络连接类型
实际应用开发时,如果存在需要用户获取大量数据的情况,最好是先判断下网络类型,提示用户当前的网络类型,是否需要连接Wifi,etc.(手机流量太贵啦,当然土豪是无视这玩意的, (/ □ \)). 定义网 ...
- DC-DC转换器原理与应用
DC/DC转换器为转变输入电压后,有效输出固定电压的电压转换器.DC/DC转换器分为三类:升压型DC/DC转换器.降压型DC/DC转换器以及升降压型DC/DC转换器.根据需求可采用三类控制.PWM控制 ...
- Spring boot将配置属性注入到bean类中
一.@ConfigurationProperties注解的使用 看配置文件,我的是yaml格式的配置: // file application.yml my: servers: - dev.bar.c ...
- POJ3349 Snowflake Snow Snowflakes(哈希)
题目链接. 分析: 哈希竟然能这么用.检查两片雪花是否相同不难,但如果是直接暴力,定会超时.所以要求哈希值相同时再检查. AC代码: #include <iostream> #includ ...
- HBase HFileBlock
HFileBlock官方源码注释: Reading HFile version 1 and 2 blocks, and writing version 2 blocks. In version 1 ...
- SQL 时间戳转DateTime类型
最近在工作中通过接口获取时间字段为时间戳的值,直接入库后再页面查询时间格式时候需要通过SQL语句将时间戳格式装换为时间格式进行比较,首先我们需要知道时间戳格式是怎么产生的,: Unix时间戳(Unix ...
- 推送消息 相关公司 手机端分享http://mob.com/
信鸽 http://xg.qq.com/xg/pro/ctr_message 云巴 http://yunba.io/usercases/ 极光https://www.jpush.cn/ 手机端分享ht ...
- 在SQL中使用自定义函数
由于数据库的一个表字段中多包含html标签,现在需要修改数据库的字段把html标签都替换掉.当然我可以通过写一个程序去修改,那毕竟有点麻烦.直接在查询分析器中执行,但是MS SQL Server并 ...
- 左移运算符<<
在许多计算机编程语言(例如:C语言.C++语言.Java语言.JavaScript语言,Pascal语言等)中,“<<”代表左移运算符(就相当于'shl').该运算符为双目运算符,结合方向 ...
- spring aop例子
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAATcAAAFWCAIAAACD6E2aAAAgAElEQVR4nO2df1gTV77/55/93z/2ee