Обработка данных на сервере. Нумерация таблиц Microsoft SQL. - PullRequest
0 голосов
/ 28 марта 2019

Я пытаюсь установить нумерацию страниц с таблицами данных, используя PHP PDO с MS SQL, так как «предел» не применим, я нахожу очень трудным заставить код работать.

Я пробовал синтаксис «TOP», ноон будет фильтровать только указанное число, и разбиение на страницы не будет работать.

Я пробовал смещение и выборка все еще не работает.

Это рабочий код, когда используется Mysql, и его так легко понятьи выполните.

if($_POST["length"] != -1)
   {
$query .= 'LIMIT ' . $_POST['start'] . ', ' . $_POST['length'];
   }

Вот коды, которые я пробовал (извините, я не очень хорош в кодировании):

//if($_POST["length"] != -1)
   {
Trial 1 : //$query .= "TOP " . $_POST['start'] . " OFFSET " .                     $_POST['length'];


Trial 2 : //$query .= "SELECT * from item ORDER BY id DESC offset 0 rows fetch next 10 rows only ";


    Trial 3 ://$query .="AND id BETWEEN ".intval( $_POST["start"] )." AND ".intval( $_POST["length"] );" "

}

Результатом должно быть разбиение на страницыс 10 отфильтрованными записями. введите описание изображения здесь

Обновление 1:

Вот снимок экрана с запросом, который я пытался проверить на сервере MS SQL, но получаяошибка (с использованием MS SQL 2008)

SQL-запрос

Ответы [ 2 ]

0 голосов
/ 28 марта 2019

Ваш подход зависит от версии SQL Server.

Подход, основанный на предложении ORDER BY с OFFSET и FETCH в качестве решения подкачки требует SQL Server 2012+.Ваш синтаксис кажется правильным, поэтому следующий код должен работать:

<?php
if ($_POST["length"] != -1) {
    $query = "
        SELECT * 
        FROM item 
        ORDER BY id DESC OFFSET ".($_POST['start']-1)." ROWS FETCH NEXT ".$_POST["length"]." ROWS ONLY
    ";
}
?>

Для SQL Server 2008+ вы можете использовать ROW_NUMBER() в качестве решения для подкачки:

<?php
if ($_POST["length"] != -1) {
    $query = 
        "SELECT *
        FROM (
            SELECT 
                *, 
                ROW_NUMBER() OVER (ORDER BY id DESC) AS Rn
            FROM item
        )
        WHERE Rn BETWEEN ".$_POST['start']." AND ".($_POST['start'] + $_POST['length'] - 1);        
}
?>
0 голосов
/ 28 марта 2019

В MSSQL, чтобы использовать ограничение, вам нужно написать свой запрос следующим образом:

ORDER BY X.Field
OFFSET 20 ROWS 
FETCH NEXT 10 ROW ONLY OPTION (RECOMPILE)

И это пропустит первые 20 записей и принесет следующие 10.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...