문제:페이지에 따라 GridView/ObjectDataSource 정렬이 변경됩니다.
-
22-07-2019 - |
문제
페이징을 사용하여 ObjectDataSource에 연결된 GridView가 있습니다.보고 있는 결과 페이지에 따라 정렬 순서가 변경된다는 점을 제외하면 페이징은 제대로 작동합니다.이로 인해 항목이 다른 문제와 함께 후속 페이지에 다시 나타납니다.한 번에 한 페이지씩 읽은 다음 정렬하는 DAL에서 문제를 추적했습니다.분명히 결과 세트 크기가 변경됨에 따라 정렬도 변경될 것입니다.이 알고리즘에 개선 사항이 있습니까?가능하다면 데이터리더를 사용하고 싶습니다.
[System.ComponentModel.DataObjectMethod(System.ComponentModel.DataObjectMethodType.Select)]
public static WordsCollection LoadForCriteria(string sqlCriteria, int maximumRows, int startRowIndex, string sortExpression)
{
//DEFAULT SORT EXPRESSION
if (string.IsNullOrEmpty(sortExpression)) sortExpression = "OrderBy";
//CREATE THE DYNAMIC SQL TO LOAD OBJECT
StringBuilder selectQuery = new StringBuilder();
selectQuery.Append("SELECT");
if (maximumRows > 0) selectQuery.Append(" TOP " + (startRowIndex + maximumRows).ToString());
selectQuery.Append(" " + Words.GetColumnNames(string.Empty));
selectQuery.Append(" FROM sw_Words");
string whereClause = string.IsNullOrEmpty(sqlCriteria) ? string.Empty : " WHERE " + sqlCriteria;
selectQuery.Append(whereClause);
selectQuery.Append(" ORDER BY " + sortExpression);
Database database = Token.Instance.Database;
DbCommand selectCommand = database.GetSqlStringCommand(selectQuery.ToString());
//EXECUTE THE COMMAND
WordsCollection results = new WordsCollection();
int thisIndex = 0;
int rowCount = 0;
using (IDataReader dr = database.ExecuteReader(selectCommand))
{
while (dr.Read() && ((maximumRows < 1) || (rowCount < maximumRows)))
{
if (thisIndex >= startRowIndex)
{
Words varWords = new Words();
Words.LoadDataReader(varWords, dr);
results.Add(varWords);
rowCount++;
}
thisIndex++;
}
dr.Close();
}
return results;
}
해결책
MSDN을 읽고 이 문제에 대한 해결책을 찾았습니다.비결은 전체 쿼리를 수행하고 정렬이 항상 일관되게 흥미로운 하위 집합만 반환하는 것입니다.그러나 이 절차는 SQL 2005에서만 작동합니다.
[System.ComponentModel.DataObjectMethod(System.ComponentModel.DataObjectMethodType.Select)]
public static WordsCollection LoadForCriteria(string sqlCriteria, int maximumRows, int startRowIndex, string sortExpression)
{
//DEFAULT SORT EXPRESSION
if (string.IsNullOrEmpty(sortExpression)) sortExpression = "OrderBy";
//CREATE THE DYNAMIC SQL TO LOAD OBJECT
StringBuilder selectQuery = new StringBuilder();
selectQuery.Append("SELECT ");
selectQuery.Append(Words.GetColumnNames(string.Empty));
selectQuery.Append(" FROM (");
selectQuery.Append("SELECT ");
selectQuery.Append(Words.GetColumnNames(string.Empty));
selectQuery.Append(", ROW_NUMBER() OVER (ORDER BY " + sortExpression + ") AS RowRank");
selectQuery.Append(" FROM sw_Words) AS WordsWithRowNumbers");
selectQuery.Append(" WHERE RowRank >" + startRowIndex.ToString() + " AND " + "RowRank <=" + (startRowIndex + maximumRows).ToString());
string whereClause = string.IsNullOrEmpty(sqlCriteria) ? string.Empty : " AND " + sqlCriteria;
selectQuery.Append(whereClause);
Database database = Token.Instance.Database;
DbCommand selectCommand = database.GetSqlStringCommand(selectQuery.ToString());
//EXECUTE THE COMMAND
WordsCollection results = new WordsCollection();
int rowCount = 0;
using (IDataReader dr = database.ExecuteReader(selectCommand))
{
while (dr.Read())
{
Words varWords = new Words();
Words.LoadDataReader(varWords, dr);
results.Add(varWords);
rowCount++;
}
dr.Close();
}
return results;
}
제휴하지 않습니다 StackOverflow