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 :

Nombre de lignes avec exec dans procédure stockée


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de Stephane_br
    Inscrit en
    Septembre 2005
    Messages
    222
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 222
    Par défaut Nombre de lignes avec exec dans procédure stockée
    Bonjour,

    J'ai une Procédure Stockée qui, à partir de variables en entrée, me créé dynamiquement une requête sous forme de chaine que j’exécute à la fin avec la commande
    exec(@machaine)
    ;
    Jusque-là, tout va bien.

    Mon souci, c'est que, avant d’exécuter ma requête, j'aimerais savoir si elle va me retourner des lignes, car si elle ne me retourne rien, j'aimerais ne pas l’exécuter et exécuter une autre requête.
    Le but, me retourner dans la Tables(0) un résultat soit par la requête créée dynamiquement, soit par ma requête alternative.
    De cette manière, je ne me souci pas de qui a trouvé quoi, j'ai toujours un résultat.

    En gros :

    En entrée : declare @myVar1 as int = 0, declare @myVar2 as int = 0, declare @myVar3 as int = 0, ..etc...

    Puis, en variable interne je fais : declare @machaine as varchar(max) = ''
    Puis, ma procédure stockée réalise un traitement qui me génère une requête complète en fonction des données fournies dans les variables en entrée :
    Au final j'obtiens un truc du genre (je simplifie) @machaine = 'select * from maTable ....'

    Avant de lancer la commande exec(@machaine) en fin de procédure stockée, j'aimerais faire un truc du style select count(*) ... et si c'est égal à zéro, je lance une requête alternative.

    Est-ce possible de faire un truc comme ça ? Ou faut-il voir cela autrement ?

    Merci de votre aide.
    Cordialement.

  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
    Par défaut
    Bonjour,

    Est-ce que toutes les requêtes retournent les mêmes colonnes de mêmes types ?

  3. #3
    Membre éclairé Avatar de Stephane_br
    Inscrit en
    Septembre 2005
    Messages
    222
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 222
    Par défaut
    Citation Envoyé par aieeeuuuuu Voir le message
    Bonjour,

    Est-ce que toutes les requêtes retournent les mêmes colonnes de mêmes types ?
    Oui, oui, c'est prévu en effet

  4. #4
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 818
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 818
    Billets dans le blog
    14
    Par défaut
    Pour savoir combien de lignes va renvoyer votre requête dynamique, il faut l'exécuter !

    Mais dans votre procédure, vous pouvez exécuter la requête et récupérer le nombre de lignes retournées dans le jeu de résultat, je pense. Et si votre jeu de résultat est vide, alors lancer la requête alternative avant de terminer la procédure.

    Si par contre le résultat de votre requête dynamique dépend du nombre de ligne dans une table, votre procédure peut commencer par vérifier le nombre de lignes de la table avant de lancer la requête dynamique potentiellement complexe.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  5. #5
    Membre éclairé Avatar de Stephane_br
    Inscrit en
    Septembre 2005
    Messages
    222
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 222
    Par défaut
    Citation Envoyé par CinePhil Voir le message
    Pour savoir combien de lignes va renvoyer votre requête dynamique, il faut l'exécuter !

    Mais dans votre procédure, vous pouvez exécuter la requête et récupérer le nombre de lignes retournées dans le jeu de résultat, je pense. Et si votre jeu de résultat est vide, alors lancer la requête alternative avant de terminer la procédure.

    Si par contre le résultat de votre requête dynamique dépend du nombre de ligne dans une table, votre procédure peut commencer par vérifier le nombre de lignes de la table avant de lancer la requête dynamique potentiellement complexe.
    Merci pour votre réponse.
    Mais pour exécuter ma requête, je suis obliger de remplir ma Tables(0) dans le résultat de ma procédure stockée ?
    Comment l'exécuter avant, sans retourner le résultat ? Et pouvoir lancer ma requête alternative ?
    Est-ce possible de mettre le résultat d'un exec('xx) dans un curseur par exemple ou autre ?
    Ou alors, on ne peut pas faire un truc du genre select count(*) from (exec('xxx')) ? Je sais que ce n'est pas possible.. mais n'y a t--il pas un truc équivalent à cela ?

    ?????
    Désolé

  6. #6
    Membre éclairé Avatar de Stephane_br
    Inscrit en
    Septembre 2005
    Messages
    222
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 222
    Par défaut
    En sachant que j'ai mas requête dans une chaine de caractères.... je peux donc en faire ce que je veux avant de l'éxécuter.
    Je pensais à remplacer tout ce qu'il y a avant le from 'select a, b, ....... from maTable where.....' par un select count mais pareil, je ne sais pas renseigner une variable de type int à partir d'une requête contenu dans une variable de type varchar(x)....

  7. #7
    Membre éclairé Avatar de Stephane_br
    Inscrit en
    Septembre 2005
    Messages
    222
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 222
    Par défaut
    Existe-t-il un objet de type Table dans les procédures stockées que je pourrais manipuler ? Dans l'idée, je rempli cet objet avec ma requête et je peux voir si il est plein ou vide ??? J'imagine que non....

  8. #8
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 818
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 818
    Billets dans le blog
    14
    Par défaut
    Mais pour exécuter ma requête, je suis obliger de remplir ma Tables(0) dans le résultat de ma procédure stockée ?
    Euh... là c'est un peu flou tant qu'on n'a pas le code de la procédure.
    Et de préférence, il faudrait aussi poser le problème dans le forum du SGBD que vous utilisez parce que les syntaxes sont différentes d'un SGBD à l'autre.

    Mais pour exécuter ma requête, je suis obliger de remplir ma Tables(0) dans le résultat de ma procédure stockée ?
    Vous pouvez utiliser un CURSOR ou une table temporaire ou... ça dépend du SGBD...

    Ben avec un IF sur le résultat !


    Bref... postez votre code et dites-nous quel SGBD vous utilisez et on vous réorientera vers le bon forum.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [11g] Problème dans procédure stockée avec ALTER SESSION
    Par seb299792 dans le forum PL/SQL
    Réponses: 6
    Dernier message: 29/06/2017, 09h26
  2. Alter table dans procédure stockée
    Par mehitabelle dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 30/11/2005, 16h14
  3. Réponses: 7
    Dernier message: 16/09/2005, 10h14
  4. procédures stockées dans procédure stockée
    Par olivc dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 30/05/2005, 16h58
  5. SQL dans Procédure stockée
    Par julure dans le forum Oracle
    Réponses: 13
    Dernier message: 02/11/2004, 16h57

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