Estoy tratando de usar la paginación de un DataGrid, todo me funciona bien, hasta que pongo EnableViewState=False, en el evento PageIndexChange vuelvo a enlazar el control, pero el grid no se me muestra. Si cambio nuevamente el valvor de EnableViewSate a true si puedo interactuar con las página, el cambio de página lo realiza a la perfección.
Lei por ahí que caundo un DataGrid se vuelve a cargar con cada ida y vuelta es mejor poner el ViewSate en falso para ahorrar en el volumen de datos, pero no me funciona

Aca le dejo el codigo que tengo el el evento PageIndexChange.
Código:
Alguien podría darme una manito por favor?private void DataGrid1_ChangePage(object sender, DataGridPageChangedEventArgs e) { DataGrid1.CurrentPageIndex = e.NewPageIndex; BindGrid(); } private void BindGrid() { string sSql = "SELECT * FROM cLeyes "; if(ViewState["SQL"]!= "") { sSql += "WHERE " + ViewState["SQL"]; } System.Data.OleDb.OleDbConnection myConn = new System.Data.OleDb.OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\\reel\\temp\\SISLEY\\sysley.mdb;Persist Security Info=False"); System.Data.OleDb.OleDbDataAdapter myComm = new System.Data.OleDb.OleDbDataAdapter(sSql,myConn); DataSet dsInstrumentos = new DataSet(); try { myComm.Fill(dsInstrumentos,"cLeyes"); DataGrid1.DataSource = dsInstrumentos.Tables["cLeyes"].DefaultView; DataGrid1.DataBind(); htmlMensajes.InnerHtml = dsInstrumentos.Tables[0].Rows.Count + " instrumentos encontrados."; } catch(System.Data.OleDb.OleDbException e) { htmlMensajes.InnerHtml = e.Message; htmlMensajes.Style["Color"] = "Red"; } myConn.Close(); }
Saludes
