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 01/04/2011, 10h16   #1
Membre du Club
 
Femme
Inscription : avril 2007
Messages : 141
Détails du profil
Informations personnelles :
Sexe : Femme
Localisation : Suisse

Informations forums :
Inscription : avril 2007
Messages : 141
Points : 41
Points : 41
Par défaut CREATE VIEW à partir de EXECUTE BLOCK.

Bonjour tout le monde.

Est-il possible, avec Firebird 2.5, de créer une vue à partir du résultat d'un EXECUTE BLOCK ?

Je m'explique, j'ai un block du type :

Code :
1
2
3
4
5
6
7
8
execute block returns (v1 smallint,v2 smallint) AS
begin
     FOR EXECUTE STATEMENT 'select v1,v2 from data'
     ON EXTERNAL DATA SOURCE 'c:\test.fdb' 
     AS USER 'sysdba' PASSWORD 'masterkey'
     INTO :v1,:v2
     DO SUSPEND;
End
Qui me retourne une liste de données V1 et V2. J'aimerais savoir si il est possible de créer une vue contenant ces données

Je débute avec les procédure Firebird donc j'ai encore pas mal de peine.

Merci d'avance.
Nono23 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/04/2011, 23h05   #2
Membre éprouvé
 
Avatar de JustMe
 
Inscription : juillet 2002
Messages : 432
Détails du profil
Informations forums :
Inscription : juillet 2002
Messages : 432
Points : 441
Points : 441
Une vue n'est qu'une simple requête stocké dans la base de données, on ne peut pas y insérer des données dedans.
Si tu expliquais ce que tu veux faire tu auras surement des réponses. Dans ce forum on trouve toujours une solution à nos problèmes.
__________________
<On fait la science avec des faits, comme on fait une maison avec des pierres : mais une accumulation de faits n'est pas plus une science qu'un tas de pierres n'est une maison> **Poincaré**
http://www.mobile-tactile.com/
JustMe est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/04/2011, 07h42   #3
Membre du Club
 
Femme
Inscription : avril 2007
Messages : 141
Détails du profil
Informations personnelles :
Sexe : Femme
Localisation : Suisse

Informations forums :
Inscription : avril 2007
Messages : 141
Points : 41
Points : 41
Salut JustMe, merci de ta réponse.

En fait, l'idée serait d'avoir un SELECT multibase. et comme on ne peut pas mettre directement le "execute block returns" dans un SELECT, je me disais qu'en passant par une vue intermédiaire et en faisant le SELECT en incluant la vue j'arriverais à mes fins. Crois-tu que c'est possible?

Merci d'avance
Nono23 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/04/2011, 20h28   #4
Expert Confirmé

 
Homme Philippe Makowski
Consultant spécialité Firebird
Inscription : mai 2002
Messages : 2 213
Détails du profil
Informations personnelles :
Nom : Homme Philippe Makowski
Âge : 49
Localisation : France

Informations professionnelles :
Activité : Consultant spécialité Firebird
Secteur : Conseil

Informations forums :
Inscription : mai 2002
Messages : 2 213
Points : 3 315
Points : 3 315
utilise une procedure stockée

Code :
1
2
3
4
5
6
7
8
CREATE PROCEDURE MAPROC returns (v1 smallint,v2 smallint) AS
begin
     FOR EXECUTE STATEMENT 'select v1,v2 from data'
     ON EXTERNAL DATA SOURCE 'c:\test.fdb' 
     AS USER 'sysdba' PASSWORD 'masterkey'
     INTO :v1,:v2
     DO SUSPEND;
End
et ensuite
Code :
SELECT v1, v2 FROM MAPROC
__________________
Philippe Makowski
IBPhoenix - Firebird
Membre de l'April
makowski est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/04/2011, 07h58   #5
Membre du Club
 
Femme
Inscription : avril 2007
Messages : 141
Détails du profil
Informations personnelles :
Sexe : Femme
Localisation : Suisse

Informations forums :
Inscription : avril 2007
Messages : 141
Points : 41
Points : 41
Salut Makowski, merci beaucoup pour ta réponse, c'est exactement ce que je cherchais.

J'ai encore juste une petite question, est-ce que tu sais si il est possible de spécifier, dans la partie

Code :
ON EXTERNAL DATA SOURCE 'c:\test.fdb'
Le nom de l'alias ODBC de la BDD au lieu du chemin physique du fichier FDB?

Merci encore
Nono23 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/04/2011, 09h41   #6
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
Bonjour,

Cela serait étonnant... Vu que firebird n'utilise pas ODBC.

Par contre tu peux essayer de mettre un alias firebird (je n'ai pas testé mais il y a des chances que ca fonctionne).
Barbibulle est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/04/2011, 16h34   #7
Expert Confirmé

 
Homme Philippe Makowski
Consultant spécialité Firebird
Inscription : mai 2002
Messages : 2 213
Détails du profil
Informations personnelles :
Nom : Homme Philippe Makowski
Âge : 49
Localisation : France

Informations professionnelles :
Activité : Consultant spécialité Firebird
Secteur : Conseil

Informations forums :
Inscription : mai 2002
Messages : 2 213
Points : 3 315
Points : 3 315
Barbidule à raison
pas ODBC
quelle idée saugrenue d'ailleurs !

mais l'alias Firebird oui
__________________
Philippe Makowski
IBPhoenix - Firebird
Membre de l'April
makowski est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 04h07.


 
 
 
 
Partenaires

Hébergement Web