前台HTML代码:

<%@ Page Language="C#" AutoEventWireup="true"  CodeFile="Default.aspx.cs" Inherits="_Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
<title>无标题页</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<table class="style1">
<tr>
<td>
原始排序:</td>
</tr>
<tr>
<td>
<asp:GridView ID="gv1" runat="server" AutoGenerateColumns="False" Width="306px"
CellPadding="4" ForeColor="#333333" GridLines="None" style="font-size: small">
<RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
<Columns>
<asp:BoundField DataField="cardNo" HeaderText="卡号" />
<asp:BoundField DataField="cardBound" HeaderText="内卡号" />
<asp:BoundField DataField="name" HeaderText="姓名" />
<asp:BoundField DataField="mobileID" HeaderText="机器码" />
</Columns>
<FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
<PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
<SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
<HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
<EditRowStyle BackColor="#999999" />
<AlternatingRowStyle BackColor="White" ForeColor="#284775" />
</asp:GridView>
</td>
</tr>
<tr>
<td>
按内卡号排序:</td>
</tr>
<tr>
<td>
<asp:GridView ID="gv2" runat="server" AutoGenerateColumns="False" Width="306px"
CellPadding="4" ForeColor="#333333" GridLines="None" style="font-size: small">
<RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
<Columns>
<asp:BoundField DataField="cardNo" HeaderText="卡号" />
<asp:BoundField DataField="cardBound" HeaderText="内卡号" />
<asp:BoundField DataField="name" HeaderText="姓名" />
<asp:BoundField DataField="mobileID" HeaderText="机器码" />
</Columns>
<FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
<PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
<SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
<HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
<EditRowStyle BackColor="#999999" />
<AlternatingRowStyle BackColor="White" ForeColor="#284775" />
</asp:GridView>
</td>
</tr>
<tr>
<td>
按机器码排序:</td>
</tr>
<tr>
<td>
<asp:GridView ID="gv3" runat="server" AutoGenerateColumns="False" Width="306px"
CellPadding="4" ForeColor="#333333" GridLines="None" style="font-size: small">
<RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
<Columns>
<asp:BoundField DataField="cardNo" HeaderText="卡号" />
<asp:BoundField DataField="cardBound" HeaderText="内卡号" />
<asp:BoundField DataField="name" HeaderText="姓名" />
<asp:BoundField DataField="mobileID" HeaderText="机器码" />
</Columns>
<FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
<PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
<SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
<HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
<EditRowStyle BackColor="#999999" />
<AlternatingRowStyle BackColor="White" ForeColor="#284775" />
</asp:GridView>
</td>
</tr>
</table> <asp:DropDownList ID="dlFilter" runat="server" AutoPostBack="True" DataTextFormatString="cardNo:{0}" OnSelectedIndexChanged="dlFilter_SelectedIndexChanged" Width="150px" AppendDataBoundItems="True">
<asp:ListItem Value="-1">选择分类编号</asp:ListItem>
</asp:DropDownList>
<asp:Label ID="lbData" runat="server"></asp:Label>
</div>
</form>
</body>
</html>

后台CS文件代码:

using System;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq; using System.Data.SqlClient;
using System.Text; public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
//排序
string conStr = "server=.;database=TYW;uid=sa;pwd=123.456;";
SqlConnection conn = new SqlConnection(conStr);//创建连接对象
if (conn.State.Equals(ConnectionState.Closed))
conn.Open();//显式地打开数据库连接
string strsql = "select top 5 cardNo,cardBound,name,mobileID from card";
SqlDataAdapter da = new SqlDataAdapter(strsql, conn);//创建数据适配器
DataSet ds = new DataSet();//创建数据集
da.Fill(ds, "card");//填充数据集 原始排序
gv1.DataSource = ds.Tables["card"];
DataView view2 = new DataView(ds.Tables["card"]);
view2.Sort = "cardBound";//设置排序表达式
gv2.DataSource = view2;//将排序后的DataView视图中数据绑定到GridView控件中
DataView view3 = new DataView(ds.Tables["card"]);
view3.Sort = "mobileID";//设置排序表达式
gv3.DataSource = view3;//将排序后的DataView视图中数据绑定到GridView控件中
Page.DataBind();//为整个页面中控件绑定数据
conn.Close();//关闭数据库连接 ///显示UrlID的数据
ReadUrlIDData();
///从Session中获取缓存的数据
if (Session["cardData"] == null)
{ ///如果没有缓存数据,则添加新的数据到缓存中
Session["cardData"] = ReadData();
///显示数据
ShowData(((DataTable)Session["cardData"]).DefaultView);
}
}
}
private void ReadUrlIDData()
{ ///创建数据库链接
string conString = "server=.;database=TYW;uid=sa;pwd=123.456;";
SqlConnection myCon = new SqlConnection(conString);
///创建执行命令
SqlCommand myCmd = new SqlCommand("SELECT DISTINCT cardNo FROM card ORDER BY cardNo", myCon);
///定义dr
SqlDataReader dr = null;
try
{ ///打开数据库的链接
myCon.Open();
///从数据库读取数据
dr = myCmd.ExecuteReader();
///设置下拉框的数据
dlFilter.DataSource = dr;
dlFilter.DataTextField = "cardNo";
dlFilter.DataValueField = "cardNo";
dlFilter.DataBind();
///关闭数据读取器
dr.Close();
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
finally
{ ///关闭数据库的链接
myCon.Close();
}
} private DataTable ReadData()
{ ///创建数据库链接
string conString = "server=.;database=TYW;uid=sa;pwd=123.456;";
SqlConnection myCon = new SqlConnection(conString);
///创建执行命令
SqlCommand myCmd = new SqlCommand("SELECT * FROM card", myCon);
///定义dr
SqlDataReader dr = null;
try
{ ///打开数据库的链接
myCon.Open();
///从数据库读取数据
dr = myCmd.ExecuteReader(CommandBehavior.CloseConnection); ///创建DataTabel,并显示DataTable中的数据
return (CreateDataTableData(dr));
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
finally
{ ///关闭数据库的链接
myCon.Close();
}
return (DataTable)null;
} private DataTable CreateDataTableData(SqlDataReader dr)
{
DataTable dt = new DataTable();
///创dt的列
foreach (DataRow row in dr.GetSchemaTable().Rows)
{ ///需要列的名称和数据类型
dt.Columns.Add(new DataColumn(row["ColumnName"].ToString(), (Type)row["DataType"]));
}
///读取数据
while (dr.Read())
{ ///创建一个新行
DataRow newrow = dt.NewRow();
foreach (DataRow row in dr.GetSchemaTable().Rows)
{ ///读取数据
newrow[row["ColumnName"].ToString()] = dr[row["ColumnName"].ToString()];
}
///添加新行
dt.Rows.Add(newrow);
}
///关闭读取器
dr.Close();
return (dt);
} private void ShowData(DataView dv)
{
StringBuilder sb = new StringBuilder();
///添加表头
sb.Append("<table border=1>");
///添加表的标题栏
sb.Append("<tr>");
for (int i = ; i < dv.Table.Columns.Count; i++)
{
sb.Append("<td bgcolor=gray>");
sb.Append(dv.Table.Columns[i].ColumnName);
sb.Append("</td>");
}
sb.Append("</tr>");
///添加数据
foreach (DataRowView rowview in dv)
{ ///添加一行数据
DataRow row = rowview.Row;
sb.Append("<tr>");
for (int i = ; i < row.ItemArray.Length; i++)
{ ///添加数据的列
sb.Append("<td>");
sb.Append(row.ItemArray[i].ToString());
sb.Append("</td>");
}
sb.Append("</tr>");
}
///添加结束符号
sb.Append("</table");
sb.Append("<hr />");
///输出字符串
lbData.Text = sb.ToString();
}
protected void dlFilter_SelectedIndexChanged(object sender, EventArgs e)
{
DataTable dt;
///从Session中获取缓存的数据, 将整个数据都缓存在Session中了
if (Session["cardData"] == null)
{ ///如果没有缓存数据,则添加新的数据到缓存中
dt = ReadData();
Session["cardData"] = dt;
}
else
{
dt = (DataTable)Session["cardData"];
}
if (dlFilter.SelectedItem.Value == "-1")
{ ///设置过滤表达式
dt.DefaultView.RowFilter = "";
///显示数据
ShowData(dt.DefaultView);
}
else
{ ///设置过滤表达式
DataView dv = dt.DefaultView;
dv.RowFilter = "cardNo ='" + dlFilter.SelectedItem.Value + "'";
///显示数据
ShowData(dv);
}
}
}

025. asp.net中GridView的排序和过滤的更多相关文章

  1. Asp.net中GridView使用详解(很全,很经典 转来的)

    Asp.net中GridView使用详解 效果图参考:http://hi.baidu.com/hello%5Fworld%5Fws/album/asp%2Enet中以gv开头的图片 l         ...

  2. Asp.net中GridView使用详解(引)【转】

    Asp.net中GridView使用详解(引) GridView无代码分页排序 GridView选中,编辑,取消,删除 GridView正反双向排序 GridView和下拉菜单DropDownList ...

  3. Asp.net中GridView使用详解(很全,很经典)

    http://blog.csdn.net/hello_world_wusu/article/details/4052844 Asp.net中GridView使用详解 效果图参考:http://hi.b ...

  4. ASP.NET中Gridview一些技巧

    ASP.NET中Gridview一些技巧 一.后台覆盖掉Gridview中自动填充的值 我们可以再Gridview中的事件触发的过程中修改其中的值,而这些值将会在具体的运行过程中覆盖掉那些自动属性.这 ...

  5. Asp.net中GridView详解《转》

    ASP.NET服务器控件GridView 1         ASP.NET 服务器控件GridView使用 本教程不介绍服务器端控件的呈现,事件处理,状态等理论知识,只介绍服务器端控件的使用操作,如 ...

  6. Asp.net中GridView使用详解(引)

    GridView无代码分页排序GridView选中,编辑,取消,删除GridView正反双向排序GridView和下拉菜单DropDownList结合GridView和CheckBox结合鼠标移到Gr ...

  7. 关于开发C#中的asp.net中gridview控件的使用

    原文网址:http://blog.sina.com.cn/s/blog_67f1b4b201017663.html 1.GridView无代码分页排序: 效果图: 1.AllowSorting设为Tr ...

  8. asp.net中gridview的checkbox使用总结

    1.在gridview中的<column>中加入 <asp:TemplateField HeaderText="选择"> <ItemTemplate& ...

  9. 使用模板技术处理ASP.NET中GridView额外序号列的问题

    问题描述: 现在要在一张GridView表中添加一列来显示行号,要求是显示下一页的时候能够递增而不是从新编号.数据库中的没有相关序号列 如何在软件端实现呢? 通过测试,添加以下代码即可解决需求. &l ...

随机推荐

  1. git 教程(14)--解决冲突

    人生不如意之事十之八九,合并分支往往也不是一帆风顺的. 准备新的feature1分支,继续我们的新分支开发:

  2. Android--ListView与数据绑定(Xamarin)

    ListView 控件是一个条目容器, 用于显示集合对象(如数组, List<T>, ObservableCollection<T>等)的每一个条目, 并提供滚动功能. 列表视 ...

  3. knockoutjs with绑定导致unobtrusive validation失效的问题

    如果最初的时候with绑定的对象是空的,那么with绑定内部的unobtrusive validation规则在提交的时候无法生效,无法进行验证. 解决办法: 在提交的时候(或者with绑定的对象非空 ...

  4. BizTalk开发系列(二十八) MSMQ 适配器

    MSMQ(MicroSoft Message Queue,微软消息队列)是在多个不同的应用之间实现相互通信的一种异步传输模式,相互通信的应用可以分布于同一台机器上,也可以分布于相连的网络空间 中的任一 ...

  5. 使用seajs封装js模块

    //方法一:将函数绑定到原型上 define(function(require, exports, module) { $.fn.tab = function(option, callback) { ...

  6. 《微信小程序七日谈》- 第四天:页面路径最多五层?导航可以这么玩

    <微信小程序七日谈>系列文章: 第一天:人生若只如初见: 第二天:你可能要抛弃原来的响应式开发思维: 第三天:玩转Page组件的生命周期: 第四天:页面路径最多五层?导航可以这么玩 微信小 ...

  7. php中文汉字截取函数

    public function substrgb($in,$num) { //$num=16; $pos=0; $bytenum=0; $out=""; while($num){ ...

  8. SSRF攻击实例解析

    ssrf攻击概述 很多web应用都提供了从其他的服务器上获取数据的功能.使用用户指定的URL,web应用可以获取图片,下载文件,读取文件内容等.这个功能如果被恶意使用,可以利用存在缺陷的web应用作为 ...

  9. perl + 匹配前导模式一次或者多次

    Vsftp:/data01/mysqllog/binlog# cat a2.pl $_="aaaa@[2]sasas"; if ($_ =~/.*?(\@\[[0-9]+\]).* ...

  10. SQL Server 移动数据库

    原文:SQL Server 移动数据库 移动系统数据库在下列情况下可能很有用: 故障恢复.例如,数据库处于可疑模式下或因硬件故障而关闭. 计划的重定位. 为预定的磁盘维护操作而进行的重定位. 下列过程 ...