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 :

procedure stockée(NULL to float)


Sujet :

Développement SQL Server

  1. #1
    Membre confirmé
    Inscrit en
    Août 2002
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Août 2002
    Messages : 84
    Par défaut procedure stockée(NULL to float)
    Bonjour ;mon probleme est le suivant:
    j'ai créer une procedure stockée qui me calcul les quantités selon le cas sur une table article. alors quand la somme des qauntité =0 la procedrue lors de la mise a jour inscrit null au lieu de 0. et cela me crée des problemes par la suite. Alors comment je peux resuodre ce probleme .Merci

    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
    22
    23
    24
    25
    26
    CREATE PROCEDURE maj_qt
    @prm CHAR,@art varchar(30)
    AS
    Declare @qt_L float,,@qt_A float;
     
    if @prm='L'
      begin
       select @qt_L=sum(qt)
       from Art_BL
       where refart=@art;
     
     
       update article set qt_L=@qt_L
       WHERE ref=@art
      end
     
      else
      if @prm='A'
       BEGIN
        select @qt_A=sum(qt)
        from Art_achat
        where refart=@art;
     
        update article set qt_Achat=@qt_A
        WHERE ref=@art
      end
    .................
    .................
    ................

  2. #2
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 8
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UPDATE article SET qt_Achat=ISNULL(@qt_A, 0)
        WHERE ref=@art

  3. #3
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 010
    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 : 22 010
    Billets dans le blog
    6
    Par défaut
    Votre requête se résume à un seul ordre SQL UPDATE !
    :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    CREATE PROCEDURE maj_qt @prm CHAR, @art varchar(30)
    AS
     
       UPDATE article 
       SET qt_L = CASE
                     WHEN @prm='L' 
                        THEN COALESCE((SELECT sum(qt)
                                       FROM Art_BL
                                       WHERE refart=@art), 0)
                     WHEN @prm='A' 
                        THEN COALESCE((SELECT sum(qt)
                                       FROM Art_achat
                                       WHERE refart=@ar), 0)
       WHERE ref=@art

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

Discussions similaires

  1. [ADO.NET] Procedure stocké + float + ora 20100
    Par freddyboy dans le forum Interfaces de programmation
    Réponses: 1
    Dernier message: 06/06/2008, 11h04
  2. Réponses: 1
    Dernier message: 04/06/2003, 11h48
  3. procedure stockée champ date
    Par tripper.dim dans le forum SQL
    Réponses: 5
    Dernier message: 25/04/2003, 09h47
  4. Appel a une procedure stockée en vba
    Par The_Nail dans le forum VBA Access
    Réponses: 36
    Dernier message: 01/04/2003, 16h44
  5. procedure stockée dans un dbbatch
    Par pram dans le forum XMLRAD
    Réponses: 4
    Dernier message: 07/02/2003, 16h35

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