用類定義窗體

using System;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Windows.Forms;


namespace cztocf
{
    public class button1 : Button
    {
        Button ok = new Button();


        public button1()
        {
            ok.Text = "ccee";
            ok.ForeColor = System.Drawing.Color.Red;
            this.Controls.Add(ok);
        }
    }
    public class classcount
    {
        public int backvalue(int x, int y)
        {
            return x + y;
        }
    }
    public class PagingSample : Form
    {
        Button prevBtn = new Button();
        Button nextBtn = new Button();

        static DataGrid myGrid = new DataGrid();
        static Label pageLbl = new Label();

        // 分页变量
        static int pageSize = 10;      // 要显示的页数
        static int totalPages = 0;      // 总页数
        static int currentPage = 0;      // 当前页
        static string firstVisibleCustomer = "";  // 当前页的第一条记录,用来进行移动“前一页”的定位。
        static string lastVisibleCustomer = "";    //当前页的最后条记录,用来进行移动“下一页”的定位。

        // DataSet用来绑定到DataGrid.
        static DataTable custTable;

        //初始化连接和DataAdapter.
        static SqlConnection nwindConn = new SqlConnection("Data Source=.;Integrated Security=SSPI;Initial Catalog=northwind");
        static SqlDataAdapter custDA = new SqlDataAdapter("", nwindConn);
        static SqlCommand selCmd = custDA.SelectCommand;

        public static void GetData(string direction)
        {
            // 创建返回一页记录的SQL语句
            selCmd.Parameters.Clear();

            switch (direction)
            {
                case "下一页":
                    selCmd.CommandText = "SELECT TOP " + pageSize + " CustomerID, CompanyName FROM Customers " +
                                  "WHERE CustomerID > @CustomerId ORDER BY CustomerID";
                    selCmd.Parameters.Add("@CustomerId", SqlDbType.VarChar, 5).Value = lastVisibleCustomer;
                    break;
                case "前一页":
                    selCmd.CommandText = "SELECT TOP " + pageSize + " CustomerID, CompanyName FROM Customers " +
                                  "WHERE CustomerID < @CustomerId ORDER BY CustomerID DESC";
                    selCmd.Parameters.Add("@CustomerId", SqlDbType.VarChar, 5).Value = firstVisibleCustomer;
                    break;
                default:
                    selCmd.CommandText = "SELECT TOP " + pageSize + " CustomerID, CompanyName FROM Customers ORDER BY CustomerID";

                    // 计算总页数
                    SqlCommand totCMD = new SqlCommand("SELECT Count(*) FROM Customers", nwindConn);
                    nwindConn.Open();
                    int totalRecords = (int)totCMD.ExecuteScalar();
                    nwindConn.Close();
                    totalPages = (int)Math.Ceiling((double)totalRecords / pageSize);

                    break;
            }

            // 用查询结果填充临时表
            DataTable tmpTable = new DataTable("Customers");
            int recordsAffected = custDA.Fill(tmpTable);

            // 如果表不存在,就创建
            if (custTable == null)
                custTable = tmpTable.Clone();

            // 如果有记录返回,就刷新表
            if (recordsAffected > 0)
            {
                switch (direction)
                {
                    case "下一页":
                        currentPage++;
                        break;
                    case "上一页":
                        currentPage--;
                        break;
                    default:
                        currentPage = 1;
                        break;
                }

                pageLbl.Text = "第" + currentPage + "/ " + totalPages + "页";

                // 清除行集,添加新记录
                custTable.Rows.Clear();

                foreach (DataRow myRow in tmpTable.Rows)
                    custTable.ImportRow(myRow);

                // 保存first 和 last 关键值
                DataRow[] ordRows = custTable.Select("", "CustomerID ASC");
                firstVisibleCustomer = ordRows[0][0].ToString();

                lastVisibleCustomer = ordRows[custTable.Rows.Count - 1][0].ToString();
            }
        }

 

        public PagingSample()
        {
            // 初始化控件并添加到Form
            this.ClientSize = new Size(560, 574);

            this.Text = "NorthWind 数据表";

            myGrid.Location = new Point(10, 10);
            myGrid.Size = new Size(340, 320);
            myGrid.AllowSorting = true;
            myGrid.CaptionText = "NorthWind 客户信息";
            myGrid.ReadOnly = true;
            myGrid.AllowNavigation = false;
            myGrid.PreferredColumnWidth = 150;

            prevBtn.Text = "前一页";
            prevBtn.Size = new Size(60, 24);
            prevBtn.Location = new Point(70, 340);
            prevBtn.Click += new EventHandler(Prev_OnClick);

            nextBtn.Text = "下一页";
            nextBtn.Size = new Size(60, 24);
            nextBtn.Location = new Point(140, 340);

            pageLbl.Text = "没有记录返回";
            pageLbl.Size = new Size(130, 16);
            pageLbl.Location = new Point(200, 244);

            this.Controls.Add(myGrid);
            this.Controls.Add(prevBtn);
            this.Controls.Add(nextBtn);
            this.Controls.Add(pageLbl);
            nextBtn.Click += new EventHandler(Next_OnClick);


            // 计算默认的第一页,并进行绑定
            GetData("Default");
            DataView custDV = new DataView(custTable, "", "CustomerID", DataViewRowState.CurrentRows);
            myGrid.SetDataBinding(custDV, "");
        }

 

        public static void Prev_OnClick(object sender, EventArgs args)
        {
            GetData("前一页");
        }

        public static void Next_OnClick(object sender, EventArgs args)
        {
            GetData("下一页");
        }

        private void InitializeComponent()
        {
            this.SuspendLayout();
            //
            // PagingSample
            //
            this.ClientSize = new System.Drawing.Size(543, 371);
            this.Name = "PagingSample";
            this.Load += new System.EventHandler(this.PagingSample_Load);
            this.ResumeLayout(false);

        }

        private void PagingSample_Load(object sender, EventArgs e)
        {

        }

    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值