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 :

Erreur formules procédure SQL Server


Sujet :

Développement SQL Server

  1. #1
    Membre du Club
    Femme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2012
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Transports

    Informations forums :
    Inscription : Juillet 2012
    Messages : 49
    Points : 42
    Points
    42
    Par défaut Erreur formules procédure SQL Server
    Bonjour,

    Voici un bout de code d'une procédure SQL Server qui vérifie une variable @Formule déclarée et valoriser plus haut.

    Comme son nom l'indique cette variable contient une formule que la procédure calculera par la suite. Cette formule est saisie par l'utilisateur via une application.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    if @Formule is null or @Formule = ''
    begin
    set @Formule = null
    return
    end
    Malheureusement, @Formule peut contenir des formules qui ne sont pas valide, et peu générer des erreurs SQL.

    Ce que j'aimerais faire c'est rajouter quelque chose du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    if @Formule is null or @Formule = '' or @Formule = non calculable
    begin
    set @Formule = null
    return
    end
    J'aimerais rajouter une condition qui dirais que si la formule n'est pas calculable, elle passe a NULL.

    J'avais penser à faire une procédure en plus pour justement tester la validité de la formule, mais je suis un peu débutante en procédure SQL Server.

    Existe t-il une fonction intégrer à SQL pour tester si la formule est calculable ou pas ?

    En fait le client souhaite ignorer les formules non valide et passer aux suivantes, j'ai oublier de préciser que @formule est traité dans une boucle.

    A chaque passage dans la boucle, @formule prend une nouvelle valeur et si sa valeur n'est pas calculable, la procédure s'arrête net et les formules suivante ne sont pas calculées.

    J'ai grand besoin de votre aide, cela fait plusieurs jour que je cherche sans grand succès .

    Merci d'avance

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Avec un petit exemple, ça serait sûrement plus clair.

    Le code complet de la procédure serait utile aussi...

  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
    21 772
    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 772
    Points : 52 732
    Points
    52 732
    Billets dans le blog
    5
    Par défaut
    Il faut que vous fassiez cela en SQL dynamique avec un bloc TRY/EXCEPT.

    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/ * * * * *

  4. #4
    Membre éprouvé
    Avatar de landry161
    Homme Profil pro
    C#,PHP,MySQL,Android...
    Inscrit en
    Juillet 2010
    Messages
    423
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : C#,PHP,MySQL,Android...

    Informations forums :
    Inscription : Juillet 2010
    Messages : 423
    Points : 1 059
    Points
    1 059
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par aieeeuuuuu Voir le message
    Bonjour,

    Avec un petit exemple, ça serait sûrement plus clair.

    Le code complet de la procédure serait utile aussi...
    Ouais

  5. #5
    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 : 42
    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
    Points : 3 173
    Points
    3 173
    Par défaut
    Il faut que vous fassiez cela en SQL dynamique avec un bloc TRY/EXCEPT.
    avec cette solution, pensez à faire un rollback à chaque fois! bonjour la faille de sécurité via injection SQL!
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

Discussions similaires

  1. Erreur de connexion à Sql server 2005 Express
    Par penchu dans le forum ASP.NET
    Réponses: 3
    Dernier message: 21/04/2008, 17h35
  2. Erreur en connexion à SQL Server 2000
    Par sonorc dans le forum JDBC
    Réponses: 2
    Dernier message: 03/03/2008, 21h55
  3. Récupérer les lignes d'une procédure SQL Server dans le programme VB.NET
    Par Mikelester12 dans le forum Accès aux données
    Réponses: 2
    Dernier message: 30/07/2007, 11h33
  4. Problème de formule dans sql server 2000
    Par flegros21 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 08/02/2007, 15h15
  5. migration - procédure SQL Server
    Par habasque dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 05/12/2006, 11h40

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