asp.net 缓存DataTable对象

http://blog.csdn.net/suntanyong88/article/details/7946359
[csharp]

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Web;  
  5. using System.Web.UI;  
  6. using System.Web.UI.WebControls;  
  7. using System.Data;  
  8. using OrderTack.BLL;  
  9.   
  10. public partial class _Default : System.Web.UI.Page  
  11. {  
  12.     OrderTrackRouterBLL bll = new OrderTrackRouterBLL();  
  13.   
  14.     protected void Page_Load(object sender, EventArgs e)  
  15.     {  
  16.         if (!IsPostBack)  
  17.         {  
  18.             bindGrid();  
  19.         }  
  20.     }  
  21.   
  22.     /// <summary>  
  23.     /// 获取用户信息  
  24.     /// </summary>  
  25.     DataTable BindUserMeg(string name)  
  26.     {  
  27.         DataTable dtUser = bll.GetUserMsg(name);  
  28.         return dtUser;  
  29.     }  
  30.   
  31.   
  32.     void bindGrid()  
  33.     { //查询记录缓存 DataTable  
  34.         DataTable dt = BindUserMeg("");  
  35.         Cache.Insert("DSN", dt, null, DateTime.Now.AddMinutes(2), System.Web.Caching.Cache.NoSlidingExpiration);  
  36.   
  37.         GridView1.DataSource = Cache["DSN"];  
  38.         GridView1.DataBind();  
  39.     }  
  40.   
  41.   
  42.     protected void Button1_Click(object sender, EventArgs e)  
  43.     {//linq模糊查询  
  44.   
  45.        DataTable dtA = (DataTable)Cache["DSN"];  
  46.   
  47.         var query = (from a in dtA.AsEnumerable()  
  48.                     let username = a.Field<string>("OrderTrackerUserName")  
  49.                     where username.Contains(TextBox1.Text)  
  50.                     select new {  
  51.                                     OrderTrackerID=a.Field<int>("OrderTrackerID"),  
  52.                                     OrderTrackerUserName =username,  
  53.                                     OrderTrackerRealName = a.Field<string>("OrderTrackerRealName")  
  54.                                });  
  55.   
  56.         GridView1.DataSource = query;  
  57.         GridView1.DataBind();  
  58.     }  
  59. }  

[html]
  1. <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>  
  2.   
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  4.   
  5. <html xmlns="http://www.w3.org/1999/xhtml">  
  6. <head runat="server">  
  7.     <title></title>  
  8.     <link href="CSS/jquery.autocomplete.css" rel="stylesheet" type="text/css" />  
  9.      <script src="js/jquery-1.3.2.min.js" type="text/javascript"></script>  
  10.     <script src="js/jquery.autocomplete.js" type="text/javascript"></script>  
  11.     <script src="js/widgetfriendlink.js" type="text/javascript"></script>  
  12.   
  13.       
  14. </head>  
  15. <body>  
  16.     <form id="form1" runat="server">  
  17.     <div>  
  18.         <asp:GridView ID="GridView1" runat="server">  
  19.         </asp:GridView>  
  20.         <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>  
  21.           
  22.        <asp:TextBox ID="txtUserName" runat="server"></asp:TextBox>  
  23.         <asp:Button ID="Button1" runat="server" onclick="Button1_Click" Text="Button" />  
  24.           
  25.     </div>  
  26.     </form>  
  27. </body>  
  28. </html>  
  29. <script type="text/javascript">  
  30.     $(function() {//智能提示  
  31.         $("#txtUserName").autocomplete("ajax/SearchUserName2.ashx", {  
  32.             minChars: 1,  
  33.             selectFirst: false,  
  34.             matchContains: true  
  35.         });  
  36.   
  37.     })  
  38. </script>  

一般处理程序

[csharp] 
  1. <%@ WebHandler Language="C#" Class="SearchUserName2" %>  
  2.   
  3. using System;  
  4. using System.Web;  
  5.   
  6. using OrderTack.BLL;  
  7. using System.Data;  
  8. using System.Text;  
  9.   
  10.   
  11.   
  12. public class SearchUserName2 : IHttpHandler {  
  13.       
  14.     public void ProcessRequest (HttpContext context) {  
  15.         context.Response.ContentType = "text/plain";  
  16.           
  17.         string strName = context.Request.QueryString["q"];  
  18.   
  19.   
  20.         StringBuilder sb = new StringBuilder();  
  21.   
  22.   
  23.         DataTable dtA = (DataTable)HttpContext.Current.Cache["DSN"];  
  24.   
  25.   
  26.         var query = (from a in dtA.AsEnumerable()  
  27.                      let username = a.Field<string>("OrderTrackerUserName")  
  28.                      where username.Contains(strName)  
  29.                      select new  
  30.                      {  
  31.                          OrderTrackerID = a.Field<int>("OrderTrackerID"),  
  32.                          OrderTrackerUserName = username,  
  33.                          OrderTrackerRealName = a.Field<string>("OrderTrackerRealName")  
  34.                      });  
  35.   
  36.         foreach (var item in query)  
  37.         {  
  38.             sb.Append("[" + item.OrderTrackerID.ToString() + "]" + item.OrderTrackerUserName).Append("\n");  
  39.         }  
  40.           
  41.           
  42.         context.Response.Write(sb.ToString());  
  43.     }  
  44.    
  45.     public bool IsReusable {  
  46.         get {  
  47.             return false;  
  48.         }  
  49.     }  
  50.   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值