真分页

Imports System.Data.SqlClient

Partial Class _Default
    Inherits System.Web.UI.Page

    Private pagesize As Integer = 3

    Private Function getPageCount() As Integer
        Using con As SqlConnection = New SqlConnection("Data Source=.;Initial Catalog=master;User ID=sa;Password=Abcdefg1")
            con.Open()
            Using cmd As SqlCommand = New SqlCommand("select count(*) from t_user", con)
                Return Math.Ceiling(cmd.ExecuteScalar() / pagesize)
            End Using
        End Using
    End Function

    Private Sub BindData()
        Using con As SqlConnection = New SqlConnection("Data Source=.;Initial Catalog=master;User ID=sa;Password=Abcdefg1")
            Using cmd As SqlCommand = New SqlCommand("select * from (select row_number() over(order by username desc) as rid,* from t_user) as t where rid between @s and @e", con)
                con.Open()
                cmd.Parameters.AddWithValue("s", (Me.Label1.Text - 1) * pagesize + 1)
                cmd.Parameters.AddWithValue("e", Me.Label1.Text * pagesize)
                Using sdr As SqlDataReader = cmd.ExecuteReader()
                    Me.Repeater1.DataSource = sdr
                    Me.Repeater1.DataBind()
                End Using
            End Using
        End Using
    End Sub

    Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
        If Not IsPostBack Then
            Me.Label1.Text = 1
            Me.Label2.Text = getPageCount()
            Me.BindData()
        End If
    End Sub

    Protected Sub Button1_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button1.Click
        Me.Label1.Text = 1
        Me.BindData()
    End Sub

    Protected Sub Button2_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button2.Click
        If Label1.Text > 1 Then
            Label1.Text -= 1
        End If
        Me.BindData()
    End Sub

    Protected Sub Button3_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button3.Click
        If Label1.Text + 0 < Label2.Text Then
            Label1.Text += 1
        End If
        Me.BindData()
    End Sub

    Protected Sub Button4_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button4.Click
        Me.Label1.Text = Me.getPageCount()
        Me.BindData()
    End Sub

    Protected Sub Button5_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button5.Click
        If Me.TextBox3.Text >= 1 AndAlso Me.TextBox3.Text <= getPageCount() Then
            Me.Label1.Text = Me.TextBox3.Text
        End If
        Me.BindData()
    End Sub

    Protected Sub Repeater1_ItemCommand(ByVal source As Object, ByVal e As System.Web.UI.WebControls.RepeaterCommandEventArgs) Handles Repeater1.ItemCommand
        Dim s As String = e.CommandName
        If s.Equals("delete") Then
            Response.Write("de")
        ElseIf s.Equals("update") Then
            Response.Write("up")
        End If
    End Sub

    Protected Sub Repeater1_ItemDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.RepeaterItemEventArgs) Handles Repeater1.ItemDataBound
        Response.Write("帮了一次")
    End Sub
End Class

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值