ASP.NET MySQL Order By дает неверные результаты - PullRequest
0 голосов
/ 20 февраля 2012

вот моя проблема, я использую asp.net для своего сайта, я получаю список книг и показываю их, все в порядке.сейчас я пытаюсь отсортировать книги по названию, автору или другому атрибуту, я использую этот код:

public static IDataReader GetPageByCritere(
        int pageNumber,
        int pageSize,
        out int totalPages,
        string critere,
        string direction)
    {
        int pageLowerBound = (pageSize * pageNumber) - pageSize;
        totalPages = 1;
        int totalRows = GetCount();

        if (pageSize > 0) totalPages = totalRows / pageSize;

        if (totalRows <= pageSize)
        {
            totalPages = 1;
        }
        else
        {
            int remainder;
            Math.DivRem(totalRows, pageSize, out remainder);
            if (remainder > 0)
            {
                totalPages += 1;
            }
        }

        StringBuilder sqlCommand = new StringBuilder();
        sqlCommand.Append("SELECT * ");
        sqlCommand.Append("FROM a_book ");
        //sqlCommand.Append("WHERE  ");
        sqlCommand.Append("ORDER BY ?Critere ?direction ");
        sqlCommand.Append("LIMIT ?PageSize ");

        if (pageNumber > 1)
        {
            sqlCommand.Append("OFFSET ?OffsetRows ");
        }

        sqlCommand.Append(";");

        MySqlParameter[] arParams = new MySqlParameter[4];

        arParams[0] = new MySqlParameter("?PageSize", MySqlDbType.Int32);
        arParams[0].Direction = ParameterDirection.Input;
        arParams[0].Value = pageSize;

        arParams[1] = new MySqlParameter("?OffsetRows", MySqlDbType.Int32);
        arParams[1].Direction = ParameterDirection.Input;
        arParams[1].Value = pageLowerBound;

        arParams[2] = new MySqlParameter("?Critere", MySqlDbType.VarChar, 50);
        arParams[2].Direction = ParameterDirection.Input;
        arParams[2].Value = critere;

        arParams[3] = new MySqlParameter("?direction", MySqlDbType.VarChar, 50);
        arParams[3].Direction = ParameterDirection.Input;
        arParams[3].Value = direction;

        return MySqlHelper.ExecuteReader(
            GetReadConnectionString(),
            sqlCommand.ToString(),
            arParams);
    }
}

когда я выполняю этот код, книги не сортируются, я получаю первый список предметовне отсортировано, вот мои sqlCommand и arParams для сортировки с заголовком для примера: sqlCommand

 {SELECT * FROM a_book ORDER BY ?Critere ?direction LIMIT ?PageSize ;}

arParams:

 {?PageSize} : 20 {?OffsetRows} : -20 {?Critere} title {?direction} DESC

пожалуйста, помогите, я не нашел никакого решения.

1 Ответ

1 голос
/ 20 февраля 2012

К сожалению, раньше это работало в MySql, но затем изменилось поведение - см. http://bugs.mysql.com/bug.php?id=31474. В этом отношении он теперь ведет себя как Oracle и SQL Server.

Вместо этого вы можете рассмотреть возможность построенияувеличьте ваш заказ в соответствии с критериями - надеюсь, ваша строка критерия не введена пользователем или получена из пользовательского ввода, в противном случае вам придется остерегаться SQL-инъекции .

Если вашкритерий состоит из одного столбца, тогда вы можете просто сделать что-то вроде:

sqlCommand.Append(String.Format("ORDER BY {0} {1}", Critere, direction))

Если Critere имеет несколько столбцов, то вы можете рассмотреть возможность передачи критериев сортировки в виде списка столбцов-указателей.

Это также рассматривается здесь: Параметр order by условие не упорядочивает -mysql, C #

...