1.封装实体类

2.写查询方法

//SubjectData类
public List<Subject> Select(string name){List<Subject> list = new List<Subject>();cmd.CommandText = "select *from Subject where SubjectName like @a ";cmd.Parameters.Clear();cmd.Parameters.Add("@a","%"+name+"%");conn.Open();SqlDataReader dr = cmd.ExecuteReader();if (dr.HasRows){while (dr.Read()){Subject s = new Subject();s.SubjectCode = dr[0].ToString();s.SubjectName = dr[1].ToString();list.Add(s);}}conn.Close();return list;}
//StudentData类/// <summary>/// 查询方法/// </summary>/// <param name="tsql">SQL语句</param>/// <param name="hh">哈希表</param>/// <returns></returns>public List<Student> Select(string tsql,Hashtable hh){List<Student> list = new List<Student>();cmd.CommandText = tsql;cmd.Parameters.Clear();foreach( string s in hh.Keys){cmd.Parameters.Add(s,hh[s]);}conn.Open();SqlDataReader dr = cmd.ExecuteReader();if (dr.HasRows){while (dr.Read()){Student s = new Student();s.Code = dr[0].ToString();s.Name = dr[1].ToString();s.Sex = Convert.ToBoolean(dr[2]);s.Birthday = Convert.ToDateTime(dr[3]);s.SubjectCode = dr[4].ToString();s.Nation = dr[5].ToString();list.Add(s);}}conn.Close();return list;}查询方法

3.Page_Load部分,最大页方法

int PageCount = 5; //每页显示条数Hashtable hs = new Hashtable();protected void Page_Load(object sender, EventArgs e){if(!IsPostBack){string tsql = "select top "+PageCount+" *from Student";//查询前PageCount条数据//Repeater1数据源指向List<Student> list = new StudentData().Select(tsql,hs);Repeater1.DataSource = list;Repeater1.DataBind();Label2.Text = "1";//第一页//获取最大页string sql = "select *from Student";Label3.Text = MaxPageNumber(sql,hs).ToString();for (int i = 1; i <= MaxPageNumber(sql,hs); i++)//给可快速跳转列表框赋值
    {DropDownList2.Items.Add(new ListItem(i.ToString(), i.ToString()));}
}
}Page_Load

public int MaxPageNumber(string sql, Hashtable hs){List<Student> list = new StudentData().Select(sql, hs);//查询所有数据double de = list.Count / (PageCount * 1.0);int aa = Convert.ToInt32(Math.Ceiling(de));//取上限return aa;}获取最大页

4.根据组合查询拼接语句方法

/// <summary>/// /// </summary>/// <param name="sql">拼接查询前PageCount条数据的语句</param>/// <param name="sql2">查询所有的语句</param>/// <param name="tj">用于分页查询与sql等拼接</param>/// <param name="count">判断前几项是否为空</param>private void Tsql(out string sql, out string sql2,out string tj,out int count){count = 0;sql = "select top " + PageCount + " *from Student";sql2 = "select *from Student";tj = "";//性别不为空if (!string.IsNullOrEmpty(tb_sex.Text.Trim())){//判断输入的是男是女,其它输入默认为未输入内容if (tb_sex.Text.Trim() == "男"){sql += " where Sex = @a";sql2 += " where Sex = @a";tj += " where Sex = @a";hs.Add("@a", "true");count++;}else if (tb_sex.Text.Trim() == "女"){sql += " where Sex = @a";sql2 += " where Sex = @a";tj += " where Sex = @a";hs.Add("@a", "false");count++;}}//年龄不为空if (!string.IsNullOrEmpty(tb_age.Text.Trim())){int a = DateTime.Now.Year;//获取当前时间的年try//确保输入的是数字
            {int ag = Convert.ToInt32(tb_age.Text.Trim());int g = a - ag;DateTime d = Convert.ToDateTime(g.ToString() + "-1-1");if (DropDownList3.SelectedValue == ">=")//小于或等于您输入的年龄,即大于或等于某个时间
                {if (count == 0)//前面的一项未输入(性别)
                    {sql += " where Birthday " + DropDownList3.SelectedValue + "@b";sql2 += " where Birthday " + DropDownList3.SelectedValue + "@b";tj += " where Birthday " + DropDownList3.SelectedValue + "@b";}else{sql += " and Birthday " + DropDownList3.SelectedValue + "@b";sql2 += " and Birthday " + DropDownList3.SelectedValue + "@b";tj += " and Birthday " + DropDownList3.SelectedValue + "@b";}hs.Add("@b", d);}else//大于或等于您输入的年龄,即小于或等于某个时间
                {DateTime dd = Convert.ToDateTime(g.ToString() + "-12-31");if (count == 0){sql += " where Birthday " + DropDownList3.SelectedValue + "@b";sql2 += " where Birthday " + DropDownList3.SelectedValue + "@b";tj += " where Birthday " + DropDownList3.SelectedValue + "@b";}else{sql += " and Birthday " + DropDownList3.SelectedValue + "@b";sql2 += " and Birthday " + DropDownList3.SelectedValue + "@b";tj += " and Birthday " + DropDownList3.SelectedValue + "@b";}hs.Add("@b", dd);}count++;}catch{}}if (!string.IsNullOrEmpty(tb_s.Text.Trim()))//判断专业是否为空
        {List<Subject> li = new SubjectData().Select(tb_s.Text.Trim());//调用查询方法模糊查询专业if (li.Count <= 0)//未查到数据
            {}else//查到数据
            {int cou = 0;//用于查到的为多条数据foreach (Subject ub in li){if (li.Count == 1)//只查到一条数据
                    {if (count == 0)//性别与年龄输入框都未输入内容
                        {sql += " where SubjectCode =@c";sql2 += " where SubjectCode =@c";tj += " where SubjectCode =@c";}else{sql += " and SubjectCode =@c";sql2 += " and SubjectCode =@c";tj += " and SubjectCode =@c";}hs.Add("@c", ub.SubjectCode);cou++;count++;}else//查到多条数据
                    {if (cou == 0)//第一次遍历
                        {if (count == 0){sql += " where (SubjectCode =@c";sql2 += " where (SubjectCode =@c";tj += " where (SubjectCode =@c";}else//性别与年龄输入框都未输入内容
                            {sql += " and (SubjectCode =@c";sql2 += " and (SubjectCode =@c";tj += " and (SubjectCode =@c";}hs.Add("@c", ub.SubjectCode);cou++;}else{sql += " or SubjectCode =@d)";sql2 += " or SubjectCode =@d)";tj += " or SubjectCode =@d)";hs.Add("@d", ub.SubjectCode);}}}}}}Tsql方法

View Code

5.组合查询 按钮功能赋予

void Button2_Click(object sender, EventArgs e){       string sql;//拼接查询前PageCount条数据的语句string sql2;//查询所有的语句string tj;int count;Tsql(out sql, out sql2,out tj,out count);Repeater1.DataSource = new StudentData().Select(sql, hs);//数据指向
        Repeater1.DataBind();Label2.Text = "1";Label3.Text = MaxPageNumber(sql2,hs).ToString();//获取当前的最大页
        DropDownList2.Items.Clear();for (int i = 1; i <= MaxPageNumber(sql2,hs); i++)//更新快捷跳转列表框
        {DropDownList2.Items.Add(new ListItem(i.ToString(), i.ToString()));}}组合查询

View Code

6.分页代码

void btn_next_Click(object sender, EventArgs e){int pagec = Convert.ToInt32(Label2.Text) + 1;//获取下一页为第几页string sql;//拼接查询前PageCount条数据的语句string sql2;//查询所有的语句string tj;int count;Tsql(out sql, out sql2, out tj, out count);if (pagec > MaxPageNumber(sql2,hs))//当前为最大页
        {return;}else{if(count>0)//进行的是组合查询的下一页跳转
           {sql += " and Code not in(select top " + (PageCount * (pagec - 1)) + " Code from Student " + tj + ")";}else{sql += " where Code not in(select top " + (PageCount * (pagec - 1)) + " Code from Student " + tj + ")";}}Repeater1.DataSource = new StudentData().Select(sql, hs);//数据指向
        Repeater1.DataBind();Label2.Text = pagec.ToString();//更新当前页面DropDownList2.SelectedValue = pagec.ToString();}下一页

View Code

void btn_prev_Click(object sender, EventArgs e){int pagec = Convert.ToInt32(Label2.Text) - 1;//获取上一页为第几页string sql;//拼接查询前PageCount条数据的语句string sql2;string tj;int count;Tsql(out sql, out sql2, out tj, out count);if (pagec <= 0)//当前为第一页
        {return;}if (count > 0)//进行的是组合查询的上一页跳转
        {sql += " and Code not in(select top " + (PageCount * (pagec - 1)) + " Code from Student " + tj + ")";}else{sql += " where Code not in(select top " + (PageCount * (pagec - 1)) + " Code from Student " + tj + ")";}List<Student> list = new StudentData().Select(sql, hs);//数据指向Repeater1.DataSource = list;Repeater1.DataBind();Label2.Text = pagec.ToString();//更新当前页面DropDownList2.SelectedValue = pagec.ToString();}上一页

上一页

void btn_first_Click(object sender, EventArgs e){string sql;string sql2;string tj;int count;Tsql(out sql, out sql2, out tj, out count);List<Student> list = new StudentData().Select(sql, hs);//数据指向Repeater1.DataSource = list;Repeater1.DataBind();Label2.Text = "1";DropDownList2.SelectedValue = "1";}跳转到第一页

首页

void btn_end_Click(object sender, EventArgs e){string sql;string sql2;string tj;int count;Tsql(out sql, out sql2, out tj, out count);if (count > 0)//进行的是组合查询的末页跳转
        {sql += " and Code not in(select top " + (PageCount * (MaxPageNumber(sql2,hs) - 1)) + " Code from Student " + tj + ")";}else{sql += " where Code not in(select top " + (PageCount * (MaxPageNumber(sql2, hs) - 1)) + " Code from Student " + tj + ")";}List<Student> list = new StudentData().Select(sql, hs);//数据指向Repeater1.DataSource = list;Repeater1.DataBind();Label2.Text = MaxPageNumber(sql2,hs).ToString();DropDownList2.SelectedValue = MaxPageNumber(sql2,hs).ToString();}最后一页跳转

末页

void DropDownList2_SelectedIndexChanged(object sender, EventArgs e){string sql;string sql2;string tj;int count;Tsql(out sql, out sql2, out tj, out count);if (count > 0)//进行的是组合查询的快捷跳转
        {sql += " and Code not in(select top " + (PageCount * (Convert.ToInt32(DropDownList2.SelectedValue) - 1)) + " Code from Student " + tj + ")";}else{sql += " where Code not in(select top " + (PageCount * (Convert.ToInt32(DropDownList2.SelectedValue) - 1)) + " Code from Student " + tj + ")";}Repeater1.DataSource = new StudentData().Select(sql, hs);//数据指向
        Repeater1.DataBind();Label2.Text = DropDownList2.SelectedValue;}快捷跳转

快捷跳转(跳至第...页)

转载于:https://www.cnblogs.com/hongsen3/p/5994881.html

WebForm 分页与组合查询相关推荐

  1. webform 分页、组合查询综合使用

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

  2. Webform(Linq高级查、分页、组合查询)

    一.linq高级查 1.模糊查(包含) 1 public List<User> Select(string name) 2 { 3 return con.User.Where(r => ...

  3. linq的简单查询 和 组合查询

    以Car表和Brand表为例,其中Car表的Brand是Brand表的Brandcode. (1)建立两表的linq(一定要做好主外键关系,),创建之后不用修改,如要添加,另建文件. (2)Car表的 ...

  4. 多条件组合查询+分页

    比较麻烦,把他记录下来. 前台UI: 实现的类代码: 程序代码 /// <summary>         /// 多条件组合查询         /// </summary> ...

  5. dataTables分页组合查询 springMVC Hibernate

    组合查询的字段:昵称,性别,年龄,和类型.dataTable列显示字段:编号,名称,性别,年龄,类型. 1 <body> 2 <form> 3 <span>昵称:& ...

  6. 页面多条件组合查询功能 代码 如何写效率高_Jeecg Boot 2.2 首个里程碑版本发布,低代码平台

    项目介绍 JeecgBoot是一款基于代码生成器的低代码开发平台,开源界"小普元"超越传统商业企业开发平台!采用前后端分离架构:SpringBoot 2.x,Ant Design& ...

  7. LinQ高级查询、组合查询

    LinQ高级查询.组合查询 LinQ高级查询: 1.模糊查询(包含) Repeater1.DataSource = con.car.Where(r =>r.name.Contains(s)).T ...

  8. 条件查询_多条件组合查询---测试用例设计

    一.假设查询因子:A,B,C,D,E(下拉框+复选框) 1.单独查询:A:B:C:D:E - 确保单独查询的正确性,这也是最基本的. 2.两个组合查询:AB:AC:AD:AE:BC:BD:BE:CD: ...

  9. springboot使用Cassandra组合查询数据

    springboot使用Cassandra组合查询数据 在application.yml中配置cassandra pom中引入Cassandra 封装Cassandra的通用类 具体使用 实现通用接口 ...

最新文章

  1. 模块讲解----time与date time(时间模块)
  2. mysql scws_apache+mysql+php+scws+myft_scws编译安装全程记录
  3. 自动关机故障常见排除法
  4. python 二叉树递归时明明已经得到了结果,但是返回None
  5. 织梦(安装,模板,基本标签)
  6. Java jta 原理_分布式事务JTA实现Atomikos与Spring集成实践
  7. Centos7安装JDK8以及环境配置
  8. RoboCode 参考代码
  9. 使用标尺工具获取某点的坐标
  10. 深入计算机组成原理(二十七)SIMD:如何加速矩阵乘法
  11. live2d web笔记之一:官方SDK尝试
  12. JavaScript 常见安全漏洞和自动化检测技术
  13. Eclipse的Maven创建
  14. 离散数学 1. 符号表、集合和命题
  15. 35枚不同风格的设计师个人网站欣赏
  16. Hello Shader之Hello Trangle
  17. AAAI-21-DocRE-Document-Level Relation Extraction with Adaptive Thresholding and Localized Context Po
  18. 为此计算机上所有用户安装此加载项,win7打开特定网站提示“控件无法安装,windows已阻止此软件因为无法验证发行者”怎么办...
  19. 有了这25个正则表达式,代码效率提高80%
  20. 莫比乌斯进阶:bzoj 3994 约数个数和(Mobius)

热门文章

  1. 【牛客 - 373A】翻硬币问题(博弈,结论,分析)
  2. 【 HDU - 1215 】七夕节(数论,约数和公式)
  3. 14.深度学习练习:Face Recognition for the Happy House
  4. js和php能生成一样的随机数_JavaScript_JS生成某个范围的随机数【四种情况详解】,前言: JS没有现成的函数,能 - phpStudy...
  5. 建立远程ftp服务器,利用无线路由器建立FTP服务器
  6. android nougat和安卓7.1,Android Nougat 7.1.2 先睹为快
  7. 【算法系列之九】合并两个有序数组
  8. css布局 右固定,CSS左侧固定右侧自适应的五种布局方法
  9. Nginx 配置UDP负载均衡
  10. epoll的再次认识