C#winform上下页,首末页

namespace WindowsApplication1
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        public static int  INum=0,AllCount=0;
        int Sizes = 8;//每页显示数
        private void Form1_Load(object sender, EventArgs e)
        {
            using (SqlConnection con = new SqlConnection(@"server = (local)\SQL2005;Integrated Security = true;" + "DataBase = db_09"))
            {
                SqlDataAdapter da = new SqlDataAdapter("select * from 工资表",con);
                DataTable dt = new DataTable();
                da.Fill(dt);
                
	     int i=dt.Rows.Count;
               AllCount = i;   //数据总数
                         
                 int m = i % Sizes;
                if (m == 0)
                {
                    m = i / Sizes;
                }
                else
                {
                    m = i / Sizes+1;
                }
                this.label3.Text = m.ToString();
                show(0,Sizes);
                this.label4.Text = "1";
            }
        }
        /// <summary>
        /// 显示数据
        /// </summary>
        /// <param name="i">开始位置从0开始</param>
        /// <param name="j">显示数据个数</param>
        private void show(int i,int j)
        {
            SqlConnection con = new SqlConnection(@"server = (local)\SQL2005;Integrated Security = true;" + "DataBase = db_09");
            SqlDataAdapter daone = new SqlDataAdapter("select * from 工资表", con);
            DataSet dsone = new DataSet();
            daone.Fill(dsone, i, j, "one");
            this.dataGridView1.DataSource = dsone.Tables["one"].DefaultView;
            dsone = null;
         }
        private void linkLabel1_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)//第一页
        {
            this.dataGridView1.DataSource = null;
            this.label4.Text = "1";
            show(0, Convert.ToInt16(this.label4.Text) * Sizes);
       }
        private void linkLabel2_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)//末页
        {
             this.label4.Text = this.label3.Text;
            this.dataGridView1.DataSource = null;
            show(Convert.ToInt16(this.label4.Text) * Sizes - Sizes,AllCount-1);
        }
        private void linkLabel3_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)//上一页
        {
            this.dataGridView1.DataSource = null;
             int m=Convert.ToInt16(this.label4.Text) - 1;
            if (m < 1)
            {
                this.label4.Text = "1";
            }
            else
            {
                this.label4.Text = m.ToString();
            }
            int a = Convert.ToInt16(this.label4.Text) * Sizes - Sizes;
            show(a, Sizes);
         }
        private void linkLabel4_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)//下一页
        {
            this.dataGridView1.DataSource = null;
            int m = Convert.ToInt16(this.label4.Text) + 1;
            if (m > Convert.ToInt16(this.label3.Text))
            {
                this.label4.Text = this.label3.Text;
            }
            else
            {
                this.label4.Text = m.ToString();
            }
            int a = Convert.ToInt16(this.label4.Text) * Sizes - Sizes;
            show(a, Sizes);
         }
    }
}

 

这个就是分页显示数据的
看看吧,改一些参数值,实验下 看是不是想要的效果,这里4个label 的顺序是,首页,末页,上一页,下一页。可以根据需要变下。 
把label换成button 也可以,你先建立个数据库,录入几个数实验下,看是不是想的效果。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值