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 :

comment remplir une table en utilisant une boucle


Sujet :

MS SQL Server

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    138
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 138
    Points : 53
    Points
    53
    Par défaut comment remplir une table en utilisant une boucle
    Bonjour,
    Quelqu'un pourrait m'aider à écrire une requête qui permet d'insérer dans une table des champs entiers (par exemple de 1 à 20, un entier par ligne) de façon automatique (en utilisant une boucle qui tourne n fois, par exemple 20 fois).

    Merci d'avance.

  2. #2
    Rédactrice

    Avatar de Fleur-Anne.Blain
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    2 637
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 2 637
    Points : 6 805
    Points
    6 805
    Par défaut
    Soit tu fais tes 20 insert soit tu te débrouilles pour faire une procédure stoquée que tu exécutes pour remplir ta table

    Citation Envoyé par nice Voir le message
    Bonjour,
    Quelqu'un pourrait m'aider à écrire une requête qui permet d'insérer dans une table des champs entiers (par exemple de 1 à 20, un entier par ligne) de façon automatique (en utilisant une boucle qui tourne n fois, par exemple 20 fois).

    Merci d'avance.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    138
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 138
    Points : 53
    Points
    53
    Par défaut
    Il faudrait que j'utilise une procédure stockée car le nombre de lignes sont très nombreuses, mais je ne sais comment faire ?

  4. #4
    Rédactrice

    Avatar de Fleur-Anne.Blain
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    2 637
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 2 637
    Points : 6 805
    Points
    6 805
    Par défaut
    Ce que tu as a faire est assez simple.


    Je t'invite donc a te documenter avec tous les tutoriels MS SQL Server à ta disposition ou tu trouveras ta réponse très rapidement.

    Citation Envoyé par nice Voir le message
    Il faudrait que j'utilise une procédure stockée car le nombre de lignes sont très nombreuses, mais je ne sais comment faire ?

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Février 2006
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Février 2006
    Messages : 126
    Points : 143
    Points
    143
    Par défaut
    Tu peux effectivement employer un curseur avec comme variable de ta PS, le nombre d'iteration souhaité.

    Des exemples de syntaxe de construction ici au chapitre 3.7 Les curseurs du lien

  6. #6
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 917
    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 917
    Points : 51 693
    Points
    51 693
    Billets dans le blog
    6
    Par défaut
    si vous êtes sous sql server 2005, vous pouvez faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    CREATE MaTable (Col INT);
     
    INSERT INTO MaTable VALUES (1);
     
    INSERT INTO Matable 
    SELECT Max(Col) + 1
    FROM MaTable;
    GO 19
    A +

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    138
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 138
    Points : 53
    Points
    53
    Par défaut
    Merci à vous deux, j'ai trouvé la solution dans le lien d'Erwan.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     DECLARE @i int
     SET @i = 0 
     WHILE @i < @max
     BEGIN
        INSERT INTO #n VALUES (@i)
        SET @i = @i + 1
     END

  8. #8
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    138
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 138
    Points : 53
    Points
    53
    Par défaut
    Citation Envoyé par SQLpro Voir le message
    si vous êtes sous sql server 2005, vous pouvez faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    CREATE MaTable (Col INT);
     
    INSERT INTO MaTable VALUES (1);
     
    INSERT INTO Matable 
    SELECT Max(Col) + 1
    FROM MaTable;
    GO 19
    A +
    Merci bien SQLpro, je suis bien sur SQL Server 2005.

  9. #9
    Membre habitué
    Profil pro
    Inscrit en
    Février 2006
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Février 2006
    Messages : 126
    Points : 143
    Points
    143
    Par défaut
    Il y a une methode assez sympa qui est proposée dans un article (en anglais) de SQLserver Central (enregistrement requis). L'article en question s'intitule "Generating Missing Dates and Numbers"

    En outre il explique comment générer une serie de dates afin d'alimenter une table de reference.

    bonne lecture

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 21/04/2008, 19h08
  2. Réponses: 6
    Dernier message: 06/03/2008, 10h46
  3. Requête utilisant une formule stockée dans une table
    Par alexiisme dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 23/01/2008, 07h01
  4. Réponses: 6
    Dernier message: 16/06/2006, 13h22
  5. copie d'une table Y d'une base A vers une table X d'une base
    Par moneyboss dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 30/08/2005, 21h24

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