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 :

Boucle while dans trigger


Sujet :

Développement SQL Server

  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Mai 2011
    Messages
    790
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations forums :
    Inscription : Mai 2011
    Messages : 790
    Par défaut Boucle while dans trigger
    Bonjour,

    J'ai une table nommé contrat.

    Je voudrai bien lister toutes les lignes de cette table et afficher la colonne type du contrat dans chaque ligne.

    Pour cela j'ai écrit le code suivant :

    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
    declare @compteur int
      declare @nbrligne int; 
      declare @typecontrat nvarchar(200)
     
      select @nbrligne = (select COUNT(*) from [RESOCRM].[dbo].[XCONTRAT] where xcon_companyid ='1966' and xcon_Deleted is null)
     
      set @compteur = 1 ;
     
      while (@compteur <= @nbrligne)
     
      begin
     
      select @typecontrat = (select xcon_typecontrat from [RESOCRM].[dbo].[XCONTRAT] where xcon_companyid ='1966' and xcon_Deleted is null)
      print @nbrligne + '' + @typecontrat
     
      set @compteur = @compteur + 1
     
      end
    Le problème c'est que j'obtiens l'erreur suivante :

    La sous-requête a retourné plusieurs valeurs. Cela n'est pas autorisé quand la sous-requête suit =, !=, <, <= , >, >= ou quand elle est utilisée en tant qu'expression.

    Est-ce-qu'il faut modifier la ligne qui existe dans le begin ?

    Merci

  2. #2
    Membre chevronné Avatar de Sebwar
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2012
    Messages
    172
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2012
    Messages : 172
    Par défaut
    Hello !

    Est ce que le nombre de ligne par type de contrat ne suffirait pas ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT XCON_TYPECONTRAT, COUNT(*) NB_CONTRAT FROM [RESOCRM].[DBO].[XCONTRAT] WHERE XCON_COMPANYID ='1966' AND XCON_DELETED IS NULL GROUP BY XCON_TYPECONTRAT
    juste pour préciser, votre erreur vient de cette requête
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select @typecontrat = (select xcon_typecontrat from [RESOCRM].[dbo].[XCONTRAT] where xcon_companyid ='1966' and xcon_Deleted is null)
    la sous requête suivantes renvoie plusieurs xcon_typecontrat
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select xcon_typecontrat from [RESOCRM].[dbo].[XCONTRAT] where xcon_companyid ='1966' and xcon_Deleted is null
    alors la variable @typecontrat ne peut contenir qu'un seul xcon_typecontrat

  3. #3
    Membre Expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Par défaut
    Quelle horreur? mais vous ne connaissez pas les jointures???


    Je vais paraphraser sqlpro : "apprenez le SQL mes livres (ses livres) et mon site (son site) sont la pour vous y aider"

Discussions similaires

  1. boucle "while" dans un sous-formulaire
    Par philebaucis dans le forum VBA Access
    Réponses: 4
    Dernier message: 02/04/2017, 06h15
  2. Boucle "while" dans un fichier Javascript ?
    Par Boris56 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 30/04/2010, 12h31
  3. Boucle while dans tableau
    Par TheRealMike dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 01/06/2009, 19h50
  4. Problème de boucle while dans un popup
    Par drogba72 dans le forum Langage
    Réponses: 2
    Dernier message: 06/02/2009, 14h19
  5. probleme de boucle while dans une procedure stockée
    Par aboulemagnifique dans le forum SQL Procédural
    Réponses: 6
    Dernier message: 08/08/2007, 12h39

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