zoukankan      html  css  js  c++  java
  • Webform(分页、组合查询)

    一、分页

    1.写查询方法:

    public List<Student> Select(int PageCount, int PageNumber)
        {//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 = 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;
        }
    查询方法

    2.C#代码

    int PageCount = 5; //每页显示条数
        protected void Page_Load(object sender, 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(new ListItem(i.ToString(), i.ToString()));
        }
    }
    Page_Load
    public int MaxPageNumber()
        {
            List<Student> list = new StudentData().select();
    
            double de = list.Count / (PageCount * 1.0);
    
            int aa = Convert.ToInt32(Math.Ceiling(de));//取上限
            return aa;
        }
    计算总页数
    void DropDownList2_SelectedIndexChanged(object sender, EventArgs e)
        {
            Repeater1.DataSource = new StudentData().Select(PageCount, Convert.ToInt32(DropDownList2.SelectedValue));
            Repeater1.DataBind();
            Label2.Text = DropDownList2.SelectedValue;
        }
    快速跳转
    void btn_end_Click(object sender, EventArgs e)
        {
            List<Student> list = new StudentData().Select(PageCount, MaxPageNumber());
            Repeater1.DataSource = list;
            Repeater1.DataBind();
            Label2.Text = MaxPageNumber().ToString();
        }
    跳转到最后一页
    void btn_first_Click(object sender, EventArgs e)
        {
            List<Student> list = new StudentData().Select(PageCount, 1);
            Repeater1.DataSource = list;
            Repeater1.DataBind();
            Label2.Text ="1";
        }
    跳转到第一页
    void btn_prev_Click(object sender, EventArgs e)
        {
            int pagec = Convert.ToInt32(Label2.Text) - 1;
            if (pagec <=0)//判断是不是第一页,是的话什么也不干
            {
                return;
            }
            List<Student> list = new StudentData().Select(PageCount, pagec);
            Repeater1.DataSource = list;
            Repeater1.DataBind();
            Label2.Text = pagec.ToString();
        }
    跳转到上一页
    void btn_next_Click(object sender, EventArgs e)
        {
             int pagec = Convert.ToInt32(Label2.Text) + 1;
             if (pagec > MaxPageNumber())// 判断是不是最后一页,是的话什么也不干
             {
                 return;
             }
            Repeater1.DataSource = new StudentData().Select(PageCount,pagec);
            Repeater1.DataBind();
            Label2.Text = pagec.ToString();
    
        }
    跳转到下一页

    二、组合查询

    1.查询方法

     1 public List<Student> Select(string tsql,Hashtable hh)
     2     {
     3         List<Student> list = new List<Student>();
     4         cmd.CommandText = tsql;
     5         cmd.Parameters.Clear();
     6         foreach( string s in hh.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 = new Student();
    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         return list;
    28     }
    查询方法
    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;
        }
    View Code

    2.c#代码

     1 void Button2_Click(object sender, 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 = new SubjectData().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 in li)
    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 = new StudentData().Select(tsql, hs);
    94         Repeater1.DataBind();
    95     }
    查询按钮赋功能
  • 相关阅读:
    eclipse快速收缩展开代码
    Java中this关键字在构造方法中的使用
    Java中String的常用方法
    Java中的Comparable<T>和Comparator<T>接口
    Oracle中的自增-序列-SEQUENCE
    Java中的代码块
    Oracle中的约束
    Oracle中对表的操作
    ROWID-Oracle中删除重复行数据
    Selenium简单回顾
  • 原文地址:https://www.cnblogs.com/1711643472qq/p/6179319.html
Copyright © 2011-2022 走看看