组合分页查询结合体

封装类

using System;
using System.Collections.Generic;
using System.Web;

/// <summary>
/// Car 的摘要说明
/// </summary>
public class Car
{
    private string _Code;

    public string Code
    {
        get { return _Code; }
        set { _Code = value; }
    }
    private string _Name;

    public string Name
    {
        get { return _Name; }
        set { _Name = value; }
    }
    private string _Brand;

    public string Brand
    {
        get { return _Brand; }
        set { _Brand = value; }
    }
    private DateTime _Time;

    public DateTime Time
    {
        get { return _Time; }
        set { _Time = value; }
    }
    private decimal _Oil;

    public decimal Oil
    {
        get { return _Oil; }
        set { _Oil = value; }
    }
    private int _Powers;

    public int Powers
    {
        get { return _Powers; }
        set { _Powers = value; }
    }
    private decimal _Price;

    public decimal Price
    {
        get { return _Price; }
        set { _Price = value; }
    }
}
View Code

建立方法

using System;
using System.Collections;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Web;

/// <summary>
/// CarData 的摘要说明
/// </summary>
public class CarData
{
    SqlConnection cnn = null;
    SqlCommand cmd = null;
    public CarData()
    {
        cnn = new SqlConnection("server=.;database=mydb;user=sa;pwd=123");
        cmd = cnn.CreateCommand();
        //
        // TODO: 在此处添加构造函数逻辑
        //
    }
    public List<Car> select(int meiyeshu,int dijiye)
    {
        List<Car> clist = null;
        cmd.CommandText = "select top " + meiyeshu + " * from Car where Code not in(select top "+(meiyeshu*(dijiye-1)) +" Code from Car)";
        cnn.Open();
        SqlDataReader ss = cmd.ExecuteReader();
        if (ss.HasRows)
        {
            clist = new List<Car>();
            while (ss.Read())
            {
                Car c = new Car();
                c.Code = ss[0].ToString();
                c.Name = ss[1].ToString();
                c.Brand = ss[2].ToString();
                c.Time = Convert.ToDateTime(ss[3]);
                c.Oil = Convert.ToDecimal(ss[4]);
                c.Powers = Convert.ToInt32(ss[5]);
                c.Price = Convert.ToDecimal(ss["Price"]);
                clist.Add(c);
            }
        }
        cnn.Close();
        return clist;
    }

    public List<Car> quan()
    {
        List<Car> ulist = null;
        cmd.CommandText = "select * from car";
        cnn.Open();
        SqlDataReader ss = cmd.ExecuteReader();
        if (ss.HasRows)
        {
            ulist = new List<Car>();
            while (ss.Read())
            {
                Car c = new Car();
                c.Code = ss[0].ToString();
                c.Name = ss[1].ToString();
                c.Brand = ss[2].ToString();
                c.Time = Convert.ToDateTime(ss[3]);
                c.Oil = Convert.ToDecimal(ss[4]);
                c.Powers = Convert.ToInt32(ss[5]);
                c.Price = Convert.ToDecimal(ss["Price"]);
                ulist.Add(c);
            }
        }
        cnn.Close();
        return ulist;
    }
    public List<Car> zuhecha(string sql,Hashtable h)
    {
        List<Car> ulist = null;
        cmd.CommandText = sql;
        cmd.Parameters.Clear();
        foreach (string k in h.Keys)
        {
            cmd.Parameters.Add(k, h[k]);
        }
        cnn.Open();
        SqlDataReader ss = cmd.ExecuteReader();
        if (ss.HasRows)
        {
            ulist = new List<Car>();
            while (ss.Read())
            {
                Car c = new Car();
                c.Code = ss[0].ToString();
                c.Name = ss[1].ToString();
                c.Brand = ss[2].ToString();
                c.Time = Convert.ToDateTime(ss[3]);
                c.Oil = Convert.ToDecimal(ss[4]);
                c.Powers = Convert.ToInt32(ss[5]);
                c.Price = Convert.ToDecimal(ss["Price"]);
                ulist.Add(c);
            }
        }

        cnn.Close();
        return ulist;
    
    }

}
View Code

建立框架

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
            名字<asp:TextBox ID="name_text" runat="server"></asp:TextBox> &nbsp; &nbsp;
           油耗<asp:DropDownList ID="oil_dd" runat="server">
               <asp:ListItem>&gt;=</asp:ListItem>
               <asp:ListItem>&lt;=</asp:ListItem>
              </asp:DropDownList><asp:TextBox ID="oil_text" runat="server"></asp:TextBox>&nbsp
        价格<asp:DropDownList ID="price_dd" runat="server">
            <asp:ListItem>&gt;=</asp:ListItem>
            <asp:ListItem>&lt;=</asp:ListItem>
        </asp:DropDownList><asp:TextBox ID="price_text" runat="server"></asp:TextBox><asp:Button ID="chaxun_btn" runat="server" Text="查询" />
        <br />
        <br />
        <asp:Label ID="Label1" runat="server" Text="Label"></asp:Label>
        <asp:Repeater ID="Repeater1" runat="server">
            <HeaderTemplate>
                <table style="text-align:center;width:100%">
                    <tr style="background-color:blue;">
                        <td>序号</td>
                        <td>名字</td>
                        <td>品牌</td>
                        <td>出场时间</td>
                        <td>油耗</td>
                        <td>马力</td>
                        <td>价格</td>
                    </tr>
            </HeaderTemplate>
            <ItemTemplate>
                <tr style="background-color:gray; color:white;">
                        <td><%#Eval("Code") %></td>
                        <td><%#Eval("Name") %></td>
                        <td><%#Eval("Brand") %></td>
                        <td><%#Eval("Time") %></td>
                        <td><%#Eval("Oil") %></td>
                        <td><%#Eval("Powers") %></td>
                        <td><%#Eval("Price") %></td>
                    </tr>
            </ItemTemplate>
            <FooterTemplate>
                </table>
            </FooterTemplate>
        </asp:Repeater>
        当前第<asp:Label ID="dijiye" runat="server" Text="Label"></asp:Label>页,共<asp:Label ID="gongjiye" runat="server" Text="Label"></asp:Label>页&nbsp&nbsp<asp:LinkButton ID="shangyiye_btn" runat="server">上一页</asp:LinkButton>&nbsp&nbsp<asp:LinkButton ID="xiayiye_btn" runat="server">下一页</asp:LinkButton>&nbsp&nbsp&nbsp跳转到<asp:DropDownList ID="tiaozhuan_dd" AutoPostBack="true" runat="server"></asp:DropDownList></form>
</body>
</html>
View Code

建立功能(只有查询和下一页功能)

using System;
using System.Collections;
using System.Collections.Generic;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

public partial class _Default : System.Web.UI.Page
{
    int pagecount = 5;
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            string sql = "select top "+pagecount+"*from Car";
            string sql2 = "select * from Car";
            Repeater1.DataSource = new CarData().zuhecha(sql,new Hashtable());
            Repeater1.DataBind();
            dijiye.Text = "1";
            dijiye.Text = "1";
            gongjiye.Text = maxpage(sql2, new Hashtable()).ToString();
        }
        chaxun_btn.Click += chaxun_btn_Click;//查询事件
        shangyiye_btn.Click += shangyiye_btn_Click;
        xiayiye_btn.Click += xiayiye_btn_Click;

    }

    void xiayiye_btn_Click(object sender, EventArgs e)
    {
        int next = Convert.ToInt32(dijiye.Text)+1;
        int i = 0;
        Hashtable h = new Hashtable();
        string sql = "select top " + pagecount + " * from Car";
        string sq2 = "select * from Car";//为了共几页而查
        string tj = "";
        if (!String.IsNullOrEmpty(name_text.Text.Trim()))
        {

            sql += " where Name like  @a";
            sq2 += " where Name like  @a";
            h.Add("@a", "%" + name_text.Text.Trim() + "%");
            i++;
            tj = " where Name like  @a";
        }
        if (!String.IsNullOrEmpty(oil_text.Text))
        {
            if (i == 0)
            {
                sql += " where Oil " + oil_dd.SelectedValue + " @b";
                sq2 += " where Oil " + oil_dd.SelectedValue + " @b";
                tj += " where Oil " + oil_dd.SelectedValue + " @b";
            }
            else
            {
                sql += " and Oil " + oil_dd.SelectedValue + " @b";
                sq2 += " and Oil " + oil_dd.SelectedValue + " @b";
                tj += " and Oil " + oil_dd.SelectedValue + " @b";

            }
            h.Add("@b", oil_text.Text);
            i++;
        }
        if (!String.IsNullOrEmpty(price_text.Text))
        {
            if (i == 0)
            {
                sql += " where Price " + price_dd.SelectedValue + " @c";
                sq2 += " where Price " + price_dd.SelectedValue + " @c";
                tj += " where Price " + price_dd.SelectedValue + " @c";
            }
            else
            {
                sql += " and Price " + price_dd.SelectedValue + " @c";
                sq2 += " and Price " + price_dd.SelectedValue + " @c";
                tj += " and Price " + price_dd.SelectedValue + " @c";
            }
            h.Add("@c", price_text.Text);
        }
      
        if (i > 0)
        {

            sql += " and Code not in (select top " + (pagecount * (next - 1)) + " Code from Car " + tj + ")";
        }
        else
        {
            sql += " where Code not in (select top " + (pagecount * (next - 1)) + " Code from Car " + tj + ")";
        }
        Label1.Text = sql;
        if (next > maxpage(sq2, h))
        {
            return;
        }
        dijiye.Text = next.ToString();
        gongjiye.Text = maxpage(sq2, h).ToString();
        Repeater1.DataSource = new CarData().zuhecha(sql, h);
        Repeater1.DataBind();
    }

    void shangyiye_btn_Click(object sender, EventArgs e)
    {
        throw new NotImplementedException();
    }

    void chaxun_btn_Click(object sender, EventArgs e)//查询事件
    {
        int i = 0;
        Hashtable h = new Hashtable();
        string sql = "select top "+pagecount+" * from Car";
        string sq2 = "select * from Car";
        dijiye.Text = "1";
        if (!String.IsNullOrEmpty(name_text.Text.Trim()))
        {

            sql += " where Name like  @a";
            sq2 += " where Name like  @a";
            h.Add("@a", "%" + name_text.Text.Trim() + "%");
            i++;
        }
        if (!String.IsNullOrEmpty(oil_text.Text))
        {
            if (i == 0)
            {
                sql += " where Oil "+oil_dd.SelectedValue+" @b";
                sq2 += " where Oil " + oil_dd.SelectedValue + " @b";
            }
            else
            {
                sql += " and Oil " + oil_dd.SelectedValue + " @b" ;
                sq2 += " and Oil " + oil_dd.SelectedValue + " @b";
            
            }
            h.Add("@b", oil_text.Text);
            i++;
        }
        if (!String.IsNullOrEmpty(price_text.Text))
        {
            if (i == 0)
            {
                sql += " where Price " + price_dd.SelectedValue + " @c";
                sq2 += " where Price " + price_dd.SelectedValue + " @c";
            }
            else
            {
                sql += " and Price " + price_dd.SelectedValue + " @c";
                sq2 += " and Price " + price_dd.SelectedValue + " @c";
            }
            h.Add("@c", price_text.Text);
        }
        gongjiye.Text = maxpage(sq2,h).ToString();
        Label1.Text = sql;
        Repeater1.DataSource = new CarData().zuhecha(sql,h);
        Repeater1.DataBind();
    }

    public int maxpage(String sql,Hashtable h)
    {
        List<Car> clist = new CarData().zuhecha(sql,h);
        int i =Convert.ToInt32( Math.Ceiling(clist.Count / (pagecount * 1.0)));
        return i;
    }


}
View Code

 

完!!

posted @ 2016-10-24 20:20  冲天小肥牛  阅读(125)  评论(0编辑  收藏  举报