zoukankan      html  css  js  c++  java
  • WebForm 分页与组合查询

    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;
        }
    
    快捷跳转
    快捷跳转(跳至第...页)
  • 相关阅读:
    初学:利用mybatis-generator自动生成代码
    数组求和forEach方法
    Node.js热部署代码,实现修改代码后自动重启服务方便实时调试
    nodejs中文乱码问题
    简单说一下SS的原理
    Spring Cloud Eureka 3 (Eureka client注册服务提供者)
    Spring Cloud Eureka 2 (Eureka Server搭建服务注册中心)
    Spring Cloud Eureka 1(eureka简介)
    eclipse中创建多模块maven web项目
    eclipse中创建maven web项目
  • 原文地址:https://www.cnblogs.com/hongsen3/p/5994881.html
Copyright © 2011-2022 走看看