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

JDBC Java Discussion :

Déclencheur Java sur Oracle


Sujet :

JDBC Java

  1. #1
    Membre du Club
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2013
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2013
    Messages : 54
    Points : 47
    Points
    47
    Par défaut Déclencheur Java sur Oracle
    Bonsoir ,

    Je suis un habitué de la plateforme Microsoft (SQL Server et c# ).
    J'ai l'habitude de créer des Trigger CLR (Comman Langage Runtime ) c-a-d des déclencheur qui sont créer dans les classe c# puis compiler en DLL et externaliser vers le SGBD.

    Avec cette façon de faire je peux manipuler les valeurs avant et après l'action du trigger (inserted , deleted , updated ) aussi attacher mon trigger a ma table directement dans ma classe sans toutes fois définis celà dans le SGBD.

    https://msdn.microsoft.com/en-us/lib...QL.100%29.aspx

    J'aimerais faire la même chose en Java mais je ne trouve pas de solution car ce que java me propose c'est de lier l'action de mon trigger a une fonction construit et chargé grâce au javaload hors je veux définir mon trigger dans la classe java puis charger dans le SGBD.

    Est il possible ??

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut

    Si c'est un trigger en Java que tu veux faire :
    https://docs.oracle.com/database/121...htm#JJDEV13234
    https://docs.oracle.com/database/121...htm#JJDEV01000
    (exemple Oracle (8)) : http://docs.oracle.com/cd/A87860_01/...8/04_call2.htm


    Si c'est pour enregistrer un écouteur depuis une application Java, il y a oracle.jdbc.dcn.DatabaseChangeListener (Database Change Notification).
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Membre du Club
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2013
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2013
    Messages : 54
    Points : 47
    Points
    47
    Par défaut
    Merci pour ta réaction joel.drigo

    Ou,i j'ai déjà parcouru ces cours mais mon problème avec, c'est que la définition du Trigger est visible au niveau du Gestionnaire de base de données, donc si c'est pour sécuriser ou valider une transaction il peut être supprimé pas le DataBase admin ce que je ne veux pas.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    REATE FUNCTION oscar_quote RETURN VARCHAR2
    2 AS LANGUAGE JAVA
    3 NAME 'Oscar.quote() return java.lang.String';
    Si c'est pour enregistrer un écouteur depuis une application Java, il y a oracle.jdbc.dcn.DatabaseChangeListener (Database Change Notification).
    Cette façon ma l’air intéressante mais ne permet pas de faire du code SQL sur les valeur :NEW ET OLD:

    Voici un exemple de microsoft
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
     
    using System;
    using System.Data;
    using System.Data.Sql;
    using Microsoft.SqlServer.Server;
    using System.Data.SqlClient;
    using System.Data.SqlTypes;
    using System.Xml;
    using System.Text.RegularExpressions;
     
    public class CLRTriggers
    {
        [SqlTrigger(Name = @"UpdateName", Target = "[dbo].[Users]", Event = "FOR INSERT")]
        public static void EmailAudit()
        {
            string userName;
            string realName;
            SqlCommand command;
            SqlTriggerContext triggContext = SqlContext.TriggerContext;
            SqlPipe pipe = SqlContext.Pipe;
            SqlDataReader reader;
     
            using (SqlConnection connection
                      = new SqlConnection(@"context connection=true"))
            {
                connection.Open();
                command = new SqlCommand(@"UPDATE USER SET Name = 'Jean dupond' WHERE ID=(select TOP(1) inserted.ID from inserted);",
                   connection);
                reader = command.ExecuteReader();
                reader.Read();
                userName = (string)reader[0];
                realName = (string)reader[1];
                reader.Close();
            }
        } 
    }
    Ici je définis un Trigger UpdateName sur la table User sur l'événement INSERT qui permet de mettre à jour la valeur du champ name de la table temporaire qui contient les valeurs nouvellement insérées.

    Avec cette façon j'ai juste la DLL qui est chargée dans mon SGBD par besoin de faire une CREATE OR REPLACE externalisé vers une fonction implémentée en Java.

    Donc je voulais avoir ce genre d'implémentation de Trigger si celà est possible en Java.

    Merci d'avance

  4. #4
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par tobus2012 Voir le message
    Oui j'ai déjà parcouru ces cours mais mon problème avec, c'est que la définition du Trigger est visible au niveau du Gestionnaire de base de donnée, donc si c'est pour sécuriser ou valider une transaction il peut être supprimé par le DataBase admin ce que je ne veux pas.
    Oui, enfin, un DBA c'est quelqu'un qui est censé faire ce genre de choses, mais c'est aussi censé être quelqu'un de responsable qui ne fait que ce qui doit être fait et pas ce qu'il ne faut pas. Parce qu'a la limite, il peut aussi faire un DROP DATABASE, s'il veut. Et puis, il y a toujours les grants s'il fallait donner des droits au DBA.

    Citation Envoyé par tobus2012 Voir le message
    Cette façon ma l’air intéressante mais ne permet pas de faire du code SQL sur les valeur :NEW ET OLD:
    Si, bien sûr. Regarde les exemples sur cette documentation : http://docs.oracle.com/cd/E11882_01/...htm#JJDBC28820
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

Discussions similaires

  1. Avis sur CV Ingénieur d'étude Java EE / Oracle
    Par ulspider dans le forum CV
    Réponses: 16
    Dernier message: 03/02/2014, 15h27
  2. Réponses: 5
    Dernier message: 26/03/2011, 18h29
  3. Polling sur Oracle grâce à Java
    Par mikina dans le forum Import/Export
    Réponses: 0
    Dernier message: 20/05/2009, 10h48
  4. Réponses: 2
    Dernier message: 15/02/2008, 12h19
  5. problème déclencheur sur oracle
    Par gapse dans le forum Oracle
    Réponses: 2
    Dernier message: 25/07/2006, 09h58

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