Précédent   Forum des professionnels en informatique > Bases de données > Firebird > SQL
SQL Forum d'entraide sur le SQL pour Firebird
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 04/05/2005, 11h20   #1
Membre à l'essai
 
Inscription : mars 2004
Messages : 33
Détails du profil
Informations forums :
Inscription : mars 2004
Messages : 33
Points : 23
Points : 23
Par défaut [FB][PS] Tableau d'entier comme paramètre ds 1 Proc Stocké ?

Bonjour,
SGBD : FireBird 1.5
Comment passer un tableau d'entier comme parmètre dans une procédure stocké (et que retourne un tableau de chaine de caractère)?
:
c'est à peu près comme celle là :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
 
CREATE PROCEDURE PS (
   !!!??? tab_ent INT [] )
RETURNS (
    !! ?? tab_str string[])
AS
begin
 
  /* Procedure Text */
 
  suspend;
end
moucrack est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/05/2005, 14h12   #2
Invité de passage
 
Inscription : mai 2005
Messages : 2
Détails du profil
Informations forums :
Inscription : mai 2005
Messages : 2
Points : 2
Points : 2
Y a personne qui peut répondre?
Ca m'interresse aussi!
Utah est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/05/2005, 14h45   #3
Membre Expert
 
Avatar de Barbibulle
 
Frédéric
Inscription : octobre 2002
Messages : 1 722
Détails du profil
Informations personnelles :
Nom : Frédéric
Âge : 42

Informations forums :
Inscription : octobre 2002
Messages : 1 722
Points : 2 025
Points : 2 025
Un tableau ce n'est pas ce qu'il y a de plus facile a manipuler en SQL.

De plus vous ne pourrez faire des tableau dynamique (taille variable) ce qui limite pas mal leur interret du coup...

Et finalement ces déclarations :

sont utilisables pour la déclaration de colonne de tables mais pas dans les PS.

Comment lire un tableau dans un PS allez vous me dire...

Et bien en décomposant le tableau élément par élément :

Code :
1
2
3
4
5
6
7
  FOR SELECT TAB_INT[1], TAB_INT[2], TAB_INT[3], ...
      FROM TAB_ENTIER
      INTO :INT1, :INT2, :INT3,...
  DO
  BEGIN
    SUSPEND;
  END
Ceci dit je vous déconseille d'utiliser les tableau dans les tables, car il vous sera difficile de les mannipuler, si vous changez de SGBD il y a de forte chance que ceux ci se soient pas supportés. Enfin ces tableau sont très facilement remplacable par une table liée par une FK. Ce qui en plus occupera certainement moins de place a moins que tous les emplacements de votre tableau ne soit systèmatiquement remplie (dans ce cas créez autant de colonne dans votre table).
Barbibulle est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/05/2005, 14h59   #4
Invité de passage
 
Inscription : mai 2005
Messages : 2
Détails du profil
Informations forums :
Inscription : mai 2005
Messages : 2
Points : 2
Points : 2
Merci pour la réponse!

J'espérais qu'il y avait un moyen de déclarer des variables de type tableau de qqch...
Apparemment, ce n'est pas possible, on est quasiment obligé de passer par une table, dommage...

Utah est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 20/05/2005, 15h03   #5
Membre éclairé
 
Inscription : décembre 2004
Messages : 379
Détails du profil
Informations forums :
Inscription : décembre 2004
Messages : 379
Points : 304
Points : 304
au sujet des tableaux, j'ai eu le même genre de question et j'ai contourné la chose en déclarant un type varchar(32760) que je remplis avec les données, et à l'autre bout, dans l'application, je reconstruis le tableau (c'est donc une sérialisation des données)

le gain de temps dans mon cas fut fabuleux! un traitement de plus de 2 heures et passé à quelques minutes! (à cause de sous-requêtes qui sont passées dans la procédure)

mais il faut dire que la tâche demandée était (est) assez tordue...

donc, cela vaut la peine de consacrer un peu de temps à la question, mais avant de ce lancer, il faut absolument étudier la question et voir si il n'existe pas d'autres solutions!
jean-jacques varvenne est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 20/05/2005, 18h53   #6
Membre à l'essai
 
Inscription : mars 2004
Messages : 33
Détails du profil
Informations forums :
Inscription : mars 2004
Messages : 33
Points : 23
Points : 23
Par défaut A quoi sert ?

Merci pour tous,

Mais !!

Dans une PS, on ne peut declarer les tableaus ni comme paramètre d'entrée, ni comme paramètre de sortie!!!??

Juste manipulation à l'interieur PS! elle devient initule donc!

Mais pourquoi ? :
moucrack est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 23/05/2005, 10h47   #7
Membre éclairé
 
Inscription : décembre 2004
Messages : 379
Détails du profil
Informations forums :
Inscription : décembre 2004
Messages : 379
Points : 304
Points : 304
les procédures stockées ne sont pas inutiles (si je comprend la question/affirmation) elles permettent de résoudre bien des problèmes de manières élégantes et très performantes, même si tout n'est pas parfait en matière de paramètre ou de tableau.

cela dit utiliser un type char ou varchar pour transmettre des tableaux fonctionne parfaitement, pour info, j'ai développée une udf qui parse les chaînes et retourne les mots dans une structure de type tableau et j'utilise le type char() pour balader les tableaux et cela fonctionne parfaitement.

il y a certainement une solution alternative à ton problème, par exemple, si tu n'a que des valeurs entières, il serait facile de construire une udf qui recoit une valeur entière et retourne la valeur en binaire qui peut-être contenu dans un char(4) (ou en code "AA" et dans ce cas, la chaîne fait 8 caractères) et donc plusieurs valeurs dans un multiple de 4 (ou de 8 en code "AA") qu'en pense-tu?

une autre approche c'est d'utiliser la fonction chr() de rfunc et de décomposer les valeurs en caractères pour les transmettres ensuite dans une chaîne.

tu vois, il existe des solutions.
jean-jacques varvenne 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 06h41.


 
 
 
 
Partenaires

Hébergement Web