Probleme avec Select Case

cs_Geff Messages postés 192 Date d'inscription vendredi 2 mars 2001 Statut Membre Dernière intervention 10 janvier 2006 - 25 févr. 2005 à 14:54
cs_fabrice69 Messages postés 1765 Date d'inscription jeudi 12 octobre 2000 Statut Membre Dernière intervention 11 décembre 2013 - 26 févr. 2005 à 23:22
Bonjour à tous!

J'ai un petit problème pour écrire une procédure stockée pour Sql Server 2000.
Voici les données de mon problème

J'ai une table client et une table contrat comme suit :



<HR>


Client
{
Nocli int
Bloque bit
Urgence int
}

Contrat
{
NoContrat int
DateSignature datetime
}

Client.NoCli est la clés primaire de Client
Contrat.NoContrat est la clés primaire de Contrat



<HR>

DATEDIFF(day, DateSignature, GETUTCDATE() )

la formule ci-dessus permet de connaitre le nombre de jour écoulé entre DateSignature et la date courante.

Et j'aimerais mettre à jour grace à une procédure stockée la propriété Urgence pour chaque client. Sachant que
Urgence vaut 1 quand Bloque= 1
ou quand DATEDIFF() < = 10 jours

Urgence vaut 2 quand Bloque = 0
et quand DATEDIFF() > 10 et DATEDIFF() < 30

Urgence vaut 3 quand Bloque = 0
et quand DATEDIFF() > 30

Voila j'aurais besoin de votre aide car visiblement je n'arrive pas à avoir une procédure stockée fonctionelle, il y'a certainement l'utilisation des SELECT CASE, ca je sais plus ou moins l'utiliser mais pour mon exemple j'ai du mal a implémanté correctement. En fait je sais faire cette procédure stockée avec comme paramètre le numéro du client (NoCli) mais pour avoir un traitement sur tous les client, là je sêche, merci de me donner un coup de main


<HR>

main(k){float i,j,r,x,y =-16;while(puts(""),y++<15)for(x
0;x++<84;putchar(" .:-;!/>)|&IH%*#"[k&15]))for(ik=r=0;
j=r*r-i*i-2+x/25,i=2*r*i+y/10,j*j+i*i<11&&k++<111;r=j);}

# GEFF

1 réponse

cs_fabrice69 Messages postés 1765 Date d'inscription jeudi 12 octobre 2000 Statut Membre Dernière intervention 11 décembre 2013 5
26 févr. 2005 à 23:22
Sous TSQL (SQL Server) cela se fait avec le SELECT xxxx CASE WHEN ...
Voila la copie de l'aide MSDN à ce sujet :

-----



<OBJECT id= hhobj_1 type=application/x-oleobject classid=clsid:adb880a6-d8ff-11cf-9377-00aa003b7a11></OBJECT>





[mk:@MSITStore:C:\Program%20Files\Microsoft%20SQL%20Server\80\Tools\Books\tsqlref.chm::/ts_da-db_2js5.htm Priorité des types de données].


Valeurs de résultat

Fonction CASE simple


<LI>Évalue input_expression , puis évalue dans l'ordre spécifié input_expression = when_expression pour chaque clause WHEN.


<LI>Renvoie l'argument result_expression de la première comparaison (input_expression = when_expression ) qui est vérifiée.


<LI>Si aucune comparaison input_expression = when_expression n'est vérifiée, SQL Server renvoie else_result_expression si une clause ELSE est spécifiée ou, à défaut de clause ELSE, la valeur NULL est renvoyée. </LI>
Fonction CASE recherchée :


<LI>Évalue, dans l'ordre spécifié, Boolean_expression pour chaque clause WHEN.


<LI>Renvoie result_expression du premier argument Boolean_expression qui est vérifié.


<LI>Si aucun argument Boolean_expression n'est vérifié, SQL Server renvoie else_result_expression si une clause ELSE est spécifiée, ou une valeur NULL dans le cas contraire. </LI>
Exemple

A. Utilisation d'une instruction SELECT avec une fonction CASE simple

Dans une instruction SELECT, une fonction CASE simple permet uniquement de vérifier si les arguments sont égaux ; aucune comparaison n'est effectuée. L'exemple suivant utilise la fonction CASE pour modifier la présentation des catégories de livres en vue d'en faciliter la lecture.

USE pubs
GO
SELECT   Category = 
      CASE type
         WHEN 'popular_comp' THEN 'Popular Computing'
         WHEN 'mod_cook' THEN 'Modern Cooking'
         WHEN 'business' THEN 'Business'
         WHEN 'psychology' THEN 'Psychology'
         WHEN 'trad_cook' THEN 'Traditional Cooking'
         ELSE 'Not yet categorized'
      END,
   CAST(title AS varchar(25)) AS 'Shortened Title',
   price AS Price
FROM titles
WHERE price IS NOT NULL
ORDER BY type, price
COMPUTE AVG(price) BY type
GO



Voici le jeu de résultats obtenu :

Category            Shortened Title           Price                      
------------------- ------------------------- -------------------------- 
Business            You Can Combat Computer S 2.99                       
Business            Cooking with Computers: S 11.95                      
Business            The Busy Executive's Data 19.99                      
Business            Straight Talk About Compu 19.99                      

                                              avg
                                              ==========================
                                              13.73                      

Category            Shortened Title           Price                      
------------------- ------------------------- -------------------------- 
Modern Cooking      The Gourmet Microwave     2.99                       
Modern Cooking      Silicon Valley Gastronomi 19.99                      

                                              avg
                                              ==========================
                                              11.49                      

Category            Shortened Title           Price                      
------------------- ------------------------- -------------------------- 
Popular Computing   Secrets of Silicon Valley 20.00                      
Popular Computing   But Is It User Friendly?  22.95                      

                                              avg
                                              ==========================
                                              21.48                      

Category            Shortened Title           Price                      
------------------- ------------------------- -------------------------- 
Psychology          Life Without Fear         7.00                       
Psychology          Emotional Security: A New 7.99                       
Psychology          Is Anger the Enemy?       10.95                      
Psychology          Prolonged Data Deprivatio 19.99                      
Psychology          Computer Phobic AND Non-P 21.59                      

                                              avg
                                              ==========================
                                              13.50                      

Category            Shortened Title           Price                      
------------------- ------------------------- -------------------------- 
Traditional Cooking Fifty Years in Buckingham 11.95                      
Traditional Cooking Sushi, Anyone?            14.99                      
Traditional Cooking Onions, Leeks, and Garlic 20.95                      

                                              avg
                                              ==========================
                                              15.96                      

(21 row(s) affected)



B. Utilisation d'une instruction SELECT avec une fonction CASE simple et recherchée

Dans une instruction SELECT, la fonction CASE recherchée permet de remplacer des valeurs dans le jeu de résultats, en fonction des valeurs de comparaison. L'exemple suivant donne le prix (colonne money ) sous la forme d'un commentaire de texte basé sur la fourchette de prix d'un livre.

USE pubs
GO
SELECT    'Price Category'  = 
      CASE 
         WHEN price IS NULL THEN 'Not yet priced'
         WHEN price < 10 THEN 'Very Reasonable Title'
         WHEN price >= 10 and price < 20 THEN 'Coffee Table Title'
         ELSE 'Expensive book!'
      END,
   CAST(title AS varchar(20)) AS 'Shortened Title'
FROM titles
ORDER BY price
GO



Voici le jeu de résultats obtenu :

Price Category        Shortened Title      
--------------------- -------------------- 
Not yet priced        Net Etiquette        
Not yet priced        The Psychology of Co 
Very Reasonable Title The Gourmet Microwav 
Very Reasonable Title You Can Combat Compu 
Very Reasonable Title Life Without Fear    
Very Reasonable Title Emotional Security:  
Coffee Table Title    Is Anger the Enemy?  
Coffee Table Title    Cooking with Compute 
Coffee Table Title    Fifty Years in Bucki 
Coffee Table Title    Sushi, Anyone?       
Coffee Table Title    Prolonged Data Depri 
Coffee Table Title    Silicon Valley Gastr 
Coffee Table Title    Straight Talk About  
Coffee Table Title    The Busy Executive's 
Expensive book!       Secrets of Silicon V 
Expensive book!       Onions, Leeks, and G 
Expensive book!       Computer Phobic And  
Expensive book!       But Is It User Frien 

(18 row(s) affected)



C. Utilisation de CASE avec SUBSTRING et SELECT

L'exemple suivant utilise CASE et THEN pour produire une liste d'auteurs, ainsi que les numéros d'identification et les types de livres écrits par chaque auteur.

USE pubs
SELECT SUBSTRING((RTRIM(a.au_fname) + ' '+ 
   RTRIM(a.au_lname) + ' '), 1, 25) AS Name, a.au_id, ta.title_id,
   Type = 
  CASE 
    WHEN SUBSTRING(ta.title_id, 1, 2) = 'BU' THEN 'Business'
    WHEN SUBSTRING(ta.title_id, 1, 2) = 'MC' THEN 'Modern Cooking'
    WHEN SUBSTRING(ta.title_id, 1, 2) = 'PC' THEN 'Popular Computing'
    WHEN SUBSTRING(ta.title_id, 1, 2) = 'PS' THEN 'Psychology'
    WHEN SUBSTRING(ta.title_id, 1, 2) = 'TC' THEN 'Traditional Cooking'
  END
FROM titleauthor ta JOIN authors a ON ta.au_id = a.au_id



Voici le jeu de résultats obtenu :

Name                      au_id       title_id Type                
------------------------- ----------- -------- ------------------- 
Johnson White             172-32-1176 PS3333   Psychology          
Marjorie Green            213-46-8915 BU1032   Business            
Marjorie Green            213-46-8915 BU2075   Business            
Cheryl Carson             238-95-7766 PC1035   Popular Computing   
Michael O'Leary           267-41-2394 BU1111   Business            
Michael O'Leary           267-41-2394 TC7777   Traditional Cooking 
Dean Straight             274-80-9391 BU7832   Business            
Abraham Bennet            409-56-7008 BU1032   Business            
Ann Dull                  427-17-2319 PC8888   Popular Computing   
Burt Gringlesby           472-27-2349 TC7777   Traditional Cooking 
Charlene Locksley         486-29-1786 PC9999   Popular Computing   
Charlene Locksley         486-29-1786 PS7777   Psychology          
Reginald Blotchet-Halls   648-92-1872 TC4203   Traditional Cooking 
Akiko Yokomoto            672-71-3249 TC7777   Traditional Cooking 
Innes del Castillo        712-45-1867 MC2222   Modern Cooking      
Michel DeFrance           722-51-5454 MC3021   Modern Cooking      
Stearns MacFeather        724-80-9391 BU1111   Business            
Stearns MacFeather        724-80-9391 PS1372   Psychology          
Livia Karsen              756-30-7391 PS1372   Psychology          
Sylvia Panteley           807-91-6654 TC3218   Traditional Cooking 
Sheryl Hunter             846-92-7186 PC8888   Popular Computing   
Anne Ringer               899-46-2035 MC3021   Modern Cooking      
Anne Ringer               899-46-2035 PS2091   Psychology          
Albert Ringer             998-72-3567 PS2091   Psychology          
Albert Ringer             998-72-3567 PS2106   Psychology          

(25 row(s) affected)


<!--RELATEDTOPICSLIST-->

Voir aussi



[javascript:hhobj_1.Click() Conversion de type de données]


[mk:@MSITStore:C:\Program%20Files\Microsoft%20SQL%20Server\80\Tools\Books\tsqlref.chm::/ts_da-db_7msw.htm Types de données]


[mk:@MSITStore:C:\Program%20Files\Microsoft%20SQL%20Server\80\Tools\Books\tsqlref.chm::/ts_ea-ez_4aur.htm Expressions]


[mk:@MSITStore:C:\Program%20Files\Microsoft%20SQL%20Server\80\Tools\Books\tsqlref.chm::/ts_sa-ses_9sfo.htm SELECT]


[mk:@MSITStore:C:\Program%20Files\Microsoft%20SQL%20Server\80\Tools\Books\tsqlref.chm::/ts_fa-fz_79f7.htm Fonctions système]


[mk:@MSITStore:C:\Program%20Files\Microsoft%20SQL%20Server\80\Tools\Books\tsqlref.chm::/ts_ua-uz_82n9.htm UPDATE]


[mk:@MSITStore:C:\Program%20Files\Microsoft%20SQL%20Server\80\Tools\Books\tsqlref.chm::/ts_wa-wz_6cmd.htm WHERE]

<!--/RELATEDTOPICSLIST--><!--END-->
<CENTER>
[ms-its:hlpview.chm::/gscopy_0z3m.htm ©1988-2000 Microsoft Corporation. Tous droits réservés.]

</CENTER>





-----

Romelard Fabrice (Alias F___)
0
Rejoignez-nous