2011-11-22 71 views
1

我的Gridview不会进行页面排序或排序。通过这个我的意思是,当我尝试按列进行排序或者当我尝试通过GridView进行页面调度时,GridView中的数据不会改变。GridView在用户控件中不进行分页或排序

我把它放在用户控件上的UpdatePanel中(.ascx)。当我在用户控制之外尝试时,下面的代码正常工作。

这里是我的代码:

<asp:GridView runat="server" ID="grdStats" AutoGenerateColumns="false" Width="100%" AllowSorting="true" 
     AllowPaging="true" PageSize="20" PagerSettings-Mode="NumericFirstLast" PagerSettings-Position="TopAndBottom"> 
     <Columns> 
      <asp:BoundField DataField="campaignname" HeaderText="Campaign Name" SortExpression="campaignname" /> 
      <asp:BoundField DataField="site_name" HeaderText="Outlet" SortExpression="site_name" /> 
      <asp:BoundField DataField="filename" HeaderText="Media" SortExpression="filename" /> 
      <asp:BoundField DataField="playinterval" HeaderText="Play Interval" SortExpression="playinterval" /> 
     </Columns> 
    </asp:GridView> 

这里的后端:

Protected Sub grdStats_PageIndexChanging(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewPageEventArgs) Handles grdStats.PageIndexChanging 
    grdStats.PageIndex = e.NewPageIndex 
    GetCampaignData() 
End Sub 

Protected Sub grdStats_Sorting(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewSortEventArgs) Handles grdStats.Sorting 

    If e.SortExpression = ViewState("sortExpr") Then 
     ViewState("sortExpr") = e.SortExpression & " desc" 
    Else 
     ViewState("sortExpr") = e.SortExpression 
    End If 

    GetCampaignData() 

End Sub 

' ######## POPULATE DATA ######### 

Private Sub GetCampaignData(Optional ByVal CompanyID As Integer = 0) 
    Dim sql As String = Nothing 

    ' Check user access level. 
    If Session("userlevel") = 1 Then 
     ' Current user is admin. 

     ' If a company has been filtered, get it's data, else, get all campaign data. 
     If CompanyID <> 0 Then 
      sql = "SELECT" & vbCrLf & _ 
      " a.campaignid," & vbCrLf & _ 
      " a.companyid," & vbCrLf & _ 
      " a.campaignname," & vbCrLf & _ 
      " a.filename," & vbCrLf & _ 
      " startdate," & vbCrLf & _ 
      " enddate," & vbCrLf & _ 
      " a.playinterval," & vbCrLf & _ 
      " a.ActiveStatus," & vbCrLf & _ 
      " b.*," & vbCrLf & _ 
      " (SELECT COUNT(*)" & vbCrLf & _ 
      "  FROM campaignstats AS c" & vbCrLf & _ 
      "  WHERE DAY(date_played) = DAY(CURRENT_DATE)" & vbCrLf & _ 
      "  AND c.campaignid = a.campaignid" & vbCrLf & _ 
      " ) AS today," & vbCrLf & _ 
      " (SELECT COUNT(*)" & vbCrLf & _ 
      "  FROM campaignstats AS d" & vbCrLf & _ 
      "  WHERE date_played > CURRENT_DATE - INTERVAL 7 DAY" & vbCrLf & _ 
      "  AND d.campaignid = a.campaignid" & vbCrLf & _ 
      " ) AS past_week," & vbCrLf & _ 
      " (SELECT COUNT(*)" & vbCrLf & _ 
      "  FROM campaignstats AS e" & vbCrLf & _ 
      "  WHERE e.campaignid = a.campaignid" & vbCrLf & _ 
      " ) AS playcount" & vbCrLf & _ 
      "FROM campaigns AS a" & vbCrLf & _ 
      "INNER JOIN companies AS b ON a.companyid = b.companyid" & vbCrLf & _ 
      "WHERE a.ActiveStatus = 1" & vbCrLf & _ 
      "AND a.companyid = " & CompanyID 

     Else 
      sql = "SELECT" & vbCrLf & _ 
      " a.campaignid," & vbCrLf & _ 
      " a.companyid," & vbCrLf & _ 
      " a.campaignname," & vbCrLf & _ 
      " a.filename," & vbCrLf & _ 
      " startdate," & vbCrLf & _ 
      " enddate," & vbCrLf & _ 
      " a.playinterval," & vbCrLf & _ 
      " a.ActiveStatus," & vbCrLf & _ 
      " b.*," & vbCrLf & _ 
      " (SELECT COUNT(*)" & vbCrLf & _ 
      "  FROM campaignstats AS c" & vbCrLf & _ 
      "  WHERE DAY(date_played) = DAY(CURRENT_DATE)" & vbCrLf & _ 
      "  AND c.campaignid = a.campaignid" & vbCrLf & _ 
      " ) AS today," & vbCrLf & _ 
      " (SELECT COUNT(*)" & vbCrLf & _ 
      "  FROM campaignstats AS d" & vbCrLf & _ 
      "  WHERE date_played > CURRENT_DATE - INTERVAL 7 DAY" & vbCrLf & _ 
      "  AND d.campaignid = a.campaignid" & vbCrLf & _ 
      " ) AS past_week," & vbCrLf & _ 
      " (SELECT COUNT(*)" & vbCrLf & _ 
      "  FROM campaignstats AS e" & vbCrLf & _ 
      "  WHERE e.campaignid = a.campaignid" & vbCrLf & _ 
      " ) AS playcount" & vbCrLf & _ 
      "FROM campaigns AS a" & vbCrLf & _ 
      "INNER JOIN companies AS b ON a.companyid = b.companyid" & vbCrLf & _ 
      "WHERE a.ActiveStatus = 1" 


     End If 
    Else 
     ' User is not an admin. 
     sql = "SELECT" & vbCrLf & _ 
     " a.campaignid," & vbCrLf & _ 
     " a.companyid," & vbCrLf & _ 
     " a.campaignname," & vbCrLf & _ 
     " a.filename," & vbCrLf & _ 
     " startdate," & vbCrLf & _ 
     " enddate," & vbCrLf & _ 
     " a.playinterval," & vbCrLf & _ 
     " a.ActiveStatus," & vbCrLf & _ 
     " b.*," & vbCrLf & _ 
     " (SELECT COUNT(*)" & vbCrLf & _ 
     "  FROM campaignstats AS c" & vbCrLf & _ 
     "  WHERE DAY(date_played) = DAY(CURRENT_DATE)" & vbCrLf & _ 
     "  AND c.campaignid = a.campaignid" & vbCrLf & _ 
     " ) AS today," & vbCrLf & _ 
     " (SELECT COUNT(*)" & vbCrLf & _ 
     "  FROM campaignstats AS d" & vbCrLf & _ 
     "  WHERE date_played > CURRENT_DATE - INTERVAL 7 DAY" & vbCrLf & _ 
     "  AND d.campaignid = a.campaignid" & vbCrLf & _ 
     " ) AS past_week," & vbCrLf & _ 
     " (SELECT COUNT(*)" & vbCrLf & _ 
     "  FROM campaignstats AS e" & vbCrLf & _ 
     "  WHERE e.campaignid = a.campaignid" & vbCrLf & _ 
     " ) AS playcount" & vbCrLf & _ 
     "FROM campaigns AS a" & vbCrLf & _ 
     "INNER JOIN companies AS b ON a.companyid = b.companyid" & vbCrLf & _ 
     "WHERE a.ActiveStatus = 1" & vbCrLf & _ 
     "AND a.companyid = " & CInt(Session("companyid")) 
    End If 

    grdCampaigns.DataSource = get_data(sql) 
    grdCampaigns.DataBind() 

    For i As Integer = 0 To grdCampaigns.Rows.Count - 1 
     grdCampaigns.Rows(i).Cells(2).Text = Microsoft.VisualBasic.Left(grdCampaigns.Rows(i).Cells(2).Text, 10) 
     grdCampaigns.Rows(i).Cells(3).Text = Microsoft.VisualBasic.Left(grdCampaigns.Rows(i).Cells(3).Text, 10) 
    Next 
End Sub 

Public Function get_data(ByVal SQLStatement As String) As DataView 

    'Populates the datatable 
    Dim dt As Data.DataTable 

    dt = db.GetDataTable(SQLStatement) 

    Dim dv As System.Data.DataView = New System.Data.DataView(dt) 

    If Not ViewState("sortExpr") Is Nothing Then 
     dv.Sort = ViewState("sortExpr") 
    Else 
     dv = dt.DefaultView 
    End If 

    Session("dv5") = dv 
    Return dv 
End Function 

任何帮助将不胜感激。

+0

你的代码对我来说很不错。你有没有其他的代码在usercontrol后面? – Icarus

+0

只需编码并从另一个网格中删除信息即可。这个应该是只读的。如果有帮助,当我填充这个网格时(通过点击另一个网格上的选择按钮),调试器在去其他任何事情之前打两次Page_Load。 – Ortund

回答

0

我很抱歉我在这个问题中粘贴的代码,虽然正确的目的,不是正确的代码与这个问题有关。这就是说,我想感谢您Icarus花时间查看我的代码。

分页/排序工作。我所做的修复是将PageIndexChangingSorting事件处理程序中的GetCampaignData()替换为所需的SQL代码和数据绑定方法,以便为我提供所需的结果。