Webform(分页、组合查询)

摘要:
一、分页1.写查询方法:publicListSelect(intPageCount,intPageNumber){//PageCount为每页显示条数,PageNumber为当前第几页Listlist=newList();cmd.CommandText="selecttop"+PageCount+"*fromStudentwhereCodeno

一、分页

1.写查询方法:

Webform(分页、组合查询)第1张Webform(分页、组合查询)第2张
public List<Student> Select(int PageCount, intPageNumber)
    {//PageCount为每页显示条数,PageNumber为当前第几页
        List<Student> list = new List<Student>();
        cmd.CommandText = "select top " + PageCount + "*from Student where Code not in (select top "+(PageCount * (PageNumber - 1))+"Code from Student)";
        conn.Open();
        SqlDataReader dr =cmd.ExecuteReader();
        if(dr.HasRows)
        {
            while(dr.Read())
            {
                Student s = newStudent();
                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();
        returnlist;
    }
查询方法

2.C#代码

Webform(分页、组合查询)第3张Webform(分页、组合查询)第4张
int PageCount = 5; //每页显示条数
    protected void Page_Load(objectsender, EventArgs e)
    {
        if(!IsPostBack)
        {
        List<Student> list = new StudentData().Select(PageCount,1);
        Repeater1.DataSource =list;
        Repeater1.DataBind();
        Label2.Text = "1";//第一页
        Label3.Text = MaxPageNumber().ToString();//总页数
}
  for (int i = 1; i <= MaxPageNumber(); i++)
    {
        DropDownList2.Items.Add(newListItem(i.ToString(), i.ToString()));
    }
}
Page_Load
Webform(分页、组合查询)第5张Webform(分页、组合查询)第6张
public intMaxPageNumber()
    {
        List<Student> list = new StudentData().select();

        double de = list.Count / (PageCount * 1.0);

        int aa = Convert.ToInt32(Math.Ceiling(de));//取上限
        returnaa;
    }
计算总页数
Webform(分页、组合查询)第7张Webform(分页、组合查询)第8张
void DropDownList2_SelectedIndexChanged(objectsender, EventArgs e)
    {
        Repeater1.DataSource = newStudentData().Select(PageCount, Convert.ToInt32(DropDownList2.SelectedValue));
        Repeater1.DataBind();
        Label2.Text =DropDownList2.SelectedValue;
    }
快速跳转
Webform(分页、组合查询)第9张Webform(分页、组合查询)第10张
void btn_end_Click(objectsender, EventArgs e)
    {
        List<Student> list = newStudentData().Select(PageCount, MaxPageNumber());
        Repeater1.DataSource =list;
        Repeater1.DataBind();
        Label2.Text =MaxPageNumber().ToString();
    }
跳转到最后一页
Webform(分页、组合查询)第11张Webform(分页、组合查询)第12张
void btn_first_Click(objectsender, EventArgs e)
    {
        List<Student> list = new StudentData().Select(PageCount, 1);
        Repeater1.DataSource =list;
        Repeater1.DataBind();
        Label2.Text ="1";
    }
跳转到第一页
Webform(分页、组合查询)第13张Webform(分页、组合查询)第14张
void btn_prev_Click(objectsender, EventArgs e)
    {
        int pagec = Convert.ToInt32(Label2.Text) - 1;
        if (pagec <=0)//判断是不是第一页,是的话什么也不干
{
            return;
        }
        List<Student> list = newStudentData().Select(PageCount, pagec);
        Repeater1.DataSource =list;
        Repeater1.DataBind();
        Label2.Text =pagec.ToString();
    }
跳转到上一页
Webform(分页、组合查询)第15张Webform(分页、组合查询)第16张
void btn_next_Click(objectsender, EventArgs e)
    {
         int pagec = Convert.ToInt32(Label2.Text) + 1;
         if (pagec > MaxPageNumber())//判断是不是最后一页,是的话什么也不干
{
             return;
         }
        Repeater1.DataSource = newStudentData().Select(PageCount,pagec);
        Repeater1.DataBind();
        Label2.Text =pagec.ToString();

    }
跳转到下一页

二、组合查询

1.查询方法

Webform(分页、组合查询)第17张Webform(分页、组合查询)第18张
1 public List<Student> Select(stringtsql,Hashtable hh)
2 {
3         List<Student> list = new List<Student>();
4         cmd.CommandText =tsql;
5 cmd.Parameters.Clear();
6         foreach( string s inhh.Keys)
7 {
8 cmd.Parameters.Add(s,hh[s]);
9 }
10 conn.Open();
11         SqlDataReader dr =cmd.ExecuteReader();
12         if(dr.HasRows)
13 {
14             while(dr.Read())
15 {
16                 Student s = newStudent();
17                 s.Code = dr[0].ToString();
18                 s.Name = dr[1].ToString();
19                 s.Sex = Convert.ToBoolean(dr[2]);
20                 s.Birthday = Convert.ToDateTime(dr[3]);
21                 s.SubjectCode = dr[4].ToString();
22                 s.Nation = dr[5].ToString();
23 list.Add(s);
24 }
25 }
26 conn.Close();
27         returnlist;
28     }
查询方法
Webform(分页、组合查询)第19张Webform(分页、组合查询)第20张
public List<Subject> Select(stringname)
    {
        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 = newSubject();
                s.SubjectCode = dr[0].ToString();
                s.SubjectName = dr[1].ToString();
                list.Add(s);
            }
        }
        conn.Close();

        returnlist;
    }
View Code

2.c#代码

Webform(分页、组合查询)第21张Webform(分页、组合查询)第22张
1 void Button2_Click(objectsender, EventArgs e)
2 {
3         int count = 0;//判断tsql是否含有where
4         Hashtable hs = new Hashtable();//哈希表
5         string tsql = "select * from Student";
6         //性别
7         if(!string.IsNullOrEmpty(tb_sex.Text.Trim()))//输入的性别非空
8 {
9             if (tb_sex.Text.Trim() == "")
10 {
11                 tsql += "where Sex = @a";
12                 hs.Add("@a", "true");
13                 count++;
14 }
15             else if (tb_sex.Text.Trim() == "")
16 {
17                 tsql += "where Sex = @a";
18                 hs.Add("@a", "false");
19                 count++;
20 }          
21 }
22         //年龄
23         if (!string.IsNullOrEmpty(tb_age.Text.Trim()))//判断年龄输入框是否为空
24 { 
25             int a =DateTime.Now.Year;
26             try {//异常保护,输入框只能是数字
27              int ag=Convert.ToInt32(tb_age.Text.Trim());
28              int g = a -ag;
29              DateTime d = Convert.ToDateTime(g.ToString()+"-1-1");
30              if (DropDownList3.SelectedValue == ">=")//列表框显示值为<=,小于某个年龄
31 {
32                  if (count == 0)
33 {
34                      tsql += "where Birthday " + DropDownList3.SelectedValue + "@b";
35 }
36                  else
37 {
38                      tsql += "and Birthday " + DropDownList3.SelectedValue + "@b";
39 }
40                  hs.Add("@b", d);
41 }
42              else//大于某个年龄
43 {
44                  DateTime dd = Convert.ToDateTime(g.ToString() + "-12-31");
45                  if (count == 0)
46 {
47                      tsql += "where Birthday " + DropDownList3.SelectedValue + "@b";
48 }
49                  else
50 {
51                      tsql += "and Birthday " + DropDownList3.SelectedValue + "@b";
52 }
53                  hs.Add("@b", dd);
54 }
55              count++;
56 }
57             catch{ 
58 }          
59 }
60         if (!string.IsNullOrEmpty(tb_s.Text.Trim()))//专业非空
61 {
62             List<Subject> li = newSubjectData().Select(tb_s.Text.Trim());
63             if (li.Count <= 0)
64 {
65 }
66             else
67             { string u ="";
68             int cou = 0;
69                 foreach(Subject ub inli)
70 {
71                     u =ub.SubjectCode;
72                     if (cou == 0)//第一条数据
73 {
74                         if (count == 0)
75 {
76                             tsql += "where SubjectCode =@c";
77 }
78                         else
79 {
80                             tsql += "and SubjectCode =@c";
81 }
82                         hs.Add("@c", u);
83                         cou++;
84 }
85                     else
86 {
87                         tsql += "or SubjectCode =@d";
88                         hs.Add("@d", u);
89 }
90 }
91 }
92 }
93         Repeater1.DataSource = newStudentData().Select(tsql, hs);
94 Repeater1.DataBind();
95     }
查询按钮赋功能

免责声明:文章转载自《Webform(分页、组合查询)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇anywhere 搭建本地服务器运行静态文件Verilog中的标点下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

随便看看

xcode模拟器不显示键盘解决方案

当我们使用Xcode进行开发时,我们并不总是需要在iPhone上运行代码。有时模拟器可以解决这些问题。但当你使用模拟器时,你会发现,如果你使用模拟器上的键盘在TextFiled中输入信息,这是可以的,但如果你使用键盘输入信息,那么你会发现模拟器上的屏幕将不再显示。这是因为默认情况下,xcode使用计算机键盘作为外部键盘,不会弹出虚拟键盘。...

MeteoInfo-Java解析与绘图教程(一)

MeteoInfo-Java解析与绘图教程(一)已经进入开发行业很多年了,这两年一直从事气象开发行业,为此对气象绘图有了新的见解像色斑图与卫星图一直都有python去绘制,在偶然的情况下,我接触到了meteoInfo,在对其使用过程中,也可以做到用java绘制格点散点图,色斑图,等值图,卫星图,风场图所以趁这个机会我开始记录自己的探索过程,方便你我他对于绘图...

GERBER文件

GERBER文件GERBER文件是一种国际标准的光绘格式文件,它包含RS-274-D和RS-274-X两种格式,其中RS-274-D称为基本GERBER格式,并要同时附带D码文件才能完整描述一张图形;RS-274-X称为扩展GERBER格式,它本身包含有D码信息。或GERBER描述是防焊层,并且描述之图形主要是防焊部分。若您自己将PCB文件转换成GERBER...

Nohup后台运行程序

场景:我现在需要跑脚本批量处理一些数据,但是我又不想盯着控制台看这个脚本的输出结果,想把这些输出结果记录到一个日志文件里面方案:可以使用Linux的nohup命令,把进程挂起,后台执行用法:$nohupXXXXXX.sh˃˃/runtime/deletedata.log&运行结果(这个数字是进程号):˃˃[1]13120有时候可能会报一个提示:$no...

GitLab 数据库

要访问GitLab数据库步骤中使用的DockerGitlab,首先输入容器dockerexec-itgitlab/bin/bash ``查找数据库配置文件``bash/var/opt/GitLab/gitlabrails/etc/database yml内容如下,记录数据库配置信息production:adapter:postgresqlencoding:u...

firefox插件-HackBar介绍与试用

HackBar实际上是一个包含一些黑客常用工具的小工具包。它的主要目的是帮助开发人员对代码进行安全审计优点是:-MD5/SHA1/SHA256哈希MySQL/MSSQLServer/Oracle快捷方式XSSulfunctions文本区域的URL重定向不会受到影响-MD5/SHA1/SHA 256哈什排列等-MySQL/MMSQLServer/Oacle快捷...