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

MS SQL Server Discussion :

SQL SERVER 2000 remonter un nombre d'enregistrement


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    266
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 266
    Par défaut SQL SERVER 2000 remonter un nombre d'enregistrement
    Bonjour

    Je souhaiterais savoir comment faire l'equivalent du limite de mysql avec sql server

    je n'arrive pas a trouver comment remonter les 15 enregistrement à partire du 98 ieme enregistrement de ma base

    merci

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    140
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 140
    Par défaut
    Bonjour,

    Il faut utiliser une sous requête et le mot clé TOP

    http://sqlserver.developpez.com/faq/?page=Jeu

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    266
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 266
    Par défaut
    Merci

    Biensur je suis aller voirla FAQ avant mais le souci de cette methode réside dans l'importance des donnée a traiter.

    Si je doit remonter les 10 enregistrement qui suive le 14523 ieme enregistrement. Cela implique de devoir remonter 14533 enregistrement pour envoir seulement 10. Au niveau performence je ne sais pas si cela est judicieux.

  4. #4
    Membre émérite
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Août 2006
    Messages
    730
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2006
    Messages : 730
    Par défaut
    bonjour,

    dans le cas de remonter 10 enreg après 14532 enreg tu as un pb:

    soit tu créé une colonne 'num' par exemple et tu fais

    select top 10 * from tatable where num>14532

    ce qui est le plus propre

    soit tu fais comme tu as dis.

    N'oublies pas que SQL serveur est un serveur BBD fait pour faire du sql et pas de la gestion de fichiers (nombre de lignes) car on ne sait pas comment sont "rangées" les données par SQLserveur.

    je pense donc qu'il te faut revoir le schéma de ta table.

    serge

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    266
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 266
    Par défaut
    Ok merci

    Par contre dans une requete serait'il possible de faire un truc comme ca

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    DECLARE @I integer  
    SET @I=0
    Select @I=@I+1 as num ,nom from MaTable
    Ce qui donnerais :

    num nom
    1 dupond
    2 martin
    3 durand
    4 george
    5 tonton
    6 tata

  6. #6
    Membre émérite
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Août 2006
    Messages
    730
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2006
    Messages : 730
    Par défaut
    non pas comme çà directement, il te faut un curseur:

    essaies avec ce code (remplace les paramètres nom et matable)

    Code : 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
    21
     
    DECLARE iden_cursor CURSOR FOR 
     SELECT nom FROM MaTable
     
    declare @idx int,@nom varchar(500)
    set @idx=0
     
       OPEN iden_cursor
       FETCH NEXT FROM iden_cursor INTO @nom
     
       WHILE @@FETCH_STATUS = 0
       BEGIN
     
          update MaTable set num=@idx where nom=@nom
          set @idx=@idx+1	
          FETCH NEXT FROM iden_cursor INTO @nom
     
       END
     
       CLOSE iden_cursor
       DEALLOCATE iden_cursor
    A+
    serge

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 5
    Dernier message: 12/12/2010, 23h04
  2. utiliser seek pour lire un enregistrement indexé sql server 2000
    Par fidelio2007 dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 27/09/2007, 00h32
  3. Réponses: 1
    Dernier message: 22/09/2006, 13h56
  4. [SQL Server 2000] compter le nombre de jours
    Par soltani1 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 11/07/2006, 14h59
  5. [SQL Server 2000] obtenir les enregistrements de x à y
    Par Jahz dans le forum Langage SQL
    Réponses: 5
    Dernier message: 13/03/2006, 12h22

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