Précédent   Forum des professionnels en informatique > Bases de données > MySQL > SQL Procédural
SQL Procédural Forum d'entraide sur les triggers, les procédures stockées et les fonctions en MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 16/09/2008, 19h05   #1
Membre habitué
 
Inscription : décembre 2002
Messages : 49
Détails du profil
Informations forums :
Inscription : décembre 2002
Messages : 49
Points : 118
Points : 118
Par défaut renvoyer le résultat d'un tableau avec prétraitement

Bonjour,

J'aimerai enrichir le résultat du d'une requête effectué dans une procédure stocké

en pseudo code
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
CREATE PROCEDURE load_items()
BEGIN
  SELECT id FROM faq ORDER BY question ASC;
 
-- Pour chaque ID
 
-- -- second appel SQL
-- -- fusion avec le premier ensemble de résultat
 
-- Fin Pour
-- renvoie du tout
 
END
le but est de simuler une jointure sur plusieurs vues, les résultats sont trop lents sinon, je pense que y'a des chances qu'on gagnent en performance en faisant les requêtes en séparé.

est ce que c'est possible ? avez vous des exemples ou lien permettant de l'implémenter facilement ?

merci d'avance
mumuri est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/09/2008, 03h31   #2
Expert Confirmé
 
Avatar de Alain Defrance
 
Homme Alain DEFRANCE
Project Lead
Inscription : août 2007
Messages : 1 993
Détails du profil
Informations personnelles :
Nom : Homme Alain DEFRANCE
Âge : 24
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations professionnelles :
Activité : Project Lead

Informations forums :
Inscription : août 2007
Messages : 1 993
Points : 2 919
Points : 2 919
Envoyer un message via MSN à Alain Defrance Envoyer un message via Skype™ à Alain Defrance
Bonjour,

Avec les curseurs cela est possible

Ça donnerais quelque chose de ce style :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
CREATE PROCEDURE load_items()
BEGIN
  DECLARE finDuCurseur INT DEFAULT 0;
  DECLARE idCourant INT;
  DECLARE CURSOR lesFaqs FOR SELECT id FROM faq ORDER BY question ASC;
  DECLARE CONTINUE HANDLER FOR NOT FOUND SET finDuCurseur = 1;
 
  OPEN lesFaqs;
 
  REPEAT
    FETCH lesFaqs INTO idCourant;
    IF NOT finDuCurseur THEN
      --  Seconde requete avec l'id idCourant
    END IF;
  UNTIL finDuCurseur END REPEAT;
 
 
  CLOSE lesFaqs;
 
END
Je ne suis pas convaincu que le SQL procédural soit necessaire ici mais sans plus de détails je ne peut donner d'avis.
__________________
http://alaindefrance.wordpress.com - http://www.alain-defrance.com
Certifications : SCJP6 - SCWCD5 - SCBCD5 - SCMAD1
Project Lead eXo Social
Java Black Belt - Java Black Belt Coach
Alain Defrance est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/09/2008, 23h22   #3
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
Utiliser des curseurs est MAL .

Les jointures sont toujours bcp plus performantes (à condition qu'il y ait les index, évidemment).

Je vous invite à lire la parole du maître : http://sqlpro.developpez.com/cours/s...r_avoidCursor/
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/09/2008, 23h28   #4
Expert Confirmé
 
Avatar de Alain Defrance
 
Homme Alain DEFRANCE
Project Lead
Inscription : août 2007
Messages : 1 993
Détails du profil
Informations personnelles :
Nom : Homme Alain DEFRANCE
Âge : 24
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations professionnelles :
Activité : Project Lead

Informations forums :
Inscription : août 2007
Messages : 1 993
Points : 2 919
Points : 2 919
Envoyer un message via MSN à Alain Defrance Envoyer un message via Skype™ à Alain Defrance
Citation:
Envoyé par Antoun Voir le message
Utiliser des curseurs est MAL
Pas taper

/me part lire le cours
__________________
http://alaindefrance.wordpress.com - http://www.alain-defrance.com
Certifications : SCJP6 - SCWCD5 - SCBCD5 - SCMAD1
Project Lead eXo Social
Java Black Belt - Java Black Belt Coach
Alain Defrance est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 05h53.


 
 
 
 
Partenaires

Hébergement Web