begin process at 2010 02 10 07:18:40
  Trouver un code source :
 
dans
 
Accueil > Forum > 

Archive SQL

 > 

Archives

 > 

Problème avec une procédure stockée

 > 

Probleme avec Select Case


Derniers messages déposésPoser une question dans le forum ou lancer une discussion

Probleme avec Select Case

vendredi 25 février 2005 à 14:54:43 | Probleme avec Select Case

Geff

Membre Club

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 :


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



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



main(k){float i,j,r,x,y=-16;while(puts(""),y++<15)for(x
=0;x++<84;putchar(" .:-;!/>)|&IH%*#"[k&15]))for(i=k=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

samedi 26 février 2005 à 23:22:35 | Re : Probleme avec Select Case

fabrice69

Administrateur CodeS-SourceS
Sous TSQL (SQL Server) cela se fait avec le SELECT xxxx CASE  WHEN ...
Voila la copie de l'aide MSDN à ce sujet :

-----
Envoyez vos commentaires sur cette pageRaccourcis clavierVoir aussi Référence de Transact-SQL

CASE

Évalue une liste de conditions et renvoie l'une des expressions de résultats possibles.

La fonction CASE peut avoir deux formats :

  • la fonction CASE simple détermine le résultat en comparant une expression à un jeu d'expressions simples ;

  • La fonction CASE recherchée détermine le résultat en évaluant un jeu d'expressions booléennes.

Les deux formats prennent en charge un argument ELSE facultatif.

Syntaxe

Fonction CASE simple

CASE input_expression
    WHEN when_expression THEN result_expression
        [ ...n ]
    [
        ELSE else_result_expression
    ]
END

Fonction CASE recherchée :

CASE
    WHEN Boolean_expression THEN result_expression
        [ ...n ]
    [
        ELSE else_result_expression
    ]
END

Arguments

input_expression

Expression évaluée à l'aide de la fonction CASE simple. Il peut s'agir de toute expression valide de Microsoft® SQL Server™.

WHEN when_expression

Expression simple à laquelle l'argument input_expression est comparé à l'aide de la fonction CASE simple. Il peut s'agir de toute expression valide de SQL Server. Le type de données de l'argument input_expression et celui de chacun des arguments when_expression doivent être identiques ou permettre une conversion implicite.

n

Espace réservé indiquant que plusieurs clauses WHEN when_expression THEN result_expression ou WHEN Boolean_expression THEN result_expression peuvent être utilisées.

THEN result_expression

Expression renvoyée lorsque la comparaison input_expression = when_expression est vérifiée, ou lorsque l'argument boolean_expression est vérifié. L'argument result_expression peut être toute expression valide de SQL Server.

ELSE else_result_expression

Expression renvoyée lorsqu'aucune opération de comparaison n'est vérifiée. Si cet argument est omis et qu'aucune opération de comparaison n'est vérifiée, CASE renvoie la valeur NULL. L'argument else_result_expression peut être toute expression valide de SQL Server. Le type de données de l'argument else_result_expression et celui de tout argument result_expression doivent être identiques ou permettre une conversion implicite.

WHEN Boolean_expression

Expression booléenne évaluée lorsque la fonction CASE recherchée est utilisée. L'argument boolean_expression peut être n'importe quelle expression booléenne valide.

Types de résultats

Renvoie le type de priorité le plus élevé du jeu de types contenu dans result_expression et l'argument facultatif else_result_expression. Pour plus d'informations, reportez-vous à Priorité des types de données.

Valeurs de résultat
Fonction CASE simple
  • Évalue input_expression, puis évalue dans l'ordre spécifié input_expression = when_expression pour chaque clause WHEN.

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

  • 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.
Fonction CASE recherchée :
  • Évalue, dans l'ordre spécifié, Boolean_expression pour chaque clause WHEN.

  • Renvoie result_expression du premier argument Boolean_expression qui est vérifié.

  • 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.
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)

Voir aussi

Conversion de type de données

Types de données

Expressions

SELECT

Fonctions système

UPDATE

WHERE

©1988-2000 Microsoft Corporation. Tous droits réservés.

-----

Romelard Fabrice (Alias F___)


Cette discussion est classée dans : client, stockée, datediff, procédure, urgence


Répondre à ce message

Sujets en rapport avec ce message

Comment trouver le host dans une procédure stockée [ par btorchet ] Bonjour,Je voudrais rerouver le host, nom de la machine, du poste a partir duquyel a été appelé une procédure stockée.Je connais host_name, quand je l Like dans une procédure stockée [ par veronique1 ] Bonjour à tous,j'utilise une requête dans une procédure stockée avec un like , la valeur provient d'un paramètre , et ma rquête ne fonctionne pas si j Une procédure stockée pour : Ajouter OU Modifier OU Supprimer [ par Bowen123 ] Bonjour,Je cherche a créer une procédure stockée pour ajouter,mettre a jour ou supprimer un element à partir d'un "id".Quelqu'un peut me mettre sur la Procédure stockée [ par batobad ] bonjourj'ai une base de données sur sql server qui contient quatre tables dont l'une, que j'ai appélée article, contient une clé primaire et trois clé Paramètre de procédure stockée null [ par Leggoff ] Bonjour à tous.Je souhaite passer en C# un paramètre null à une procédure stockée (Ma toute première procédure !).L'utilisation de null  ne fonctionne Abandon de transaction suite TimeOut dans procédure stockée [ par foxfred ] Bonjour,Une procédure stockée appelée depuis une appli VB.Net effectue le traitement suivant :BEGIN TRANSACTION   -- Suppression d'une contrainte dans Récupérer le code d'une procédure stockée [ par yoannd ] Bonjour les gens, Alors voila, je souhaite récupérer, au moyen d'une requete SQL, le code d'une procédure stockée (n'importe laquelle). Je sais que c log procédure stockée (SQL Server) [ par jguillemette ] bonjour,à partir d'un *.bat je lance un DTS qui exécute une procédure stockéla trace de l'exécution du *.bat est redigée dans un fichier logce dernier PROMPT dans une procédure stockée [ par tedparker ] Bonjour   Est-il possible de demander des paramètres par un PROMPT dans une procédure PL SQL ? J'en ai super besoin. Je crée ma procédure dans un pack Problème de passage de paramètre dans une procédure stockée [ par pfacon ] J'ai créé une procédure stockée de création de base de données SQL:CREATE PROCEDURE creation_base  @nom varchar(8)  AS create database[@nom]GOJ'appell


Nos sponsors


Sondage...

Comparez les prix


HTC Hero

Entre 550€ et 550€

CalendriCode

Février 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,359 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales