1、组合查询
(1)数据访问类

//参数1:SQL语句 参数2:哈希表
public List<Users> chas(string s,Hashtable has)
{
List<Users> List = new List<Users>();
Users u = null;
com.CommandText = s;
com.Parameters.Clear();
foreach(string aa in has.Keys)
{
com.Parameters.Add(aa,has[aa]);
}
con.Open();
SqlDataReader dr = com.ExecuteReader();
if (dr.HasRows)
{
while (dr.Read())
{
u = new Users()
{
UserName = dr[].ToString(),
PassWord = dr[].ToString(),
NickName = dr[].ToString(),
Sex = Convert.ToBoolean(dr[]),
Birthday = Convert.ToDateTime(dr[]),
Phone = dr[].ToString(),
Email = dr[].ToString(),
Natoin = dr[].ToString(),
Area = dr[].ToString(),
};
List.Add(u);
}
}
con.Close();
return List;
}

(2)查找按钮事件

 Hashtable has = new Hashtable();//实例化哈希表,作用防攻击

//拼sql语句
string sqls = "select *from Users ";
if(TextBox1.Text!="")
{
sqls += " where UserName like @a";
has.Add("@a", "%" + TextBox1.Text.Trim() + "%");//将用户输入的内容放进哈希表,防攻击
count++;
}
if(Drop_nation.SelectedValue !="")
{
if(count !=)//如果上面有查询条件接and
{
sqls += " and Nation=@b"; }
else//如果上面没有查询条件接where
{
sqls += " WHERE Nation=@b"; count++;
}
string sss=Drop_nation.SelectedValue.ToString();
has.Add("@b",sss );
count++;
}

//Repeater数据绑定
      Repeater1.DataSource = new Usersdata().chas(sqls,has);
      Repeater1.DataBind();
      count = 0;

2、分页
前台

           当前第<asp:Label ID="Label1" runat="server" Text=""></asp:Label>页
共<asp:Label ID="Label2" runat="server" Text=""></asp:Label>页
<asp:LinkButton ID="LinkButton1" runat="server" >首页</asp:LinkButton>
<asp:LinkButton ID="LinkButton2" runat="server">上一页</asp:LinkButton>
<asp:LinkButton ID="LinkButton3" runat="server">下一页</asp:LinkButton>
<asp:LinkButton ID="LinkButton4" runat="server">末页</asp:LinkButton>
跳到
<asp:DropDownList ID="DropDownList1" AutoPostBack="true" runat="server"></asp:DropDownList>

后台

(1)数据访问类

//参数1:第几页 参数2:每页显示的个数
public List<Users> cha(int page,int pagecode)
{
List<Users> List = new List<Users>();
Users u = null;
//注意:sql语句
com.CommandText = "select top " + pagecode + " *FROM Users where UserName not in (select top " + ((page - ) * pagecode) + " UserName FROM Users)";
con.Open();
SqlDataReader dr = com.ExecuteReader();
if (dr.HasRows)
{
while (dr.Read())
{
u = new Users()
{
UserName = dr[].ToString(),
PassWord = dr[].ToString(),
NickName = dr[].ToString(),
Sex = Convert.ToBoolean(dr[]),
Birthday = Convert.ToDateTime(dr[]),
Phone = dr[].ToString(),
Email = dr[].ToString(),
Natoin = dr[].ToString(),
Area = dr[].ToString(),
};
List.Add(u);
}
}
con.Close();
return List;
}

(2)

//全局变量,每页显示的个数
int pagecode = ;
//跳到指定页数
void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
{
int a=Convert.ToInt32(DropDownList1.SelectedValue);//获取页数
//显示数据
Repeater1.DataSource = new Usersdata().cha(a, pagecode);
Repeater1.DataBind();
Label1.Text = a.ToString();//显示当前页
}
//下一页
void LinkButton3_Click(object sender, EventArgs e)
{
Label1.Text = (Convert.ToInt32(Label1.Text) + ).ToString();//显示下一页
if (Convert.ToInt32(Label1.Text) <= MAXPAGE(pagecode))//判断是否小于最大页
{
Repeater1.DataSource = new Usersdata().cha(Convert.ToInt32(Label1.Text), pagecode);
Repeater1.DataBind();
}
else
{
Label1.Text = MAXPAGE(pagecode).ToString();
return;
}
}
//上一页
void LinkButton2_Click(object sender, EventArgs e)
{
Label1.Text =(Convert.ToInt32(Label1.Text) - ).ToString();//显示上一页
if (Convert.ToInt32(Label1.Text)<=)//判断是否大于0页
{
Label1.Text = "";
return;
}
Repeater1.DataSource = new Usersdata().cha(Convert.ToInt32(Label1.Text), pagecode);
Repeater1.DataBind();
}
//末页
void LinkButton4_Click(object sender, EventArgs e)
{
Repeater1.DataSource = new Usersdata().cha(MAXPAGE(pagecode), pagecode);
Repeater1.DataBind();
Label1.Text = MAXPAGE(pagecode).ToString();
}
//首页
void LinkButton1_Click(object sender, EventArgs e)
{
Repeater1.DataSource = new Usersdata().cha(, pagecode);
Repeater1.DataBind();
Label1.Text = "";
} //最大页数
private static int MAXPAGE(int pagecode)
{
double ye = (new Usersdata().cha().Count) / (pagecode *1.0);
int maxye = Convert.ToInt32(Math.Ceiling(ye));
return maxye;
}

3 组合查询和分页结合使用
先查询后分页(拼SQL语句)

数据访问类:同上面的组合查询

        string sqls = "select top " + pagecode + " *from Users ";//带分页和查询条件的SQL语句
string sql2 = "select *from Users";//带查询条件的SQL的语句
string sqls1 = "";//查询条件sql语句
if (TextBox1.Text != "")
{
sqls += " where UserName like @a";
sqls1 += " where UserName like @a";
has.Add("@a", "%" + TextBox1.Text.Trim() + "%");
count++;
}
if (Drop_nation.SelectedValue != "")
{
if (count != )
{
sqls += " and Nation=@b";
sqls1 += " and Nation=@b";
}
else
{
sqls += " WHERE Nation=@b";
sqls1 += " WHERE Nation=@b";
count++;
}
string sss = Drop_nation.SelectedValue.ToString();
has.Add("@b", sss);
count++;
} if (count > )
{
sqls += " and UserName not in (select top " + ((Convert.ToInt32(Label1.Text) - ) * pagecode) + " UserName from Users" + sqls1 + ")";
}
else
{
sqls += " where UserName not in (select top " + ((Convert.ToInt32(Label1.Text) - ) * pagecode) + " UserName from Users)";
}
//用label记录sql语句并隐藏,当上一页、下一页等可以从label中取出用

Label3.Text = sqls;
Label4.Text = sqls1;
Label5.Text = sql2 + sqls1;

//Repeater数据绑定
Repeater1.DataSource = new Usersdata().chas(Label3.Text, has);
Repeater1.DataBind();

webform组合查询和分页的更多相关文章

  1. Web 组合查询加 分页

    使用ADO.NET 数据访问技术制作web端组合查询加分页的功能关键在于查询SQL语句的拼接 以Car 表为例 每页显示3条数据 数据访问类使用查询方法,tsql 查询的连接字符串,查询的参数放到Ha ...

  2. LINQ 小项目【组合查询、分页】

    使用 linq 在网页上对用户信息增删改,组合查询,分页显示 using System; using System.Collections.Generic; using System.Linq; us ...

  3. Linq组合查询与分页组合查询结合

    1.组合查询 <div>姓名:<asp:TextBox ID="T1" runat="server"></asp:TextBox& ...

  4. WebForm组合查询

    封转类 using System; using System.Collections.Generic; using System.Linq; using System.Web; /// <sum ...

  5. LinQ 组合查询与分页

    1.以开头查 public List<Car> Select1(string a){ return con.Car.Where(r => r.Name.StartsWith(a)). ...

  6. LinkQ 组合查询与分页

    1.以开头查 public List<Car> Select1(string a){ return con.Car.Where(r => r.Name.StartsWith(a)). ...

  7. spring boot jpa 多条件组合查询带分页的案例

    spring data jpa 是一个封装了hebernate的dao框架,用于单表操作特别的方便,当然也支持多表,只不过要写sql.对于单表操作,jpake可以通过各种api进行搞定,下面是一个对一 ...

  8. webform 组合查询

    界面: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx ...

  9. LINQ 组合查询 和分页查询的使用

    前端代码 <%@ Page Language="C#" AutoEventWireup="true" Debug="true" Cod ...

随机推荐

  1. 防刷新jq左侧滚动条导航展示

    html代码: <div class="fangchan_navcont">        <div class="fangchan_nav" ...

  2. 用collectionview实现瀑布流-转

    算法总体思路 先说一下总体上的思路.既然图片的大小.位置各不一样,我们很自然地会想到需要算出每个item的frame,然后把这些frame赋值给当前item的UICollectionViewLayou ...

  3. Shell基础-Bash变量-用户自定义变量

    变量设置规则: 变量名称可以由字母.下划线和数字组成,但是不能由数字开头. 在Bash中变量的默认类型是字符串类型,若需要进行数值运算,则需指定变量类型为数值型.变量用等号链接,且两边不能有空格.若需 ...

  4. Objective-c——UI进阶开发第一天(UIPickerView和UIDatePicker)

    一.知识点 1.介绍数据选择控件UIPickerView和日期选择控件UIDatePicker控件 * UIPickerView的案例 * 点餐系统 * 城市选择 * 国旗选择 * UIDatePic ...

  5. Android——手机内部文件存储(作业)

    作业:把用户的注册信息存储到文件里,登录成功后读出并显示出来 activity_practice2的layout文件: <?xml version="1.0" encodin ...

  6. 切换到android studio环境

    下载: android-studio-bundle-135.1740770-windows.exe sysimg_arm-21_r03.zip 设置环境变量: ANDROID_SDK_HOME     ...

  7. HighCharts使用心得

    HighCharts使用心得 前言: 之前很早的一个项目中使用过highcharts,感觉挺方便的,图表类型也比较丰富,而且还支持数据的下钻,但是如果投入商业使用的话还会有一些版权的问题,所以后来就使 ...

  8. 大师教你<部落冲突>如何切换账号

    前提申请两个谷歌账号,账号一和账号二,想要切换账号,只需清除部落冲突在手机上的数据即可.详情请看下文! 1. 第一次登陆,进入游戏后 2. 没有谷歌商店的童鞋,下载谷歌安装器(一键修复)以及VPNFQ ...

  9. 黄聪:jquery 校验中国身份证号码

    大陆18位身份证(第二代身份证) 身份号码是一组具有特征组合码,由十七位数字本体码和一位校验码组成. 排列顺序从左至右依次为:六位数字地区码,八位数字生日码,三位数字顺序码和一位数字校验码. 校验方法 ...

  10. FCKeditor 2.6.4.1 初始化值不能显示中文问题

    最近在学习PHP加入FCKeditor 在线编辑器,发现在初始化Value赋值时,英文可以显示出来,中文怎么都显示不出来,连乱码都不显示. 经过漫长的探索,终于找到原因了! 在fckeditor目录下 ...