前台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. STL中的lower_bound和upper_bound的理解

    STL迭代器表述范围的时候,习惯用[a, b),所以lower_bound表示的是第一个不小于给定元素的位置 upper_bound表示的是第一个大于给定元素的位置. 譬如,值val在容器内的时候,从 ...

  2. Chapter 4: Tomcat Default Connector

    一.概述 第三章介绍的connector是一个很好的学习工具,但是我们还可以做的更多.这一章介绍的是Tomcat4默认的connector. 一个Tomcat的connector是一个独立的模块,能够 ...

  3. 【Oracle XE系列之三】使用OMF方式手工创建Oracle XE数据库

    环境:win10_X64_Pro 1.创建数据库实例,实例名为PF C:\oraclexe\app\oracle\product\11.2.0\server\bin>oradim -new -s ...

  4. 【LeetCode OJ】Palindrome Partitioning

    Problem Link: http://oj.leetcode.com/problems/palindrome-partitioning/ We solve this problem using D ...

  5. mysql [ERROR] Can't create IP socket: Permission denied

    /*************************************************************************** * mysql [ERROR] Can't c ...

  6. [virsh] error: unknown OS type hvm解决办法

    今天在linux服务器上编译安装升级了下qemu,升级命令如下: root@ubuntu:/opt/qemu-# ./configure --prefix=/usr/local/ --target-l ...

  7. GFF format

    后记: ************************************************************************ 在使用cufflinks和cuffmerge中 ...

  8. Hamming Codes

    1. 海明校验码检错采用的是分组交叉奇偶校验法.     将编码中的数据位分成r个校验组,组内采取奇偶校验,每组一个校验位,可构成r位检错码.r>1     全部检错码为0表示数据正常,不为零时 ...

  9. ANTLR3完全参考指南读书笔记[01]

    引用 Terence Parr. The Definitive ANTLR Reference, Building Domain Specific Languages(antlr3 version). ...

  10. 137. Single Number II

    Given an array of integers, every element appears three times except for one. Find that single one. ...