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

PL/SQL Oracle Discussion :

Procedures stockées vs autres procedures


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de links
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    113
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2003
    Messages : 113
    Par défaut Procedures stockées vs autres procedures
    Bonjour,
    J'aimerais savoir quelle est la différence entre procedure stockée et procedure coté client.
    Mis à part le fait que ce sont des procedure sauvegardés dans la base, donc j'imagine que leur execution est plus rapide, qu'elles vont bénéficier de la sauvegarde automatique et qu'elles seront facilement partageable et gérable. Quel autre interet y'a t il a stocker les procedures et quelles sont les particularités de ces procedures ?. Y'a t il un traitement particulier pour les procedures stockées ?
    Merci

  2. #2
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 291
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 291
    Par défaut
    Si tu mets une procédure sur ton appli cliente, elle ne sera pas disponible quand tu utiliseras une autre appli cliente. Tout passer en proc stock permet ainsi de rendre la base autonome par rapport à ses applis, et de ne pas tout redévelopper dans chaque appli. De cette façon, chaque couche est mieux spécialisée sur son rôle : la couche de données s'occupe de tout ce qui est traitement des données, et la couche applicative s'occupe de l'interaction avec les utilisateurs.

  3. #3
    Membre Expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437

  4. #4
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Par défaut
    L'intêret peut être réellement important.

    1/ vitesse : par exemple des traitements locaux faisant intervenir plusieurs dizaines de requêtes et exécutés des milliers des fois sont passer leur temps a faire du ping pong sur le réseau et le temps final (en fonction du traitement) sera en partie du aux roundtrips client/serveur. Avec du pl/sql, les fonctions sont précompilées dans la base et donc plus (ou beaucoup moins) de ping pong. Nous avions au taf un traitement de génération pour chaque patient dans notre appli a exécuter des milliers de fois d'affilé depuis un client lourd. Nous avons passé le code (des dizaines de requetes très lourdes et mettant en oeuvre beaucoup de jointures en PL/SQL. Il ne restait que les appels du client : Résultat : la ou il fallait 30 minutes de traitement total, il ne fallai plus que 2 à 3 minutes.


    2 / la réusabilité du code : nous avions notre base Oracle, un appli client serveur developpée avec un 4GL, un intranet en java, des interfaces avec d'autres systèmes en C, des pocket pc qui synchronisent avec un serveur de syncho en C++, ..
    Bref, tout ce beau monde faisait plus ou moins la même chose. Mais les "même" traitements que l'on retrouvait dans les 5 vecteurs était écris chacun dans un langage différent, à des période différentes, parfois par des personnes différentes, ... Donc, au final, aucun des traitements partagés était différent !!! Impossible à maintenir et a faire évoluer !
    Donc, un beau jour, nous avons pris tout le code commun, crée des packages PL/SQL, avons supprimé les anciens codes par des appels PL/SQL... Et là le bonheur : code identique depuis 5 languages et applications différentes.
    En cas de bug ou d'évolution, 1 seule source à modifier et qui plus est dans un bloc note si faut ! pas re-recompilation à la chaine, ...

    J'espère que cela t'aura éclairé sur les avantages des procédures stockées.
    Surtout que le PL/SQL est le language serveur le plus évolué de tout ceux proposé par des SGDB.. tu faire ce que tu veux (mail, socket, xml, ....)
    Vincent Rogier.

    Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog

    Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !

    OCILIB (C Driver for Oracle)

    Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle

  5. #5
    Membre émérite
    Inscrit en
    Décembre 2003
    Messages
    493
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 493
    Par défaut
    Citation Envoyé par links
    Mis à part le fait que ce sont des procedure sauvegardés dans la base, donc j'imagine que leur execution est plus rapide, qu'elles vont bénéficier de la sauvegarde automatique et qu'elles seront facilement partageable et gérable.
    c'est déjà pas mal

  6. #6
    Membre confirmé Avatar de links
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    113
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2003
    Messages : 113
    Par défaut
    Merci à tous

Discussions similaires

  1. Procedures stockées vs autres procedures
    Par links dans le forum SQL
    Réponses: 18
    Dernier message: 31/01/2008, 23h43
  2. Réponses: 2
    Dernier message: 22/06/2006, 11h26
  3. executer une procedure stockée d'une BD depuis une autre BD
    Par MoTUmBo dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 29/08/2005, 16h02
  4. Procedures stockées qui appellent un autre ?
    Par Tchinkatchuk dans le forum PostgreSQL
    Réponses: 4
    Dernier message: 09/05/2005, 09h30
  5. Réponses: 3
    Dernier message: 21/09/2004, 07h35

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