IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Développement SQL Server Discussion :

Comment faire les paginations avec MSSQL ?


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 160
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 160
    Par défaut Comment faire les paginations avec MSSQL ?
    Bonjour,
    J'ai cheché un bon momet et j'ai trouvé pas mal de truc différents sans satisfaction. Le dernier en date est avec mais c'est mal documenté
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $tsql = "SELECT * FROM
                (SELECT ROW_NUMBER() OVER(ORDER BY ProductID)
                AS RowNumber, Name, ProductNumber FROM Production.Product)
            AS TEST
            WHERE RowNumber BETWEEN ? AND ? + 1";
    Par exemple, ci-dessus, l'exemple ne dit pas ou est le nom de la table et pourquoi il y a deux FROM

    Je voulais donc savoir si vous pouviez m'aider à adapter ma requete
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    $where ="la.id_label < 100"; (// 100 est pour limiter le nombre de lignes...)
    //Read Query
    $tsql= 'SELECT id_label, id_glacier, g_name, g_country, l_name, id_replica, t_name, r_name, isOut, isIn, isAnalized, analized, comment, b_name FROM labels AS la
    	INNER JOIN glaciers AS gl ON gl.id_glacier = la.glaciers_id_glacier
    	INNER JOIN locations AS lo ON lo.id_location = la.locations_id_location
    	INNER JOIN types AS ty ON ty.id_type = la.types_id_type
    	INNER JOIN replicas AS re ON re.id_replica = la.replicas_id_replica
    	INNER JOIN boxes AS bo ON bo.id_box = la.boxes_id_box
    	WHERE '.$where.'
    	ORDER BY id_glacier ASC;';
    En fait, il fait deux select? Mais j'ai du mal à comprendre comment adapter ma requet (qui fonctionne) ainsi.

    Serait-il possible d'avoir un exemple?

    Milles mercis

  2. #2
    Membre expérimenté
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 160
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 160
    Par défaut
    Je pense que la solution serait celle-ci
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    $tsql= 'SELECT ROW_NUMBER() OVER(ORDER BY id_label ASC) AS rowws, id_label, id_glacier, g_name, g_country, l_name, id_replica, t_name, r_name, isOut, isIn, isAnalized, analized, comment, b_name FROM labels AS la
    					INNER JOIN glaciers AS gl ON gl.id_glacier = la.glaciers_id_glacier
    					INNER JOIN locations AS lo ON lo.id_location = la.locations_id_location
    					INNER JOIN types AS ty ON ty.id_type = la.types_id_type
    					INNER JOIN replicas AS re ON re.id_replica = la.replicas_id_replica
    					INNER JOIN boxes AS bo ON bo.id_box = la.boxes_id_box
    					WHERE id_label BETWEEN 3 and 10 AND '.$where.'
    					ORDER BY id_glacier ASC;'
    mais je me demande sur l'impact des deux
    ORDER BY id_glacier
    ORDER BY id_label

    Lequel est "plus important"?
    Est-ce qu'il order d'abord les label puis les glacier?

    Dans tous les cas, ceci ne me retorune pas le nombre de lignes totales, ce que j'ai besoin pour faire la paginaton.
    Devrais-je alors faire deux requete?

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    le principe de pagination est basé sur la syntaxe SQL : "... LIMIT ..., ...".

    Donc, il n'y a aucun besoin d'adapter ton code à... je ne sais pas quoi !



    Ça utilise mysql_, mais le PRINCIPE reste valable.

  4. #4
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    @jreaux : le principe est le même, mais la syntaxe de la requête est spécifique au SGDB.
    @pierrot : en gros, ton problème c'est davantage comment limiter les résultats dans la requête. On va poser la question à nos amis du forum BDD quitte à revenir en PHP pour adapter le script de pagination ensuite.
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Invité
    Invité(e)

  6. #6
    Membre émérite Avatar de Oishiiii
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2009
    Messages
    508
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Août 2009
    Messages : 508
    Par défaut
    La FAQ SQL Server date de 2005

    Depuis SQL Server 2012 il est possible d'utiliser la clause ORDER BY pour ça;

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ORDER BY DepartmentID   
        OFFSET 0 ROWS  
        FETCH NEXT 10 ROWS ONLY;
    Documentation et exemples: https://docs.microsoft.com/en-us/sql...er-2017#Offset

  7. #7
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 995
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 995
    Billets dans le blog
    6
    Par défaut
    Citation Envoyé par jreaux62 Voir le message
    Bonjour,

    le principe de pagination est basé sur la syntaxe SQL : "... LIMIT ..., ...".

    Donc, il n'y a aucun besoin d'adapter ton code à... je ne sais pas quoi !



    Ça utilise mysql_, mais le PRINCIPE reste valable.
    LIMIT est une merde de MySQl ! Cela n'existe pas en SQL.

    La norme SQL défini différentes façons dont la plus simple est basé sur la clause ORDER BY avec les opérateurs OFFSET et FETCH :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    -- retourner les lignes à partir de...
    OFFSET <offset row count> { ROW | ROWS } 
     
    -- retourner n lignes
    FETCH { FIRST | NEXT } [ <fetch first row count> ] { ROW | ROWS } ONLY
       <offset row count> :=
          <simple value specification>
       <fetch first row count> :=
          <simple value specification>
    Si vous aviez cherché un peu : https://sqlpro.developpez.com/SQL2008/#LII-C


    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ORDER BY MaColonne OFFSET 50 ROWS FETCH 10 ROWS ONLY
    indique que l'on passe les 50 premières lignes et que l'on affiche les 10 suivantes.

    A +

    PS : apprenez la langage SQL ! Mon livre peut vous y aider...
    Nom : SQL.jpg
Affichages : 111
Taille : 47,4 Ko
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  8. #8
    Membre expérimenté
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 160
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 160
    Par défaut
    Bonjour,
    Je vous remercie à tous pour vos réponses.

    J'ai réussi à le faire (avant de voir la réponse de SQLpro) ainsi:
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
     
    <?php
    $tsql= 'SELECT ROW_NUMBER() OVER(ORDER BY id_label ASC) AS rowws, id_label, id_glacier, g_name, g_country, l_name, id_replica, t_name, r_name, isOut, isIn, isAnalized, analized, comment, b_name FROM labels AS la
    					INNER JOIN glaciers AS gl ON gl.id_glacier = la.glaciers_id_glacier
    					INNER JOIN locations AS lo ON lo.id_location = la.locations_id_location
    					INNER JOIN types AS ty ON ty.id_type = la.types_id_type
    					INNER JOIN replicas AS re ON re.id_replica = la.replicas_id_replica
    					INNER JOIN boxes AS bo ON bo.id_box = la.boxes_id_box
    					WHERE id_label BETWEEN '.$firstItemPerPgae.' and '.$lastItemPerPgae.' '.$where.'
    					ORDER BY id_glacier ASC;';
     
     
     
            $getResults= sqlsrv_query($conn, $tsql, array(), array("Scrollable"=>"buffered"));
            $num_rows = sqlsrv_num_rows( $getResults );
     
    while ($row = sqlsrv_fetch_array($getResults, SQLSRV_FETCH_ASSOC)) {
    [... code...]
    }
    ?>

    Je ne sais pas ce que vous en penser?

    Mais je vais regarder aussi du côté de OFFSET et FETCH

Discussions similaires

  1. Comment faire un menu avec le meme espace entre les éléments
    Par pierrot10 dans le forum Mise en page CSS
    Réponses: 9
    Dernier message: 12/09/2016, 22h55
  2. Comment faire un bouton avec un passage lumineux toutes les 5 secondes
    Par infovect dans le forum Général JavaScript
    Réponses: 20
    Dernier message: 17/07/2014, 15h12
  3. Comment faire un critère avec les dates en JDBC
    Par demcoul dans le forum JDBC
    Réponses: 2
    Dernier message: 01/01/2009, 19h46
  4. Comment faire un Select avec les formulaires sous Access?
    Par kesamba dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 21/11/2007, 10h57
  5. [INDY] comment faire un 'POST' avec idHTTP??
    Par gamez dans le forum Composants VCL
    Réponses: 5
    Dernier message: 17/05/2004, 19h02

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo